From 8f93da5e498319d9d0e411e739fc3a29e6d3f238 Mon Sep 17 00:00:00 2001 From: Andrew Ross Date: Tue, 3 May 2022 14:48:07 -0500 Subject: [PATCH] Fix minimum index compatibility error message (#3159) This is a very simple fix that adds a special case for the backward compatibility message for OS 1.x/ES 7.x. This basically mirrors a special case already codified in [Version][1]. I think this is a reasonable fix because it allows the message to be quite verbose. It should also only need to exist on the 2.x branch of OpenSearch since it is a special case that will no longer exist in 3.x when the entire LegacyESVersion concept can be removed from the code base. [1]: https://github.com/opensearch-project/OpenSearch/blob/cb238aae616d6a0fd8f82e128a1f94c8e4e8b1f7/server/src/main/java/org/opensearch/Version.java#L398 Signed-off-by: Andrew Ross (cherry picked from commit 300620edada9ef41403f5ae27a3b581b651f5cb2) --- .../metadata/MetadataIndexUpgradeService.java | 44 +++++++++++++------ .../MetadataIndexUpgradeServiceTests.java | 27 +++++------- 2 files changed, 42 insertions(+), 29 deletions(-) diff --git a/server/src/main/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeService.java b/server/src/main/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeService.java index f6f42e0d81063..eb2126bddf7a6 100644 --- a/server/src/main/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeService.java +++ b/server/src/main/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeService.java @@ -37,6 +37,7 @@ import org.apache.lucene.analysis.Analyzer; import org.apache.lucene.search.similarities.BM25Similarity; import org.apache.lucene.search.similarities.Similarity; +import org.opensearch.LegacyESVersion; import org.opensearch.Version; import org.opensearch.common.TriFunction; import org.opensearch.common.settings.IndexScopedSettings; @@ -134,20 +135,35 @@ boolean isUpgraded(IndexMetadata indexMetadata) { private void checkSupportedVersion(IndexMetadata indexMetadata, Version minimumIndexCompatibilityVersion) { if (indexMetadata.getState() == IndexMetadata.State.OPEN && isSupportedVersion(indexMetadata, minimumIndexCompatibilityVersion) == false) { - throw new IllegalStateException( - "The index [" - + indexMetadata.getIndex() - + "] was created with version [" - + indexMetadata.getCreationVersion() - + "] but the minimum compatible version is [" - - + minimumIndexCompatibilityVersion - + "]. It should be re-indexed in OpenSearch " - + minimumIndexCompatibilityVersion.major - + ".x before upgrading to " - + Version.CURRENT - + "." - ); + if (minimumIndexCompatibilityVersion.equals(LegacyESVersion.V_7_0_0)) { + // This branch can be removed when LegacyESVersion is removed + throw new IllegalStateException( + "The index [" + + indexMetadata.getIndex() + + "] was created with version [" + + indexMetadata.getCreationVersion() + + "] but the minimum compatible version is " + + "OpenSearch 1.0.0 (or Elasticsearch 7.0.0). " + + "It should be re-indexed in OpenSearch 1.x " + + "(or Elasticsearch 7.x) before upgrading to " + + Version.CURRENT + + "." + ); + } else { + throw new IllegalStateException( + "The index [" + + indexMetadata.getIndex() + + "] was created with version [" + + indexMetadata.getCreationVersion() + + "] but the minimum compatible version is [" + + minimumIndexCompatibilityVersion + + "]. It should be re-indexed in OpenSearch " + + minimumIndexCompatibilityVersion.major + + ".x before upgrading to " + + Version.CURRENT + + "." + ); + } } } diff --git a/server/src/test/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeServiceTests.java b/server/src/test/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeServiceTests.java index cee95323b8129..ed01f1753e70e 100644 --- a/server/src/test/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeServiceTests.java +++ b/server/src/test/java/org/opensearch/cluster/metadata/MetadataIndexUpgradeServiceTests.java @@ -139,24 +139,21 @@ public void testFailUpgrade() { .put(IndexMetadata.SETTING_VERSION_CREATED, indexCreated) .build() ); - String message = expectThrows( + String actualMessage = expectThrows( IllegalStateException.class, () -> service.upgradeIndexMetadata(metadata, Version.CURRENT.minimumIndexCompatibilityVersion()) ).getMessage(); - assertEquals( - message, - "The index [[foo/BOOM]] was created with version [" - + indexCreated - + "] " - + "but the minimum compatible version is [" - + minCompat - + "]." - + " It should be re-indexed in OpenSearch " - + minCompat.major - + ".x before upgrading to " - + Version.CURRENT.toString() - + "." - ); + + String expectedMessage = "The index [[foo/BOOM]] was created with version [" + + indexCreated + + "] but the minimum compatible version is " + + "OpenSearch 1.0.0 (or Elasticsearch 7.0.0). " + + "It should be re-indexed in OpenSearch 1.x " + + "(or Elasticsearch 7.x) before upgrading to " + + Version.CURRENT + + "."; + + assertEquals(expectedMessage, actualMessage); indexCreated = VersionUtils.randomVersionBetween(random(), minCompat, Version.CURRENT); indexUpgraded = VersionUtils.randomVersionBetween(random(), indexCreated, Version.CURRENT);