From 35488d0891acd0e4f834919033a03c73d761b7fb Mon Sep 17 00:00:00 2001 From: Lee Hinman Date: Tue, 14 Apr 2020 10:46:40 -0600 Subject: [PATCH 1/3] Add support for V2 index templates to /_cat/templates This adds support for V2 index templates to the cat templates API. It uses the `order` field as priority in order not to break compatibility, while adding the `composed_of` field to show component templates that are used from an index template. Relates to #53101 --- .../test/cat.templates/10_basic.yml | 97 +++++++++++++++++-- .../rest/action/cat/RestTemplatesAction.java | 20 +++- 2 files changed, 107 insertions(+), 10 deletions(-) diff --git a/rest-api-spec/src/main/resources/rest-api-spec/test/cat.templates/10_basic.yml b/rest-api-spec/src/main/resources/rest-api-spec/test/cat.templates/10_basic.yml index fe0d7ee30730f..0b7f63d30d662 100644 --- a/rest-api-spec/src/main/resources/rest-api-spec/test/cat.templates/10_basic.yml +++ b/rest-api-spec/src/main/resources/rest-api-spec/test/cat.templates/10_basic.yml @@ -1,5 +1,9 @@ --- "Help": + - skip: + version: " - 7.9.99" + reason: "not backported yet" + - do: cat.templates: help: true @@ -10,6 +14,7 @@ index_patterns .+ \n order .+ \n version .+ \n + composed_of .+ \n $/ --- @@ -26,6 +31,9 @@ --- "Normal templates": + - skip: + version: " - 7.9.99" + reason: "not backported yet" - do: indices.put_template: @@ -58,7 +66,7 @@ (^|\n)test \s+ \[test-\*\] \s+ 0 \s+ - 1 + 1 \s+ (\n|$) / @@ -68,12 +76,15 @@ (^|\n)test_2 \s+ \[test-2\*\] \s+ 1 \s+ - 2 + 2 \s+ (\n|$) / --- "Filtered templates": + - skip: + version: " - 7.9.99" + reason: "not backported yet" - do: indices.put_template: @@ -107,12 +118,16 @@ test \s+ \[t\*\] \s+ 0 \s+ - 1 + 1 \s* \n $/ --- "Column headers": + - skip: + version: " - 7.9.99" + reason: "not backported yet" + - do: indices.put_template: name: test @@ -135,17 +150,22 @@ name \s+ index_patterns \s+ order \s+ - version + version \s+ + composed_of \n test \s+ \[t\*\] \s+ 0 \s+ - 1 + 1 \s* \n $/ --- "Select columns": + - skip: + version: " - 7.9.99" + reason: "not backported yet" + - do: indices.put_template: name: test @@ -177,7 +197,10 @@ --- "Sort templates": - skip: + version: " - 7.9.99" + reason: "not backported yet" features: default_shards, no_xpack + - do: indices.put_template: name: test @@ -207,8 +230,8 @@ - match: $body: | /^ - test \s+ \[t\*\] \s+ \n - test_1 \s+ \[te\*\] \s+ 1 \n + test \s+ \[t\*\] \s+ \n \n + test_1 \s+ \[te\*\] \s+ 1 \n \n $/ - do: @@ -219,15 +242,18 @@ - match: $body: | /^ - test_1 \s+ \[te\*\] \s+ 1\n - test \s+ \[t\*\] \s+ \n + test_1 \s+ \[te\*\] \s+ 1\n \n + test \s+ \[t\*\] \s+ \n \n $/ --- "Multiple template": - skip: + version: " - 7.9.99" + reason: "not backported yet" features: default_shards, no_xpack + - do: indices.put_template: name: test_1 @@ -254,4 +280,57 @@ test_1 \s+ \[t\*,\ te\*\] \n + \n $/ + +--- +"Mixture of V1 and V2 templates": + - skip: + version: " - 7.9.99" + reason: "not backported yet" + features: allowed_warnings + + - do: + indices.put_template: + name: test + body: + order: 0 + version: 1 + index_patterns: test-* + settings: + number_of_shards: 1 + number_of_replicas: 0 + + - do: + allowed_warnings: + - "index template [testv2] has index patterns [v2-test] matching patterns from existing older templates [global] with patterns (global => [*]); this template [testv2] will take precedence during new index creation" + indices.put_index_template: + name: testv2 + body: + index_patterns: [v2-test] + priority: 4 + version: 3 + composed_of: [foo, bar] + + - do: + cat.templates: {} + + - match: + $body: > + / + (^|\n)test \s+ + \[test-\*\] \s+ + 0 \s+ + 1 \s+ + (\n|$) + / + + - match: + $body: > + / + (^|\n)testv2 \s+ + \[v2-test\] \s+ + 4 \s+ + 3 \s+ + \[foo,\ bar\] + / diff --git a/server/src/main/java/org/elasticsearch/rest/action/cat/RestTemplatesAction.java b/server/src/main/java/org/elasticsearch/rest/action/cat/RestTemplatesAction.java index d511cfea7d63c..fcb9910143432 100644 --- a/server/src/main/java/org/elasticsearch/rest/action/cat/RestTemplatesAction.java +++ b/server/src/main/java/org/elasticsearch/rest/action/cat/RestTemplatesAction.java @@ -24,6 +24,7 @@ import org.elasticsearch.action.admin.cluster.state.ClusterStateResponse; import org.elasticsearch.client.node.NodeClient; import org.elasticsearch.cluster.metadata.IndexTemplateMetadata; +import org.elasticsearch.cluster.metadata.IndexTemplateV2; import org.elasticsearch.cluster.metadata.Metadata; import org.elasticsearch.common.Table; import org.elasticsearch.common.regex.Regex; @@ -32,6 +33,7 @@ import org.elasticsearch.rest.action.RestResponseListener; import java.util.List; +import java.util.Map; import static org.elasticsearch.rest.RestRequest.Method.GET; @@ -76,8 +78,9 @@ protected Table getTableWithHeader(RestRequest request) { table.startHeaders(); table.addCell("name", "alias:n;desc:template name"); table.addCell("index_patterns", "alias:t;desc:template index patterns"); - table.addCell("order", "alias:o;desc:template application order number"); + table.addCell("order", "alias:o,p;desc:template application order/priority number"); table.addCell("version", "alias:v;desc:version"); + table.addCell("composed_of", "alias:c;desc:component templates comprising index template"); table.endHeaders(); return table; } @@ -93,6 +96,21 @@ private Table buildTable(RestRequest request, ClusterStateResponse clusterStateR table.addCell("[" + String.join(", ", indexData.patterns()) + "]"); table.addCell(indexData.getOrder()); table.addCell(indexData.getVersion()); + table.addCell(""); + table.endRow(); + } + } + + for (Map.Entry entry : metadata.templatesV2().entrySet()) { + String name = entry.getKey(); + IndexTemplateV2 template = entry.getValue(); + if (patternString == null || Regex.simpleMatch(patternString, name)) { + table.startRow(); + table.addCell(name); + table.addCell("[" + String.join(", ", template.indexPatterns()) + "]"); + table.addCell(template.priority()); + table.addCell(template.version()); + table.addCell("[" + String.join(", ", template.composedOf()) + "]"); table.endRow(); } } From f032761dff0d1bd096d1d85f7a42671bf8e2e965 Mon Sep 17 00:00:00 2001 From: Lee Hinman Date: Mon, 27 Apr 2020 16:19:40 -0600 Subject: [PATCH 2/3] Update docs --- docs/reference/cat/templates.asciidoc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/reference/cat/templates.asciidoc b/docs/reference/cat/templates.asciidoc index 512ccaadde0d6..b16275e042681 100644 --- a/docs/reference/cat/templates.asciidoc +++ b/docs/reference/cat/templates.asciidoc @@ -65,7 +65,7 @@ The API returns the following response: [source,txt] -------------------------------------------------- -name index_patterns order version +name index_patterns order version composed_of template0 [te*] 0 template1 [tea*] 1 template2 [teak*] 2 7 From 7d10828abde62102530786f793e873585b3e2587 Mon Sep 17 00:00:00 2001 From: Lee Hinman Date: Tue, 28 Apr 2020 08:35:09 -0600 Subject: [PATCH 3/3] Fix clearing of templates in ESRestTestCase --- .../elasticsearch/test/rest/ESRestTestCase.java | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/test/framework/src/main/java/org/elasticsearch/test/rest/ESRestTestCase.java b/test/framework/src/main/java/org/elasticsearch/test/rest/ESRestTestCase.java index 7d9ee8105ee50..0e4e897df1907 100644 --- a/test/framework/src/main/java/org/elasticsearch/test/rest/ESRestTestCase.java +++ b/test/framework/src/main/java/org/elasticsearch/test/rest/ESRestTestCase.java @@ -97,6 +97,7 @@ import static java.util.Collections.unmodifiableList; import static org.hamcrest.Matchers.anEmptyMap; import static org.hamcrest.Matchers.anyOf; +import static org.hamcrest.Matchers.containsString; import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.everyItem; import static org.hamcrest.Matchers.in; @@ -559,12 +560,21 @@ private void wipeCluster() throws Exception { if ("".equals(template)) { throw new IllegalStateException("empty template in templates list:\n" + templates); } - logger.debug("Clearing template [{}]", template); - adminClient().performRequest(new Request("DELETE", "_template/" + template)); + logger.info("Clearing template [{}]", template); + try { + adminClient().performRequest(new Request("DELETE", "_template/" + template)); + } catch (ResponseException e) { + // This is fine, it could be a V2 template + assertThat(e.getMessage(), containsString("index_template [" + template + "] missing")); + try { + adminClient().performRequest(new Request("DELETE", "_index_template/" + template)); + } catch (ResponseException e2) { + // We hit a version of ES that doesn't support index templates v2 yet, so it's safe to ignore + } + } } } try { - adminClient().performRequest(new Request("DELETE", "_index_template/*")); adminClient().performRequest(new Request("DELETE", "_component_template/*")); } catch (ResponseException e) { // We hit a version of ES that doesn't support index templates v2 yet, so it's safe to ignore