From a6243e53d7b25bd56c1a6de93cda67dfa5605035 Mon Sep 17 00:00:00 2001 From: Mirko Jotic Date: Thu, 23 Aug 2018 21:31:01 -0400 Subject: [PATCH] [#30405] Adding tests for QueryExplanation - Backwards compatability of serialization --- .../validate/query/QueryExplanationTests.java | 42 +++++++++++++++++++ 1 file changed, 42 insertions(+) diff --git a/server/src/test/java/org/elasticsearch/action/admin/indices/validate/query/QueryExplanationTests.java b/server/src/test/java/org/elasticsearch/action/admin/indices/validate/query/QueryExplanationTests.java index db167e0c7669e..11c8193cd746b 100644 --- a/server/src/test/java/org/elasticsearch/action/admin/indices/validate/query/QueryExplanationTests.java +++ b/server/src/test/java/org/elasticsearch/action/admin/indices/validate/query/QueryExplanationTests.java @@ -19,11 +19,20 @@ package org.elasticsearch.action.admin.indices.validate.query; +import org.elasticsearch.Version; import org.elasticsearch.common.xcontent.XContentParser; import org.elasticsearch.test.AbstractStreamableXContentTestCase; +import org.elasticsearch.common.io.stream.StreamInput; +import org.elasticsearch.common.io.stream.StreamOutput; import java.io.IOException; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.when; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.times; +import static org.mockito.Mockito.anyString; + public class QueryExplanationTests extends AbstractStreamableXContentTestCase { static QueryExplanation createRandomQueryExplanation(boolean isValid) { @@ -56,4 +65,37 @@ protected QueryExplanation createBlankInstance() { protected QueryExplanation createTestInstance() { return createRandomQueryExplanation(); } + + public void testCompatabilityOfStreamInputApi_V_6_4_0() throws IOException { + QueryExplanation queryExplanation = createRandomQueryExplanation(true); + StreamInput in = mock(StreamInput.class); + when(in.getVersion()).thenReturn(Version.V_6_4_0); + queryExplanation.readFrom(in); + verify(in, times(3)).readOptionalString(); + } + + public void testCompatabilityOfStreamInputApi_V_5_4_0() throws IOException { + QueryExplanation queryExplanation = createRandomQueryExplanation(true); + StreamInput in = mock(StreamInput.class); + when(in.getVersion()).thenReturn(Version.V_5_4_0); + queryExplanation.readFrom(in); + verify(in).readString(); + verify(in).readInt(); + } + + public void testCompatabilityOfStreamOutputApi_V_6_4_0() throws IOException { + QueryExplanation queryExplanation = createRandomQueryExplanation(true); + StreamOutput out = mock(StreamOutput.class); + when(out.getVersion()).thenReturn(Version.V_6_4_0); + queryExplanation.writeTo(out); + verify(out, times(3)).writeOptionalString(anyString()); + } + + public void testCompatabilityOfStreamOutputApi_V_5_4_0() throws IOException { + QueryExplanation queryExplanation = createRandomQueryExplanation(true); + StreamOutput out = mock(StreamOutput.class); + when(out.getVersion()).thenReturn(Version.V_5_4_0); + queryExplanation.writeTo(out); + verify(out).writeString(anyString()); + } }