|
18 | 18 | import org.elasticsearch.cluster.metadata.DataStreamTestHelper; |
19 | 19 | import org.elasticsearch.cluster.metadata.IndexNameExpressionResolver; |
20 | 20 | import org.elasticsearch.cluster.metadata.Metadata; |
| 21 | +import org.elasticsearch.common.compress.CompressedXContent; |
21 | 22 | import org.elasticsearch.common.settings.ClusterSettings; |
22 | 23 | import org.elasticsearch.common.settings.Settings; |
23 | 24 | import org.elasticsearch.core.TimeValue; |
24 | 25 | import org.elasticsearch.core.Tuple; |
25 | 26 | import org.elasticsearch.index.Index; |
| 27 | +import org.elasticsearch.index.IndexMode; |
26 | 28 | import org.elasticsearch.index.IndexNotFoundException; |
| 29 | +import org.elasticsearch.index.IndexSettingProvider; |
27 | 30 | import org.elasticsearch.index.IndexSettingProviders; |
28 | 31 | import org.elasticsearch.indices.SystemIndices; |
29 | 32 | import org.elasticsearch.indices.TestIndexNameExpressionResolver; |
@@ -483,4 +486,58 @@ public void testDataStreamIsFailureStoreEffectivelyEnabled_enabledByClusterSetti |
483 | 486 | assertThat(response.getDataStreams(), hasSize(1)); |
484 | 487 | assertThat(response.getDataStreams().getFirst().isFailureStoreEffectivelyEnabled(), is(true)); |
485 | 488 | } |
| 489 | + |
| 490 | + public void testProvidersAffectMode() { |
| 491 | + ClusterState state; |
| 492 | + { |
| 493 | + var mBuilder = new Metadata.Builder(); |
| 494 | + DataStreamTestHelper.getClusterStateWithDataStreams( |
| 495 | + mBuilder, |
| 496 | + List.of(Tuple.tuple("data-stream-1", 2)), |
| 497 | + List.of(), |
| 498 | + System.currentTimeMillis(), |
| 499 | + Settings.EMPTY, |
| 500 | + 0, |
| 501 | + false, |
| 502 | + false |
| 503 | + ); |
| 504 | + state = ClusterState.builder(new ClusterName("_name")).metadata(mBuilder).build(); |
| 505 | + } |
| 506 | + |
| 507 | + var req = new GetDataStreamAction.Request(TEST_REQUEST_TIMEOUT, new String[] {}); |
| 508 | + var response = TransportGetDataStreamsAction.innerOperation( |
| 509 | + state, |
| 510 | + req, |
| 511 | + resolver, |
| 512 | + systemIndices, |
| 513 | + ClusterSettings.createBuiltInClusterSettings(), |
| 514 | + dataStreamGlobalRetentionSettings, |
| 515 | + emptyDataStreamFailureStoreSettings, |
| 516 | + new IndexSettingProviders( |
| 517 | + Set.of( |
| 518 | + ( |
| 519 | + indexName, |
| 520 | + dataStreamName, |
| 521 | + templateIndexMode, |
| 522 | + metadata, |
| 523 | + resolvedAt, |
| 524 | + indexTemplateAndCreateRequestSettings, |
| 525 | + combinedTemplateMappings) -> Settings.builder().put("index.mode", IndexMode.LOOKUP).build() |
| 526 | + ) |
| 527 | + ), |
| 528 | + null |
| 529 | + ); |
| 530 | + assertThat(response.getDataStreams().getFirst().getIndexModeName(), equalTo("lookup")); |
| 531 | + assertThat( |
| 532 | + response.getDataStreams() |
| 533 | + .getFirst() |
| 534 | + .getIndexSettingsValues() |
| 535 | + .values() |
| 536 | + .stream() |
| 537 | + .findFirst() |
| 538 | + .map(GetDataStreamAction.Response.IndexProperties::indexMode) |
| 539 | + .orElse("bad"), |
| 540 | + equalTo("standard") |
| 541 | + ); |
| 542 | + } |
486 | 543 | } |
0 commit comments