From 8c962acc3b1157f62fd7fb2ad1b416c376be9dbb Mon Sep 17 00:00:00 2001 From: Hailong Cui Date: Thu, 29 Jun 2023 17:58:22 +0800 Subject: [PATCH 1/4] Metadata members from ImmutableOpenMap to j.u.Map Signed-off-by: Hailong Cui --- .../IndexStateManagementHistory.kt | 7 +++++-- .../indexstatemanagement/ManagedIndexRunner.kt | 6 +++--- .../indexstatemanagement/MetadataService.kt | 12 +++++++----- .../opensearchapi/OpenSearchExtensions.kt | 4 +--- .../step/shrink/AttemptMoveShardsStep.kt | 5 +++-- .../step/shrink/WaitForMoveShardsStep.kt | 9 +++++---- .../step/shrink/WaitForShrinkStep.kt | 2 +- .../action/explain/TransportExplainAction.kt | 2 +- .../rollup/RollupMapperService.kt | 4 ++-- .../util/RollupFieldValueExpressionResolver.kt | 4 ++-- .../indexmanagement/util/IndexUtils.kt | 4 ++-- .../IndexStateManagementIntegTestCase.kt | 2 +- .../MetadataRegressionIT.kt | 18 +++++++++--------- .../MetadataServiceTests.kt | 3 +-- .../step/AttemptTransitionStepTests.kt | 3 +-- .../rollup/RollupMapperServiceTests.kt | 7 ++----- .../snapshotmanagement/TestUtils.kt | 3 +-- 17 files changed, 47 insertions(+), 48 deletions(-) diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementHistory.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementHistory.kt index 9c46489d8..b957f7714 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementHistory.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementHistory.kt @@ -176,7 +176,7 @@ class IndexStateManagementHistory( clusterStateRequest, object : ActionListener { override fun onResponse(clusterStateResponse: ClusterStateResponse) { - if (!clusterStateResponse.state.metadata.indices.isEmpty) { + if (!clusterStateResponse.state.metadata.indices.isEmpty()) { val indicesToDelete = getIndicesToDelete(clusterStateResponse) logger.info("Deleting old history indices viz $indicesToDelete") deleteAllOldHistoryIndices(indicesToDelete) @@ -199,7 +199,10 @@ class IndexStateManagementHistory( val creationTime = indexMetaData.creationDate if ((Instant.now().toEpochMilli() - creationTime) > historyRetentionPeriod.millis) { - val alias = indexMetaData.aliases.firstOrNull { IndexManagementIndices.HISTORY_WRITE_INDEX_ALIAS == it.value.alias } + val alias = indexMetaData.aliases.firstNotNullOfOrNull { + alias -> + IndexManagementIndices.HISTORY_WRITE_INDEX_ALIAS == alias.value.alias + } if (alias != null && historyEnabled) { // If index has write alias and history is enable, don't delete the index. continue diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/ManagedIndexRunner.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/ManagedIndexRunner.kt index a6fdfdba8..c8d65321a 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/ManagedIndexRunner.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/ManagedIndexRunner.kt @@ -262,12 +262,12 @@ object ManagedIndexRunner : } // Check the cluster state for the index metadata - var clusterStateIndexMetadata = getIndexMetadata(managedIndexConfig.index) + val clusterStateIndexMetadata = getIndexMetadata(managedIndexConfig.index) val defaultIndexMetadataService = indexMetadataProvider.services[DEFAULT_INDEX_TYPE] as DefaultIndexMetadataService val clusterStateIndexUUID = clusterStateIndexMetadata?.let { defaultIndexMetadataService.getCustomIndexUUID(it) } // If the index metadata is null, the index is not in the cluster state. If the index metadata is not null, but // the cluster state index uuid differs from the one in the managed index config then the config is referring - // to a different index which does not exist in the cluster. We need to check all of the extensions to confirm an index exists + // to a different index which does not exist in the cluster. We need to check all the extensions to confirm an index exists if (clusterStateIndexMetadata == null || clusterStateIndexUUID != managedIndexConfig.indexUuid) { // If the cluster state/default index type didn't have an index with a matching name and uuid combination, try all other index types val nonDefaultIndexTypes = indexMetadataProvider.services.keys.filter { it != DEFAULT_INDEX_TYPE } @@ -846,7 +846,7 @@ object ManagedIndexRunner : val response: ClusterStateResponse = client.admin().cluster().suspendUntil { state(clusterStateRequest, it) } - indexMetaData = response.state.metadata.indices.firstOrNull()?.value + indexMetaData = response.state.metadata.indices[index] } catch (e: Exception) { logger.error("Failed to get IndexMetaData from cluster manager cluster state for index=$index", e) } diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt index c42682f71..55da58544 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt @@ -111,11 +111,13 @@ class MetadataService( val indexUuidMap = mutableMapOf() clusterStateManagedIndexMetadata.forEach { (indexName, metadata) -> val indexMetadata = indicesMetadata[indexName] - val currentIndexUuid = indexMetadata.indexUUID - if (currentIndexUuid != metadata?.indexUuid) { - corruptManagedIndices.add(indexMetadata.index) - } else { - indexUuidMap[currentIndexUuid] = indexName + indexMetadata?.let { + val currentIndexUuid = it.indexUUID + if (currentIndexUuid != metadata?.indexUuid) { + corruptManagedIndices.add(it.index) + } else { + indexUuidMap[currentIndexUuid] = indexName + } } } logger.info("Corrupt managed indices with outdated index uuid in metadata: $corruptManagedIndices") diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/opensearchapi/OpenSearchExtensions.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/opensearchapi/OpenSearchExtensions.kt index 157676f00..cb7e4c6ad 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/opensearchapi/OpenSearchExtensions.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/opensearchapi/OpenSearchExtensions.kt @@ -199,8 +199,6 @@ fun XContentBuilder.buildMetadata(name: String, metadata: ToXContentFragment, pa // Get the oldest rollover time or null if index was never rolled over fun IndexMetadata.getOldestRolloverTime(): Instant? { - return this.rolloverInfos.values() - .map { it.value.time } - .minOrNull() // oldest should be min as its epoch time + return this.rolloverInfos.values.minOfOrNull { it.time } // oldest should be min as its epoch time ?.let { Instant.ofEpochMilli(it) } } diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/AttemptMoveShardsStep.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/AttemptMoveShardsStep.kt index a08e5beaf..9754f5d8a 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/AttemptMoveShardsStep.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/AttemptMoveShardsStep.kt @@ -84,7 +84,8 @@ class AttemptMoveShardsStep(private val action: ShrinkAction) : ShrinkStep(name, val (statsStore, statsDocs, shardStats) = getIndexStats(indexName, client) ?: return this val indexSize = statsStore.sizeInBytes // Get stats of current and target shards - val numOriginalShards = context.clusterService.state().metadata.indices[indexName].numberOfShards + val numOriginalShards = context.clusterService.state().metadata.indices[indexName]?.numberOfShards + ?: error("numOriginalShards should not be null") val numTargetShards = getNumTargetShards(numOriginalShards, indexSize) if (shouldFailTooManyDocuments(statsDocs, numTargetShards)) return this @@ -215,7 +216,7 @@ class AttemptMoveShardsStep(private val action: ShrinkAction) : ShrinkStep(name, private fun shouldFailUnsafe(clusterService: ClusterService, indexName: String): Boolean { // If forceUnsafe is set and is true, then we don't even need to check the number of replicas if (action.forceUnsafe == true) return false - val numReplicas = clusterService.state().metadata.indices[indexName].numberOfReplicas + val numReplicas = clusterService.state().metadata.indices[indexName]?.numberOfReplicas val shouldFailForceUnsafeCheck = numReplicas == 0 if (shouldFailForceUnsafeCheck) { logger.info(UNSAFE_FAILURE_MESSAGE) diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForMoveShardsStep.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForMoveShardsStep.kt index e4f27686b..943f59279 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForMoveShardsStep.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForMoveShardsStep.kt @@ -33,7 +33,8 @@ class WaitForMoveShardsStep(private val action: ShrinkAction) : ShrinkStep(name, val numShardsInSync = getNumShardsInSync(shardStats, context.clusterService.state(), indexName) val nodeToMoveOnto = localShrinkActionProperties.nodeName val numShardsOnNode = getNumShardsWithCopyOnNode(shardStats, context.clusterService.state(), nodeToMoveOnto) - val numPrimaryShards = context.clusterService.state().metadata.indices[indexName].numberOfShards + val numPrimaryShards = context.clusterService.state().metadata.indices[indexName]?.numberOfShards + ?: error("numberOfShards should not be null") // If a copy of each shard is on the node, and all shards are in sync, move on if (numShardsOnNode >= numPrimaryShards && numShardsInSync >= numPrimaryShards) { @@ -49,8 +50,8 @@ class WaitForMoveShardsStep(private val action: ShrinkAction) : ShrinkStep(name, // Returns the number of shard IDs where all primary and replicas are in sync private fun getNumShardsInSync(shardStats: Array, state: ClusterState, indexName: String): Int { - val numReplicas = state.metadata.indices[indexName].numberOfReplicas - val inSyncAllocations = state.metadata.indices[indexName].inSyncAllocationIds + val numReplicas = state.metadata.indices[indexName]?.numberOfReplicas ?: error("numberOfReplicas should not be null") + val inSyncAllocations = state.metadata.indices[indexName]?.inSyncAllocationIds var numShardsInSync = 0 for (shard: ShardStats in shardStats) { val routingInfo = shard.shardRouting @@ -58,7 +59,7 @@ class WaitForMoveShardsStep(private val action: ShrinkAction) : ShrinkStep(name, if (routingInfo.primary()) { // All shards must be in sync as it isn't known which shard (replica or primary) will be // moved to the target node and used in the shrink. - if (inSyncAllocations[routingInfo.id].size == (numReplicas + 1)) { + if (inSyncAllocations?.get(routingInfo.id)?.size == (numReplicas + 1)) { numShardsInSync++ } } diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForShrinkStep.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForShrinkStep.kt index 6eb783a85..906360039 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForShrinkStep.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/shrink/WaitForShrinkStep.kt @@ -54,7 +54,7 @@ class WaitForShrinkStep(private val action: ShrinkAction) : ShrinkStep(name, tru private suspend fun shrinkNotDone(targetIndex: String, targetNumShards: Int, client: Client, clusterService: ClusterService): Boolean { val numPrimaryShardsStarted = getNumPrimaryShardsStarted(client, targetIndex) - val numPrimaryShards = clusterService.state().metadata.indices[targetIndex].numberOfShards + val numPrimaryShards = clusterService.state().metadata.indices[targetIndex]?.numberOfShards return numPrimaryShards != targetNumShards || numPrimaryShardsStarted != targetNumShards } diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/transport/action/explain/TransportExplainAction.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/transport/action/explain/TransportExplainAction.kt index a007e2868..3ea39159c 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/transport/action/explain/TransportExplainAction.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/transport/action/explain/TransportExplainAction.kt @@ -269,7 +269,7 @@ class TransportExplainAction @Inject constructor( clusterStateRequest, object : ActionListener { override fun onResponse(response: ClusterStateResponse) { - val clusterStateIndexMetadatas = response.state.metadata.indices.associate { it.key to it.value } + val clusterStateIndexMetadatas = response.state.metadata.indices getMetadataMap(clusterStateIndexMetadatas, threadContext) } diff --git a/src/main/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperService.kt b/src/main/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperService.kt index 2f44f4389..8ac3b365e 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperService.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperService.kt @@ -343,9 +343,9 @@ class RollupMapperService( return RollupJobValidationResult.Failure(getMappingsResult.message, getMappingsResult.cause) } - val indexMapping: MappingMetadata = res.mappings[targetIndexResolvedName] + val indexMapping: MappingMetadata? = res.mappings[targetIndexResolvedName] - return if (((indexMapping.sourceAsMap?.get(_META) as Map<*, *>?)?.get(ROLLUPS) as Map<*, *>?)?.containsKey(rollup.id) == true) { + return if (((indexMapping?.sourceAsMap?.get(_META) as Map<*, *>?)?.get(ROLLUPS) as Map<*, *>?)?.containsKey(rollup.id) == true) { RollupJobValidationResult.Valid } else { RollupJobValidationResult.Invalid("Rollup job [${rollup.id}] does not exist in rollup index [$targetIndexResolvedName]") diff --git a/src/main/kotlin/org/opensearch/indexmanagement/rollup/util/RollupFieldValueExpressionResolver.kt b/src/main/kotlin/org/opensearch/indexmanagement/rollup/util/RollupFieldValueExpressionResolver.kt index fe2c38801..f800b54cd 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/rollup/util/RollupFieldValueExpressionResolver.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/rollup/util/RollupFieldValueExpressionResolver.kt @@ -57,9 +57,9 @@ object RollupFieldValueExpressionResolver { open class IndexAliasUtils(val clusterService: ClusterService) { open fun hasAlias(index: String): Boolean { - val aliases = this.clusterService.state().metadata().indices.get(index)?.aliases + val aliases = this.clusterService.state().metadata().indices[index]?.aliases if (aliases != null) { - return aliases.size() > 0 + return aliases.isNotEmpty() } return false } diff --git a/src/main/kotlin/org/opensearch/indexmanagement/util/IndexUtils.kt b/src/main/kotlin/org/opensearch/indexmanagement/util/IndexUtils.kt index 7edf0b613..c3c923bec 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/util/IndexUtils.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/util/IndexUtils.kt @@ -80,10 +80,10 @@ class IndexUtils { return DEFAULT_SCHEMA_VERSION } - fun shouldUpdateIndex(index: IndexMetadata, newVersion: Long): Boolean { + fun shouldUpdateIndex(index: IndexMetadata?, newVersion: Long): Boolean { var oldVersion = DEFAULT_SCHEMA_VERSION - val indexMapping = index.mapping()?.sourceAsMap() + val indexMapping = index?.mapping()?.sourceAsMap() if (indexMapping != null && indexMapping.containsKey(_META) && indexMapping[_META] is HashMap<*, *>) { val metaData = indexMapping[_META] as HashMap<*, *> if (metaData.containsKey(SCHEMA_VERSION)) { diff --git a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementIntegTestCase.kt b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementIntegTestCase.kt index aa2027f0a..ed6c02a18 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementIntegTestCase.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/IndexStateManagementIntegTestCase.kt @@ -109,7 +109,7 @@ abstract class IndexStateManagementIntegTestCase : OpenSearchIntegTestCase() { // return listOf(TestPlugin::class.java) // } - protected fun getIndexMetadata(indexName: String): IndexMetadata { + protected fun getIndexMetadata(indexName: String): IndexMetadata? { return client().admin().cluster().prepareState() .setIndices(indexName) .setMetadata(true).get() diff --git a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataRegressionIT.kt b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataRegressionIT.kt index e18aa6c33..cbee16532 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataRegressionIT.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataRegressionIT.kt @@ -70,7 +70,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { addPolicyToIndex(indexName, policyID) // put some metadata into cluster state - var indexMetadata = getIndexMetadata(indexName) + var indexMetadata = getIndexMetadata(indexName)!! metadataToClusterState = metadataToClusterState.copy( index = indexName, indexUuid = indexMetadata.indexUUID, @@ -85,7 +85,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { UpdateManagedIndexMetaDataAction.INSTANCE, request ).get() logger.info(response.isAcknowledged) - indexMetadata = getIndexMetadata(indexName) + indexMetadata = getIndexMetadata(indexName)!! logger.info("check if metadata is saved in cluster state: ${indexMetadata.getCustomData("managed_index_metadata")}") // TODO increase wait time since flaky seeing here. After looking through the log @@ -102,7 +102,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { "Happy moving", getExplainManagedIndexMetaData(indexName).info?.get("message") ) - assertEquals(null, getIndexMetadata(indexName).getCustomData("managed_index_metadata")) + assertEquals(null, getIndexMetadata(indexName)!!.getCustomData("managed_index_metadata")) } logger.info("metadata has moved") @@ -156,7 +156,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { logger.info("managed-index: ${getExistingManagedIndexConfig(indexName)}") // manually save metadata into cluster state - var indexMetadata = getIndexMetadata(indexName) + var indexMetadata = getIndexMetadata(indexName)!! metadataToClusterState = metadataToClusterState.copy( index = indexName, indexUuid = indexMetadata.indexUUID, @@ -172,7 +172,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { ).get() logger.info(response.isAcknowledged) - indexMetadata = getIndexMetadata(indexName) + indexMetadata = getIndexMetadata(indexName)!! logger.info("check if metadata is saved in cluster state: ${indexMetadata.getCustomData("managed_index_metadata")}") waitFor { @@ -187,7 +187,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { "Happy moving", getExplainManagedIndexMetaData(indexName).info?.get("message") ) - assertEquals(null, getIndexMetadata(indexName).getCustomData("managed_index_metadata")) + assertEquals(null, getIndexMetadata(indexName)!!.getCustomData("managed_index_metadata")) } logger.info("metadata has moved") @@ -225,7 +225,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { addPolicyToIndex(indexName, policyID) // put some metadata into cluster state - val indexMetadata = getIndexMetadata(indexName) + val indexMetadata = getIndexMetadata(indexName)!! metadataToClusterState = metadataToClusterState.copy( index = indexName, indexUuid = "randomindexuuid", @@ -237,7 +237,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { ) ) client().execute(UpdateManagedIndexMetaDataAction.INSTANCE, request).get() - logger.info("check if metadata is saved in cluster state: ${getIndexMetadata(indexName).getCustomData("managed_index_metadata")}") + logger.info("check if metadata is saved in cluster state: ${getIndexMetadata(indexName)!!.getCustomData("managed_index_metadata")}") waitFor { assertEquals( @@ -248,7 +248,7 @@ class MetadataRegressionIT : IndexStateManagementIntegTestCase() { waitFor(Instant.ofEpochSecond(120)) { assertEquals(null, getExplainManagedIndexMetaData(indexName).info?.get("message")) - assertEquals(null, getIndexMetadata(indexName).getCustomData("managed_index_metadata")) + assertEquals(null, getIndexMetadata(indexName)!!.getCustomData("managed_index_metadata")) } logger.info("corrupt metadata has been cleaned") diff --git a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataServiceTests.kt b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataServiceTests.kt index ecbfda5f4..84b9a8ccf 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataServiceTests.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataServiceTests.kt @@ -22,7 +22,6 @@ import org.opensearch.client.ClusterAdminClient import org.opensearch.cluster.ClusterState import org.opensearch.cluster.metadata.Metadata import org.opensearch.cluster.service.ClusterService -import org.opensearch.common.collect.ImmutableOpenMap import org.opensearch.indexmanagement.IndexManagementIndices import org.opensearch.test.OpenSearchTestCase import kotlin.test.assertFailsWith @@ -40,7 +39,7 @@ class MetadataServiceTests : OpenSearchTestCase() { fun setup() { whenever(clusterService.state()).doReturn(clusterState) whenever(clusterState.metadata).doReturn(metadata) - whenever(metadata.indices).doReturn(ImmutableOpenMap.of()) + whenever(metadata.indices).doReturn(mapOf()) } fun `test config index not exists`() = runBlocking { diff --git a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/AttemptTransitionStepTests.kt b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/AttemptTransitionStepTests.kt index aeeedd7c9..3f3114f10 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/AttemptTransitionStepTests.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/indexstatemanagement/step/AttemptTransitionStepTests.kt @@ -23,7 +23,6 @@ import org.opensearch.cluster.ClusterState import org.opensearch.cluster.metadata.IndexMetadata import org.opensearch.cluster.metadata.Metadata import org.opensearch.cluster.service.ClusterService -import org.opensearch.common.collect.ImmutableOpenMap import org.opensearch.common.settings.ClusterSettings import org.opensearch.common.settings.Settings import org.opensearch.index.shard.DocsStats @@ -50,7 +49,7 @@ class AttemptTransitionStepTests : OpenSearchTestCase() { private val indexUUID: String = "indexUuid" @Suppress("UNCHECKED_CAST") private val indexMetadata: IndexMetadata = mock { - on { rolloverInfos } doReturn ImmutableOpenMap.builder().build() + on { rolloverInfos } doReturn mapOf() on { indexUUID } doReturn indexUUID } private val metadata: Metadata = mock { diff --git a/src/test/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperServiceTests.kt b/src/test/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperServiceTests.kt index f606e207b..5d8004107 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperServiceTests.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/rollup/RollupMapperServiceTests.kt @@ -21,7 +21,6 @@ import org.opensearch.client.IndicesAdminClient import org.opensearch.cluster.metadata.IndexNameExpressionResolver import org.opensearch.cluster.metadata.MappingMetadata import org.opensearch.cluster.service.ClusterService -import org.opensearch.common.collect.ImmutableOpenMap import org.opensearch.common.xcontent.XContentType import org.opensearch.indexmanagement.rollup.model.RollupJobValidationResult import org.opensearch.test.OpenSearchTestCase @@ -292,16 +291,14 @@ class RollupMapperServiceTests : OpenSearchTestCase() { private fun getMappingResponse(indexName: String, emptyMapping: Boolean = false): GetMappingsResponse { val mappings = if (emptyMapping) { - ImmutableOpenMap.Builder().build() + mapOf() } else { val mappingSourceMap = createParser( XContentType.JSON.xContent(), javaClass.classLoader.getResource("mappings/kibana-sample-data.json").readText() ).map() val mappingMetadata = MappingMetadata("_doc", mappingSourceMap) // it seems it still expects a type, i.e. _doc now - ImmutableOpenMap.Builder() - .fPut(indexName, mappingMetadata) - .build() + mapOf(indexName to mappingMetadata) } return GetMappingsResponse(mappings) diff --git a/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt b/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt index b4bebcf11..5a3c016d2 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt @@ -14,7 +14,6 @@ import org.opensearch.action.admin.cluster.snapshots.get.GetSnapshotsResponse import org.opensearch.action.index.IndexResponse import org.opensearch.cluster.SnapshotsInProgress import org.opensearch.common.UUIDs -import org.opensearch.common.collect.ImmutableOpenMap import org.opensearch.common.unit.TimeValue import org.opensearch.common.xcontent.LoggingDeprecationHandler import org.opensearch.core.xcontent.NamedXContentRegistry @@ -242,7 +241,7 @@ fun mockInProgressSnapshotInfo( emptyList(), randomNonNegativeLong(), randomNonNegativeLong(), - ImmutableOpenMap.of(), + mapOf(), "", mapOf("sm_policy" to "daily-snapshot"), Version.CURRENT, From 87fe8701b9473c5c9621cf1978cdd38aade4596b Mon Sep 17 00:00:00 2001 From: zhichao-aws Date: Thu, 29 Jun 2023 13:59:32 +0800 Subject: [PATCH 2/4] add field remoteStoreIndexShallowCopy in SM TestUtils (#825) Signed-off-by: zhichao-aws --- .../indexmanagement/snapshotmanagement/TestUtils.kt | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt b/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt index 5a3c016d2..c9ecbf1eb 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/snapshotmanagement/TestUtils.kt @@ -208,6 +208,7 @@ fun mockSnapshotInfo( endTime: Long = randomNonNegativeLong(), reason: String? = null, // reason with valid string leads to FAILED snapshot state policyName: String = "daily-snapshot", + remoteStoreIndexShallowCopy: Boolean = randomBoolean(), ): SnapshotInfo { val result = SnapshotInfo( SnapshotId(name, UUIDs.randomBase64UUID()), @@ -220,6 +221,7 @@ fun mockSnapshotInfo( emptyList(), false, mapOf("sm_policy" to policyName), + remoteStoreIndexShallowCopy ) return result } @@ -231,6 +233,7 @@ fun mockSnapshotInfo( */ fun mockInProgressSnapshotInfo( name: String = randomAlphaOfLength(10), + remoteStoreIndexShallowCopy: Boolean = randomBoolean(), ): SnapshotInfo { val entry = SnapshotsInProgress.Entry( Snapshot("repo", SnapshotId(name, UUIDs.randomBase64UUID())), @@ -245,6 +248,7 @@ fun mockInProgressSnapshotInfo( "", mapOf("sm_policy" to "daily-snapshot"), Version.CURRENT, + remoteStoreIndexShallowCopy ) return SnapshotInfo(entry) } From d47d58df938b1051158e491d0fc1783a88905765 Mon Sep 17 00:00:00 2001 From: Hailong Cui Date: Thu, 29 Jun 2023 15:49:36 +0800 Subject: [PATCH 3/4] fix NPE for transform aggregations (#830) Signed-off-by: Hailong Cui --- .../opensearch/indexmanagement/transform/model/Transform.kt | 4 +++- .../opensearch/indexmanagement/transform/TransformRunnerIT.kt | 4 ++-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/src/main/kotlin/org/opensearch/indexmanagement/transform/model/Transform.kt b/src/main/kotlin/org/opensearch/indexmanagement/transform/model/Transform.kt index b6ed9357d..38925d65d 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/transform/model/Transform.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/transform/model/Transform.kt @@ -363,7 +363,9 @@ data class Transform( groups.add(Dimension.parse(xcp)) } } - AGGREGATIONS_FIELD -> aggregations = AggregatorFactories.parseAggregators(xcp) + AGGREGATIONS_FIELD -> { + AggregatorFactories.parseAggregators(xcp)?.let { aggregations = it } + } CONTINUOUS_FIELD -> continuous = xcp.booleanValue() USER_FIELD -> { user = if (xcp.currentToken() == Token.VALUE_NULL) null else User.parse(xcp) diff --git a/src/test/kotlin/org/opensearch/indexmanagement/transform/TransformRunnerIT.kt b/src/test/kotlin/org/opensearch/indexmanagement/transform/TransformRunnerIT.kt index 9ba16a52c..29a3b43a9 100644 --- a/src/test/kotlin/org/opensearch/indexmanagement/transform/TransformRunnerIT.kt +++ b/src/test/kotlin/org/opensearch/indexmanagement/transform/TransformRunnerIT.kt @@ -321,7 +321,7 @@ class TransformRunnerIT : TransformRestTestCase() { assertTrue("Target transform index was not created", indexExists(transform.targetIndex)) } - waitFor(Instant.ofEpochSecond(60)) { + waitFor(Instant.ofEpochSecond(180)) { val transformJob = getTransform(transformId = transform.id) assertNotNull("Transform job doesn't have metadata set", transformJob.metadataId) val transformMetadata = getTransformMetadata(transformJob.metadataId!!) @@ -504,7 +504,7 @@ class TransformRunnerIT : TransformRestTestCase() { assertTrue("Target transform index was not created", indexExists(transform.targetIndex)) } - waitFor(Instant.ofEpochSecond(60)) { + waitFor(Instant.ofEpochSecond(180)) { val transformJob = getTransform(transformId = transform.id) assertNotNull("Transform job doesn't have metadata set", transformJob.metadataId) val transformMetadata = getTransformMetadata(transformJob.metadataId!!) From 5979df0b0b01de6464d90def14722de492862c23 Mon Sep 17 00:00:00 2001 From: Hailong Cui Date: Fri, 30 Jun 2023 10:19:31 +0800 Subject: [PATCH 4/4] Fix detekt Signed-off-by: Hailong Cui --- .../indexmanagement/indexstatemanagement/MetadataService.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt index 55da58544..712378b47 100644 --- a/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt +++ b/src/main/kotlin/org/opensearch/indexmanagement/indexstatemanagement/MetadataService.kt @@ -40,7 +40,7 @@ import java.lang.Exception * MetadataService starts to move metadata from cluster state to config index */ @OpenForTesting -@Suppress("MagicNumber", "ReturnCount", "LongMethod", "ComplexMethod") +@Suppress("MagicNumber", "ReturnCount", "LongMethod", "ComplexMethod", "NestedBlockDepth") class MetadataService( private val client: Client, private val clusterService: ClusterService,