[ML] Add an assertion on annotations mappings to upgrade test (#62331)

The annotations index is not covered by the comparison between
mappings and templates, as it does not use an index template.

This commit adds an assertion on annotations index mappings
that will fail if the mappings are not upgraded as expected.

Backport of #62325
This commit is contained in:
David Roberts 2020-09-14 18:46:35 +01:00 committed by GitHub
parent ec335c7c34
commit 3d5c13f559
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 32 additions and 0 deletions

View File

@ -53,6 +53,7 @@ public class MlMappingsUpgradeIT extends AbstractUpgradeTestCase {
break; break;
case UPGRADED: case UPGRADED:
assertUpgradedResultsMappings(); assertUpgradedResultsMappings();
assertUpgradedAnnotationsMappings();
closeAndReopenTestJob(); closeAndReopenTestJob();
assertUpgradedConfigMappings(); assertUpgradedConfigMappings();
assertMappingsMatchTemplates(); assertMappingsMatchTemplates();
@ -127,6 +128,37 @@ public class MlMappingsUpgradeIT extends AbstractUpgradeTestCase {
}); });
} }
@SuppressWarnings("unchecked")
private void assertUpgradedAnnotationsMappings() throws Exception {
assertBusy(() -> {
Request getMappings = new Request("GET", ".ml-annotations-write/_mappings");
Response response = client().performRequest(getMappings);
Map<String, Object> responseLevel = entityAsMap(response);
assertNotNull(responseLevel);
Map<String, Object> indexLevel = null;
// The name of the concrete index underlying the annotations index write alias may or may not have been
// changed by the upgrade process (depending on what other tests are being run and the order they're run
// in), so navigating to the next level of the tree must account for both cases
for (Map.Entry<String, Object> entry : responseLevel.entrySet()) {
if (entry.getKey().startsWith(".ml-annotations-")) {
indexLevel = (Map<String, Object>) entry.getValue();
break;
}
}
assertNotNull(indexLevel);
assertEquals(Version.CURRENT.toString(), extractValue("mappings._meta.version", indexLevel));
// TODO: as the years go by, the field we assert on here should be changed
// to the most recent field we've added that would be incorrectly mapped by dynamic
// mappings, for example a field we want to be "keyword" incorrectly mapped as "text"
assertEquals("Incorrect type for event in " + responseLevel, "keyword",
extractValue("mappings.properties.event.type", indexLevel));
});
}
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
private void assertUpgradedConfigMappings() throws Exception { private void assertUpgradedConfigMappings() throws Exception {