Add tests for SqlGetIndicesAction.Request serialization (elastic/x-pack-elasticsearch#2452)

This request is already serializeable so we may as well add
tests for that so we don't break it.

Original commit: elastic/x-pack-elasticsearch@16cca77ccf
This commit is contained in:
Nik Everett 2017-09-11 14:37:57 -04:00 committed by GitHub
parent 94de0d8041
commit 8b6a0daa05
2 changed files with 117 additions and 0 deletions

View File

@ -33,8 +33,10 @@ import org.elasticsearch.xpack.sql.analysis.catalog.EsIndex;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Objects;
import java.util.function.Function; import java.util.function.Function;
import static java.util.Comparator.comparing; import static java.util.Comparator.comparing;
@ -114,6 +116,24 @@ public class SqlGetIndicesAction
this.indicesOptions = indicesOptions; this.indicesOptions = indicesOptions;
return this; return this;
} }
@Override
public boolean equals(Object obj) {
if (obj == null || obj.getClass() != getClass()) {
return false;
}
Request other = (Request) obj;
return Arrays.equals(indices, other.indices)
&& indicesOptions.equals(other.indicesOptions)
&& local == other.local
&& masterNodeTimeout.equals(other.masterNodeTimeout)
&& getParentTask().equals(other.getParentTask());
}
@Override
public int hashCode() {
return Objects.hash(Arrays.hashCode(indices), indicesOptions, local, masterNodeTimeout, getParentTask());
}
} }
public static class RequestBuilder extends MasterNodeReadOperationRequestBuilder<Request, Response, RequestBuilder> { public static class RequestBuilder extends MasterNodeReadOperationRequestBuilder<Request, Response, RequestBuilder> {

View File

@ -0,0 +1,97 @@
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License;
* you may not use this file except in compliance with the Elastic License.
*/
package org.elasticsearch.xpack.sql.plugin;
import org.elasticsearch.action.support.IndicesOptions;
import org.elasticsearch.common.unit.TimeValue;
import org.elasticsearch.tasks.TaskId;
import org.elasticsearch.test.AbstractStreamableTestCase;
import org.elasticsearch.test.EqualsHashCodeTestUtils.MutateFunction;
import org.elasticsearch.xpack.sql.plugin.SqlGetIndicesAction.Request;
import java.util.Arrays;
import java.util.function.Supplier;
public class SqlGetIndicesRequestTests extends AbstractStreamableTestCase<SqlGetIndicesAction.Request> {
@Override
protected Request createTestInstance() {
Request request = new Request(randomIndicesOptions(), randomIndices());
request.local(randomBoolean());
request.masterNodeTimeout(randomTimeValue());
request.setParentTask(randomTaskId());
return request;
}
@Override
protected Request createBlankInstance() {
return new Request();
}
@Override
protected MutateFunction<Request> getMutateFunction() {
return SqlGetIndicesRequestTests::mutate;
}
private static Request mutate(Request request) {
@SuppressWarnings("unchecked")
Supplier<Request> supplier = randomFrom(
() -> {
Request mutant = new Request(
randomValueOtherThan(request.indicesOptions(), SqlGetIndicesRequestTests::randomIndicesOptions),
request.indices());
mutant.local(request.local());
mutant.masterNodeTimeout(request.masterNodeTimeout());
mutant.setParentTask(request.getParentTask());
return mutant;
},
() -> {
Request mutant = new Request(
request.indicesOptions(),
randomValueOtherThanMany(i -> Arrays.equals(request.indices(), i), SqlGetIndicesRequestTests::randomIndices));
mutant.local(request.local());
mutant.masterNodeTimeout(request.masterNodeTimeout());
mutant.setParentTask(request.getParentTask());
return mutant;
}, () -> {
Request mutant = new Request(request.indicesOptions(), request.indices());
mutant.local(false == request.local());
mutant.masterNodeTimeout(request.masterNodeTimeout());
mutant.setParentTask(request.getParentTask());
return mutant;
}, () -> {
Request mutant = new Request(request.indicesOptions(), request.indices());
mutant.local(request.local());
mutant.masterNodeTimeout(randomValueOtherThan(request.masterNodeTimeout(),
() -> TimeValue.parseTimeValue(randomTimeValue(), "test")));
mutant.setParentTask(request.getParentTask());
return mutant;
}, () -> {
Request mutant = new Request(request.indicesOptions(), request.indices());
mutant.local(false == request.local());
mutant.masterNodeTimeout(request.masterNodeTimeout());
mutant.setParentTask(randomValueOtherThan(request.getParentTask(), SqlGetIndicesRequestTests::randomTaskId));
return mutant;
});
return supplier.get();
}
private static IndicesOptions randomIndicesOptions() {
return IndicesOptions.fromOptions(randomBoolean(), randomBoolean(), randomBoolean(), randomBoolean(), randomBoolean(),
randomBoolean(), randomBoolean());
}
private static String[] randomIndices() {
String[] indices = new String[between(1, 10)];
for (int i = 0; i < indices.length; i++) {
indices[i] = randomAlphaOfLength(5);
}
return indices;
}
private static TaskId randomTaskId() {
return randomBoolean() ? TaskId.EMPTY_TASK_ID : new TaskId(randomAlphaOfLength(5), randomLong());
}
}