From eb6620b7b21afa0989eaa6b7a6df859dd2a7f3e0 Mon Sep 17 00:00:00 2001 From: Thomas Farr Date: Thu, 20 Jun 2024 00:00:45 +1200 Subject: [PATCH] Default analyzer deserialization to custom type when unspecified (#1033) * Default analyzer deserialization to custom type when unspecified Signed-off-by: Thomas Farr * Add changelog Signed-off-by: Thomas Farr * Fix for java8 Signed-off-by: Thomas Farr --------- Signed-off-by: Thomas Farr (cherry picked from commit 80dc741a6a088d6a9f419471aa33b8ca02c404c5) --- CHANGELOG.md | 1 + .../opensearch/_types/analysis/Analyzer.java | 2 +- .../analysis/AnalyzerDeserializerTest.java | 30 +++++++++++++++++++ 3 files changed, 32 insertions(+), 1 deletion(-) create mode 100644 java-client/src/test/java/org/opensearch/client/opensearch/_types/analysis/AnalyzerDeserializerTest.java diff --git a/CHANGELOG.md b/CHANGELOG.md index a42ed35a36..0efa9dd30d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ Inspired from [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) ### Removed ### Fixed +- Fixed error when deserializing an analyzer without `type` specified ([#1033](https://github.com/opensearch-project/opensearch-java/pull/1033)) ### Security diff --git a/java-client/src/main/java/org/opensearch/client/opensearch/_types/analysis/Analyzer.java b/java-client/src/main/java/org/opensearch/client/opensearch/_types/analysis/Analyzer.java index 3a60a8daf7..0a0ffd6f4e 100644 --- a/java-client/src/main/java/org/opensearch/client/opensearch/_types/analysis/Analyzer.java +++ b/java-client/src/main/java/org/opensearch/client/opensearch/_types/analysis/Analyzer.java @@ -606,7 +606,7 @@ protected static void setupAnalyzerDeserializer(ObjectDeserializer op) op.add(Builder::smartcn, SmartcnAnalyzer._DESERIALIZER, Kind.Smartcn.jsonValue()); op.add(Builder::cjk, CjkAnalyzer._DESERIALIZER, Kind.Cjk.jsonValue()); - op.setTypeProperty("type", null); + op.setTypeProperty("type", Kind.Custom.jsonValue()); } diff --git a/java-client/src/test/java/org/opensearch/client/opensearch/_types/analysis/AnalyzerDeserializerTest.java b/java-client/src/test/java/org/opensearch/client/opensearch/_types/analysis/AnalyzerDeserializerTest.java new file mode 100644 index 0000000000..e4a8c21a36 --- /dev/null +++ b/java-client/src/test/java/org/opensearch/client/opensearch/_types/analysis/AnalyzerDeserializerTest.java @@ -0,0 +1,30 @@ +/* + * SPDX-License-Identifier: Apache-2.0 + * + * The OpenSearch Contributors require contributions made to + * this file be licensed under the Apache-2.0 license or a + * compatible open source license. + */ + +package org.opensearch.client.opensearch._types.analysis; + +import org.junit.Test; +import org.opensearch.client.opensearch.model.ModelTestCase; + +public class AnalyzerDeserializerTest extends ModelTestCase { + @Test + public void deserializesTypelessCustomAnalyzer() { + String json = "{\n" + + " \"filter\": [\"kuromoji_baseform\", \"ja_stop\"],\n" + + " \"char_filter\": [\"icu_normalizer\"],\n" + + " \"tokenizer\": \"kuromoji_tokenizer\"\n" + + "}"; + + Analyzer analyzer = fromJson(json, Analyzer._DESERIALIZER); + assertTrue(analyzer.isCustom()); + assertEquals("kuromoji_tokenizer", analyzer.custom().tokenizer()); + assertEquals("icu_normalizer", analyzer.custom().charFilter().get(0)); + assertEquals("kuromoji_baseform", analyzer.custom().filter().get(0)); + assertEquals("ja_stop", analyzer.custom().filter().get(1)); + } +}