[7.x] Fix retrieving data stream stats for a DS with multiple backing indices (#59806) (#59810)

Backports the following commits to 7.x:

    Fix retrieving data stream stats for a DS with multiple backing indices (#59806)
This commit is contained in:
Lee Hinman 2020-07-17 16:56:07 -06:00 committed by GitHub
parent e963918830
commit 8c7d414a3b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 19 additions and 12 deletions

View File

@ -1,8 +1,8 @@
--- ---
"Multi Get with alias that resolves to multiple indices": "Multi Get with alias that resolves to multiple indices":
- skip: - skip:
version: " - 6.99.99" version: " - 7.8.99"
reason: types are required in requests before 7.0.0 reason: "message was changed to fix grammar in 7.9"
- do: - do:
bulk: bulk:
@ -42,4 +42,4 @@
- match: { docs.1._type: null } - match: { docs.1._type: null }
- match: { docs.1._id: "2" } - match: { docs.1._id: "2" }
- match: { docs.1.error.root_cause.0.type: "illegal_argument_exception" } - match: { docs.1.error.root_cause.0.type: "illegal_argument_exception" }
- match: { docs.1.error.root_cause.0.reason: "/[aA]lias.\\[test_two_and_three\\].has.more.than.one.indices.associated.with.it.\\[\\[test_[23]{1},.test_[23]{1}\\]\\],.can't.execute.a.single.index.op/" } - match: { docs.1.error.root_cause.0.reason: "/[aA]lias.\\[test_two_and_three\\].has.more.than.one.index.associated.with.it.\\[test_[23]{1},.test_[23]{1}\\],.can't.execute.a.single.index.op/" }

View File

@ -1,5 +1,8 @@
--- ---
"Multi Get with alias that resolves to multiple indices": "Multi Get with alias that resolves to multiple indices":
- skip:
version: " - 7.8.99"
reason: "message was changed to fix grammar in 7.9"
- do: - do:
bulk: bulk:
@ -39,4 +42,4 @@
- match: { docs.1._type: test } - match: { docs.1._type: test }
- match: { docs.1._id: "2" } - match: { docs.1._id: "2" }
- match: { docs.1.error.root_cause.0.type: "illegal_argument_exception" } - match: { docs.1.error.root_cause.0.type: "illegal_argument_exception" }
- match: { docs.1.error.root_cause.0.reason: "/[aA]lias.\\[test_two_and_three\\].has.more.than.one.indices.associated.with.it.\\[\\[test_[23]{1},.test_[23]{1}\\]\\],.can't.execute.a.single.index.op/" } - match: { docs.1.error.root_cause.0.reason: "/[aA]lias.\\[test_two_and_three\\].has.more.than.one.index.associated.with.it.\\[test_[23]{1},.test_[23]{1}\\],.can't.execute.a.single.index.op/" }

View File

@ -95,7 +95,7 @@ public class SimpleMgetIT extends ESIntegTestCase {
assertThat(mgetResponse.getResponses()[1].getIndex(), is("multiIndexAlias")); assertThat(mgetResponse.getResponses()[1].getIndex(), is("multiIndexAlias"));
assertThat(mgetResponse.getResponses()[1].isFailed(), is(true)); assertThat(mgetResponse.getResponses()[1].isFailed(), is(true));
assertThat(mgetResponse.getResponses()[1].getFailure().getMessage(), containsString("more than one indices")); assertThat(mgetResponse.getResponses()[1].getFailure().getMessage(), containsString("more than one index"));
mgetResponse = client().prepareMultiGet() mgetResponse = client().prepareMultiGet()
.add(new MultiGetRequest.Item("multiIndexAlias", "test", "1")) .add(new MultiGetRequest.Item("multiIndexAlias", "test", "1"))
@ -103,7 +103,7 @@ public class SimpleMgetIT extends ESIntegTestCase {
assertThat(mgetResponse.getResponses().length, is(1)); assertThat(mgetResponse.getResponses().length, is(1));
assertThat(mgetResponse.getResponses()[0].getIndex(), is("multiIndexAlias")); assertThat(mgetResponse.getResponses()[0].getIndex(), is("multiIndexAlias"));
assertThat(mgetResponse.getResponses()[0].isFailed(), is(true)); assertThat(mgetResponse.getResponses()[0].isFailed(), is(true));
assertThat(mgetResponse.getResponses()[0].getFailure().getMessage(), containsString("more than one indices")); assertThat(mgetResponse.getResponses()[0].getFailure().getMessage(), containsString("more than one index"));
} }
public void testThatMgetShouldWorkWithAliasRouting() throws IOException { public void testThatMgetShouldWorkWithAliasRouting() throws IOException {

View File

@ -258,8 +258,8 @@ public class IndexNameExpressionResolver {
indexNames[i++] = indexMetadata.getIndex().getName(); indexNames[i++] = indexMetadata.getIndex().getName();
} }
throw new IllegalArgumentException(indexAbstraction.getType().getDisplayName() + " [" + expression + throw new IllegalArgumentException(indexAbstraction.getType().getDisplayName() + " [" + expression +
"] has more than one indices associated with it [" + Arrays.toString(indexNames) + "] has more than one index associated with it " + Arrays.toString(indexNames) +
"], can't execute a single index op"); ", can't execute a single index op");
} }
for (IndexMetadata index : indexAbstraction.getIndices()) { for (IndexMetadata index : indexAbstraction.getIndices()) {

View File

@ -604,7 +604,7 @@ public class IndexNameExpressionResolverTests extends ESTestCase {
new IndexNameExpressionResolver.Context(state, IndicesOptions.strictSingleIndexNoExpandForbidClosed()); new IndexNameExpressionResolver.Context(state, IndicesOptions.strictSingleIndexNoExpandForbidClosed());
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, IllegalArgumentException e = expectThrows(IllegalArgumentException.class,
() -> indexNameExpressionResolver.concreteIndexNames(context, "foofoobar")); () -> indexNameExpressionResolver.concreteIndexNames(context, "foofoobar"));
assertThat(e.getMessage(), containsString("alias [foofoobar] has more than one indices associated with it")); assertThat(e.getMessage(), containsString("alias [foofoobar] has more than one index associated with it"));
} }
{ {
@ -612,7 +612,7 @@ public class IndexNameExpressionResolverTests extends ESTestCase {
new IndexNameExpressionResolver.Context(state, IndicesOptions.strictSingleIndexNoExpandForbidClosed()); new IndexNameExpressionResolver.Context(state, IndicesOptions.strictSingleIndexNoExpandForbidClosed());
IllegalArgumentException e = expectThrows(IllegalArgumentException.class, IllegalArgumentException e = expectThrows(IllegalArgumentException.class,
() -> indexNameExpressionResolver.concreteIndexNames(context, "foo", "foofoobar")); () -> indexNameExpressionResolver.concreteIndexNames(context, "foo", "foofoobar"));
assertThat(e.getMessage(), containsString("alias [foofoobar] has more than one indices associated with it")); assertThat(e.getMessage(), containsString("alias [foofoobar] has more than one index associated with it"));
} }
{ {

View File

@ -47,13 +47,17 @@ setup:
name: simple-data-stream1 name: simple-data-stream1
- is_true: acknowledged - is_true: acknowledged
- do:
indices.rollover:
alias: "simple-data-stream1"
- do: - do:
indices.data_streams_stats: {} indices.data_streams_stats: {}
- match: { data_stream_count: 1 } - match: { data_stream_count: 1 }
- match: { backing_indices: 1 } - match: { backing_indices: 2 }
- length: { data_streams: 1 } - length: { data_streams: 1 }
- match: { data_streams.0.data_stream: 'simple-data-stream1' } - match: { data_streams.0.data_stream: 'simple-data-stream1' }
- match: { data_streams.0.backing_indices: 1 } - match: { data_streams.0.backing_indices: 2 }
- match: { data_streams.0.maximum_timestamp: 0 } - match: { data_streams.0.maximum_timestamp: 0 }
- do: - do: