From e8bb9ea68fd518822015efaa3471a3c74ce17424 Mon Sep 17 00:00:00 2001 From: Nik Everett Date: Thu, 2 Sep 2021 14:46:12 -0400 Subject: [PATCH] Add matching pattern to error in fields (backport of #76903) (#77191) This adds the pattern into the error message returned when trying to fetch fields. So this: ``` POST _search { "fields": [ { "field": "*", "format": "date_time" } ] } ``` Will return an error message like ``` error fetching [foo] which matches [*]: Field [foo] of type [keyword] doesn't support formats ``` --- .../test/search/330_fetch_fields.yml | 115 ++++++++++++++++++ .../search/fetch/subphase/FieldFetcher.java | 12 +- x-pack/qa/runtime-fields/build.gradle | 3 + 3 files changed, 129 insertions(+), 1 deletion(-) diff --git a/rest-api-spec/src/yamlRestTest/resources/rest-api-spec/test/search/330_fetch_fields.yml b/rest-api-spec/src/yamlRestTest/resources/rest-api-spec/test/search/330_fetch_fields.yml index c5cf973e67e61..1d156a4eb98fe 100644 --- a/rest-api-spec/src/yamlRestTest/resources/rest-api-spec/test/search/330_fetch_fields.yml +++ b/rest-api-spec/src/yamlRestTest/resources/rest-api-spec/test/search/330_fetch_fields.yml @@ -855,6 +855,7 @@ Test nested field with sibling field resolving to DocValueFetcher: - match: { hits.hits.0.fields.number.2 : 3 } - match: { hits.hits.0.fields.number.3 : 5 } - match: { hits.hits.0.fields.number.4 : 6 } + --- Test token_count inside nested field doesn't fail: - skip: @@ -892,3 +893,117 @@ Test token_count inside nested field doesn't fail: body: _source: false fields: [ "*" ] + +--- +error includes field name: + - skip: + version: ' - 7.15.99' + reason: 'error changed in 7.16.0' + + - do: + indices.create: + index: test + body: + settings: + index.number_of_shards: 1 + mappings: + properties: + keyword: + type: keyword + date: + type: date + + - do: + index: + index: test + id: 1 + refresh: true + body: + keyword: "value" + date: "1990-12-29T22:30:00.000Z" + + - do: + catch: '/error fetching \[keyword\]: Field \[keyword\] of type \[keyword\] doesn''t support formats./' + search: + index: test + body: + fields: + - field: keyword + format: "yyyy/MM/dd" + +--- +error includes glob pattern: + - skip: + version: ' - 7.15.99' + reason: 'error changed in 7.16.0' + + - do: + indices.create: + index: test + body: + settings: + index.number_of_shards: 1 + mappings: + properties: + dkeyword: + type: keyword + date: + type: date + + - do: + index: + index: test + id: 1 + refresh: true + body: + dkeyword: "value" + date: "1990-12-29T22:30:00.000Z" + + - do: + catch: '/error fetching \[dkeyword\] which matched \[d\*\]: Field \[dkeyword\] of type \[keyword\] doesn''t support formats./' + search: + index: test + body: + fields: + - field: d* + format: "yyyy/MM/dd" + + +--- +error for flattened includes whole path: + - skip: + version: ' - 7.15.99' + reason: 'error changed in 7.16.0' + + - do: + indices.create: + index: test + body: + settings: + index.number_of_shards: 1 + mappings: + properties: + flattened: + type: flattened + + date: + type: date + + - do: + index: + index: test + id: 1 + refresh: true + body: + flattened: + foo: bar + date: "1990-12-29T22:30:00.000Z" + + - do: + catch: '/error fetching \[flattened.bar\]: Field \[flattened.bar\] of type \[flattened\] doesn''t support formats./' + search: + index: test + body: + fields: + - field: flattened.bar + format: "yyyy/MM/dd" diff --git a/server/src/main/java/org/elasticsearch/search/fetch/subphase/FieldFetcher.java b/server/src/main/java/org/elasticsearch/search/fetch/subphase/FieldFetcher.java index 9f39a2d9a3877..62fafa7f0caf7 100644 --- a/server/src/main/java/org/elasticsearch/search/fetch/subphase/FieldFetcher.java +++ b/server/src/main/java/org/elasticsearch/search/fetch/subphase/FieldFetcher.java @@ -92,7 +92,17 @@ private static FieldFetcher create(SearchExecutionContext context, } // only add concrete fields if they are not beneath a known nested field if (nestedParentPath == null) { - ValueFetcher valueFetcher = ft.valueFetcher(context, fieldAndFormat.format); + ValueFetcher valueFetcher; + try { + valueFetcher = ft.valueFetcher(context, fieldAndFormat.format); + } catch (IllegalArgumentException e) { + StringBuilder error = new StringBuilder("error fetching [").append(field).append(']'); + if (isWildcardPattern) { + error.append(" which matched [").append(fieldAndFormat.field).append(']'); + } + error.append(": ").append(e.getMessage()); + throw new IllegalArgumentException(error.toString(), e); + } fieldContexts.put(field, new FieldContext(field, valueFetcher)); } } diff --git a/x-pack/qa/runtime-fields/build.gradle b/x-pack/qa/runtime-fields/build.gradle index 6b7780ea511df..8529b43f3c525 100644 --- a/x-pack/qa/runtime-fields/build.gradle +++ b/x-pack/qa/runtime-fields/build.gradle @@ -85,6 +85,9 @@ subprojects { 'search/171_terms_query_with_types/*', 'search/340_type_query/type query', 'msearch/12_basic_with_types/*', + // The error messages are different + 'search/330_fetch_fields/error includes field name', + 'search/330_fetch_fields/error includes glob pattern', /////// NOT SUPPORTED /////// ].join(',') }