Change HLRC CCR response tests to use AbstractResponseTestCase base class. (#40257)
This way the response classes are tested in a more realistic setting. Relates to #39745
This commit is contained in:
parent
26c63e0115
commit
c29027d99e
|
@ -64,6 +64,9 @@ dependencies {
|
||||||
testCompile "org.hamcrest:hamcrest-all:${versions.hamcrest}"
|
testCompile "org.hamcrest:hamcrest-all:${versions.hamcrest}"
|
||||||
//this is needed to make RestHighLevelClientTests#testApiNamingConventions work from IDEs
|
//this is needed to make RestHighLevelClientTests#testApiNamingConventions work from IDEs
|
||||||
testCompile "org.elasticsearch:rest-api-spec:${version}"
|
testCompile "org.elasticsearch:rest-api-spec:${version}"
|
||||||
|
// Needed for serialization tests:
|
||||||
|
// (In order to serialize a server side class to a client side class or the other way around)
|
||||||
|
testCompile "org.elasticsearch.plugin:x-pack-core:${version}"
|
||||||
|
|
||||||
restSpec "org.elasticsearch:rest-api-spec:${version}"
|
restSpec "org.elasticsearch:rest-api-spec:${version}"
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,351 +20,67 @@
|
||||||
package org.elasticsearch.client.ccr;
|
package org.elasticsearch.client.ccr;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.client.ccr.AutoFollowStats.AutoFollowedCluster;
|
import org.elasticsearch.client.AbstractResponseTestCase;
|
||||||
import org.elasticsearch.client.ccr.IndicesFollowStats.ShardFollowStats;
|
import org.elasticsearch.client.ccr.IndicesFollowStats.ShardFollowStats;
|
||||||
import org.elasticsearch.common.collect.Tuple;
|
import org.elasticsearch.common.collect.Tuple;
|
||||||
import org.elasticsearch.common.unit.ByteSizeUnit;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.unit.ByteSizeValue;
|
import org.elasticsearch.xpack.core.ccr.ShardFollowNodeTaskStatus;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.xpack.core.ccr.action.CcrStatsAction;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.xpack.core.ccr.action.FollowStatsAction;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
|
||||||
import org.elasticsearch.test.ESTestCase;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import static org.elasticsearch.test.AbstractXContentTestCase.xContentTester;
|
|
||||||
import static org.hamcrest.Matchers.anyOf;
|
import static org.hamcrest.Matchers.anyOf;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.instanceOf;
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
|
|
||||||
public class CcrStatsResponseTests extends ESTestCase {
|
public class CcrStatsResponseTests extends AbstractResponseTestCase<CcrStatsAction.Response, CcrStatsResponse> {
|
||||||
|
|
||||||
public void testFromXContent() throws IOException {
|
@Override
|
||||||
xContentTester(this::createParser,
|
protected CcrStatsAction.Response createServerTestInstance() {
|
||||||
CcrStatsResponseTests::createTestInstance,
|
org.elasticsearch.xpack.core.ccr.AutoFollowStats autoFollowStats = new org.elasticsearch.xpack.core.ccr.AutoFollowStats(
|
||||||
CcrStatsResponseTests::toXContent,
|
randomNonNegativeLong(),
|
||||||
CcrStatsResponse::fromXContent)
|
randomNonNegativeLong(),
|
||||||
.supportsUnknownFields(true)
|
randomNonNegativeLong(),
|
||||||
.assertEqualsConsumer(CcrStatsResponseTests::assertEqualInstances)
|
randomReadExceptions(),
|
||||||
.assertToXContentEquivalence(false)
|
randomTrackingClusters()
|
||||||
.test();
|
);
|
||||||
|
FollowStatsAction.StatsResponses statsResponse = createStatsResponse();
|
||||||
|
return new CcrStatsAction.Response(autoFollowStats, statsResponse);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Needed, because exceptions in IndicesFollowStats and AutoFollowStats cannot be compared
|
static NavigableMap<String, Tuple<Long, ElasticsearchException>> randomReadExceptions() {
|
||||||
private static void assertEqualInstances(CcrStatsResponse expectedInstance, CcrStatsResponse newInstance) {
|
|
||||||
assertNotSame(expectedInstance, newInstance);
|
|
||||||
|
|
||||||
{
|
|
||||||
AutoFollowStats newAutoFollowStats = newInstance.getAutoFollowStats();
|
|
||||||
AutoFollowStats expectedAutoFollowStats = expectedInstance.getAutoFollowStats();
|
|
||||||
assertThat(newAutoFollowStats.getNumberOfSuccessfulFollowIndices(),
|
|
||||||
equalTo(expectedAutoFollowStats.getNumberOfSuccessfulFollowIndices()));
|
|
||||||
assertThat(newAutoFollowStats.getNumberOfFailedRemoteClusterStateRequests(),
|
|
||||||
equalTo(expectedAutoFollowStats.getNumberOfFailedRemoteClusterStateRequests()));
|
|
||||||
assertThat(newAutoFollowStats.getNumberOfFailedFollowIndices(),
|
|
||||||
equalTo(expectedAutoFollowStats.getNumberOfFailedFollowIndices()));
|
|
||||||
assertThat(newAutoFollowStats.getRecentAutoFollowErrors().size(),
|
|
||||||
equalTo(expectedAutoFollowStats.getRecentAutoFollowErrors().size()));
|
|
||||||
assertThat(newAutoFollowStats.getRecentAutoFollowErrors().keySet(),
|
|
||||||
equalTo(expectedAutoFollowStats.getRecentAutoFollowErrors().keySet()));
|
|
||||||
for (final Map.Entry<String, Tuple<Long, ElasticsearchException>> entry :
|
|
||||||
newAutoFollowStats.getRecentAutoFollowErrors().entrySet()) {
|
|
||||||
// x-content loses the exception
|
|
||||||
final Tuple<Long, ElasticsearchException> expected =
|
|
||||||
expectedAutoFollowStats.getRecentAutoFollowErrors().get(entry.getKey());
|
|
||||||
assertThat(entry.getValue().v2().getMessage(), containsString(expected.v2().getMessage()));
|
|
||||||
assertThat(entry.getValue().v1(), equalTo(expected.v1()));
|
|
||||||
assertNotNull(entry.getValue().v2().getCause());
|
|
||||||
assertThat(
|
|
||||||
entry.getValue().v2().getCause(),
|
|
||||||
anyOf(instanceOf(ElasticsearchException.class), instanceOf(IllegalStateException.class)));
|
|
||||||
assertThat(entry.getValue().v2().getCause().getMessage(), containsString(expected.v2().getCause().getMessage()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
{
|
|
||||||
IndicesFollowStats newIndicesFollowStats = newInstance.getIndicesFollowStats();
|
|
||||||
IndicesFollowStats expectedIndicesFollowStats = expectedInstance.getIndicesFollowStats();
|
|
||||||
assertThat(newIndicesFollowStats.getShardFollowStats().size(),
|
|
||||||
equalTo(expectedIndicesFollowStats.getShardFollowStats().size()));
|
|
||||||
assertThat(newIndicesFollowStats.getShardFollowStats().keySet(),
|
|
||||||
equalTo(expectedIndicesFollowStats.getShardFollowStats().keySet()));
|
|
||||||
for (Map.Entry<String, List<ShardFollowStats>> indexEntry : newIndicesFollowStats.getShardFollowStats().entrySet()) {
|
|
||||||
List<ShardFollowStats> newStats = indexEntry.getValue();
|
|
||||||
List<ShardFollowStats> expectedStats = expectedIndicesFollowStats.getShardFollowStats(indexEntry.getKey());
|
|
||||||
assertThat(newStats.size(), equalTo(expectedStats.size()));
|
|
||||||
for (int i = 0; i < newStats.size(); i++) {
|
|
||||||
ShardFollowStats actualShardFollowStats = newStats.get(i);
|
|
||||||
ShardFollowStats expectedShardFollowStats = expectedStats.get(i);
|
|
||||||
|
|
||||||
assertThat(actualShardFollowStats.getRemoteCluster(), equalTo(expectedShardFollowStats.getRemoteCluster()));
|
|
||||||
assertThat(actualShardFollowStats.getLeaderIndex(), equalTo(expectedShardFollowStats.getLeaderIndex()));
|
|
||||||
assertThat(actualShardFollowStats.getFollowerIndex(), equalTo(expectedShardFollowStats.getFollowerIndex()));
|
|
||||||
assertThat(actualShardFollowStats.getShardId(), equalTo(expectedShardFollowStats.getShardId()));
|
|
||||||
assertThat(actualShardFollowStats.getLeaderGlobalCheckpoint(),
|
|
||||||
equalTo(expectedShardFollowStats.getLeaderGlobalCheckpoint()));
|
|
||||||
assertThat(actualShardFollowStats.getLeaderMaxSeqNo(), equalTo(expectedShardFollowStats.getLeaderMaxSeqNo()));
|
|
||||||
assertThat(actualShardFollowStats.getFollowerGlobalCheckpoint(),
|
|
||||||
equalTo(expectedShardFollowStats.getFollowerGlobalCheckpoint()));
|
|
||||||
assertThat(actualShardFollowStats.getLastRequestedSeqNo(), equalTo(expectedShardFollowStats.getLastRequestedSeqNo()));
|
|
||||||
assertThat(actualShardFollowStats.getOutstandingReadRequests(),
|
|
||||||
equalTo(expectedShardFollowStats.getOutstandingReadRequests()));
|
|
||||||
assertThat(actualShardFollowStats.getOutstandingWriteRequests(),
|
|
||||||
equalTo(expectedShardFollowStats.getOutstandingWriteRequests()));
|
|
||||||
assertThat(actualShardFollowStats.getWriteBufferOperationCount(),
|
|
||||||
equalTo(expectedShardFollowStats.getWriteBufferOperationCount()));
|
|
||||||
assertThat(actualShardFollowStats.getFollowerMappingVersion(),
|
|
||||||
equalTo(expectedShardFollowStats.getFollowerMappingVersion()));
|
|
||||||
assertThat(actualShardFollowStats.getFollowerSettingsVersion(),
|
|
||||||
equalTo(expectedShardFollowStats.getFollowerSettingsVersion()));
|
|
||||||
assertThat(actualShardFollowStats.getTotalReadTimeMillis(),
|
|
||||||
equalTo(expectedShardFollowStats.getTotalReadTimeMillis()));
|
|
||||||
assertThat(actualShardFollowStats.getSuccessfulReadRequests(),
|
|
||||||
equalTo(expectedShardFollowStats.getSuccessfulReadRequests()));
|
|
||||||
assertThat(actualShardFollowStats.getFailedReadRequests(), equalTo(expectedShardFollowStats.getFailedReadRequests()));
|
|
||||||
assertThat(actualShardFollowStats.getOperationsReads(), equalTo(expectedShardFollowStats.getOperationsReads()));
|
|
||||||
assertThat(actualShardFollowStats.getBytesRead(), equalTo(expectedShardFollowStats.getBytesRead()));
|
|
||||||
assertThat(actualShardFollowStats.getTotalWriteTimeMillis(),
|
|
||||||
equalTo(expectedShardFollowStats.getTotalWriteTimeMillis()));
|
|
||||||
assertThat(actualShardFollowStats.getSuccessfulWriteRequests(),
|
|
||||||
equalTo(expectedShardFollowStats.getSuccessfulWriteRequests()));
|
|
||||||
assertThat(actualShardFollowStats.getFailedWriteRequests(),
|
|
||||||
equalTo(expectedShardFollowStats.getFailedWriteRequests()));
|
|
||||||
assertThat(actualShardFollowStats.getOperationWritten(), equalTo(expectedShardFollowStats.getOperationWritten()));
|
|
||||||
assertThat(actualShardFollowStats.getReadExceptions().size(),
|
|
||||||
equalTo(expectedShardFollowStats.getReadExceptions().size()));
|
|
||||||
assertThat(actualShardFollowStats.getReadExceptions().keySet(),
|
|
||||||
equalTo(expectedShardFollowStats.getReadExceptions().keySet()));
|
|
||||||
for (final Map.Entry<Long, Tuple<Integer, ElasticsearchException>> entry :
|
|
||||||
actualShardFollowStats.getReadExceptions().entrySet()) {
|
|
||||||
final Tuple<Integer, ElasticsearchException> expectedTuple =
|
|
||||||
expectedShardFollowStats.getReadExceptions().get(entry.getKey());
|
|
||||||
assertThat(entry.getValue().v1(), equalTo(expectedTuple.v1()));
|
|
||||||
// x-content loses the exception
|
|
||||||
final ElasticsearchException expected = expectedTuple.v2();
|
|
||||||
assertThat(entry.getValue().v2().getMessage(), containsString(expected.getMessage()));
|
|
||||||
assertNotNull(entry.getValue().v2().getCause());
|
|
||||||
assertThat(
|
|
||||||
entry.getValue().v2().getCause(),
|
|
||||||
anyOf(instanceOf(ElasticsearchException.class), instanceOf(IllegalStateException.class)));
|
|
||||||
assertThat(entry.getValue().v2().getCause().getMessage(), containsString(expected.getCause().getMessage()));
|
|
||||||
}
|
|
||||||
assertThat(actualShardFollowStats.getTimeSinceLastReadMillis(),
|
|
||||||
equalTo(expectedShardFollowStats.getTimeSinceLastReadMillis()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void toXContent(CcrStatsResponse response, XContentBuilder builder) throws IOException {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
AutoFollowStats autoFollowStats = response.getAutoFollowStats();
|
|
||||||
builder.startObject(CcrStatsResponse.AUTO_FOLLOW_STATS_FIELD.getPreferredName());
|
|
||||||
{
|
|
||||||
builder.field(AutoFollowStats.NUMBER_OF_SUCCESSFUL_INDICES_AUTO_FOLLOWED.getPreferredName(),
|
|
||||||
autoFollowStats.getNumberOfSuccessfulFollowIndices());
|
|
||||||
builder.field(AutoFollowStats.NUMBER_OF_FAILED_REMOTE_CLUSTER_STATE_REQUESTS.getPreferredName(),
|
|
||||||
autoFollowStats.getNumberOfFailedRemoteClusterStateRequests());
|
|
||||||
builder.field(AutoFollowStats.NUMBER_OF_FAILED_INDICES_AUTO_FOLLOWED.getPreferredName(),
|
|
||||||
autoFollowStats.getNumberOfFailedFollowIndices());
|
|
||||||
builder.startArray(AutoFollowStats.RECENT_AUTO_FOLLOW_ERRORS.getPreferredName());
|
|
||||||
for (Map.Entry<String, Tuple<Long, ElasticsearchException>> entry :
|
|
||||||
autoFollowStats.getRecentAutoFollowErrors().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(AutoFollowStats.LEADER_INDEX.getPreferredName(), entry.getKey());
|
|
||||||
builder.field(AutoFollowStats.TIMESTAMP.getPreferredName(), entry.getValue().v1());
|
|
||||||
builder.field(AutoFollowStats.AUTO_FOLLOW_EXCEPTION.getPreferredName());
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
ElasticsearchException.generateThrowableXContent(builder, ToXContent.EMPTY_PARAMS, entry.getValue().v2());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
builder.startArray(AutoFollowStats.AUTO_FOLLOWED_CLUSTERS.getPreferredName());
|
|
||||||
for (Map.Entry<String, AutoFollowedCluster> entry : autoFollowStats.getAutoFollowedClusters().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(AutoFollowStats.CLUSTER_NAME.getPreferredName(), entry.getKey());
|
|
||||||
builder.field(AutoFollowStats.TIME_SINCE_LAST_CHECK_MILLIS.getPreferredName(),
|
|
||||||
entry.getValue().getTimeSinceLastCheckMillis());
|
|
||||||
builder.field(AutoFollowStats.LAST_SEEN_METADATA_VERSION.getPreferredName(),
|
|
||||||
entry.getValue().getLastSeenMetadataVersion());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
|
|
||||||
IndicesFollowStats indicesFollowStats = response.getIndicesFollowStats();
|
|
||||||
builder.startObject(CcrStatsResponse.FOLLOW_STATS_FIELD.getPreferredName());
|
|
||||||
{
|
|
||||||
builder.startArray(IndicesFollowStats.INDICES_FIELD.getPreferredName());
|
|
||||||
for (Map.Entry<String, List<ShardFollowStats>> indexEntry :
|
|
||||||
indicesFollowStats.getShardFollowStats().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(IndicesFollowStats.INDEX_FIELD.getPreferredName(), indexEntry.getKey());
|
|
||||||
builder.startArray(IndicesFollowStats.SHARDS_FIELD.getPreferredName());
|
|
||||||
{
|
|
||||||
for (ShardFollowStats stats : indexEntry.getValue()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(ShardFollowStats.LEADER_CLUSTER.getPreferredName(), stats.getRemoteCluster());
|
|
||||||
builder.field(ShardFollowStats.LEADER_INDEX.getPreferredName(), stats.getLeaderIndex());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_INDEX.getPreferredName(), stats.getFollowerIndex());
|
|
||||||
builder.field(ShardFollowStats.SHARD_ID.getPreferredName(), stats.getShardId());
|
|
||||||
builder.field(ShardFollowStats.LEADER_GLOBAL_CHECKPOINT_FIELD.getPreferredName(),
|
|
||||||
stats.getLeaderGlobalCheckpoint());
|
|
||||||
builder.field(ShardFollowStats.LEADER_MAX_SEQ_NO_FIELD.getPreferredName(), stats.getLeaderMaxSeqNo());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_GLOBAL_CHECKPOINT_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerGlobalCheckpoint());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_MAX_SEQ_NO_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerMaxSeqNo());
|
|
||||||
builder.field(ShardFollowStats.LAST_REQUESTED_SEQ_NO_FIELD.getPreferredName(),
|
|
||||||
stats.getLastRequestedSeqNo());
|
|
||||||
builder.field(ShardFollowStats.OUTSTANDING_READ_REQUESTS.getPreferredName(),
|
|
||||||
stats.getOutstandingReadRequests());
|
|
||||||
builder.field(ShardFollowStats.OUTSTANDING_WRITE_REQUESTS.getPreferredName(),
|
|
||||||
stats.getOutstandingWriteRequests());
|
|
||||||
builder.field(ShardFollowStats.WRITE_BUFFER_OPERATION_COUNT_FIELD.getPreferredName(),
|
|
||||||
stats.getWriteBufferOperationCount());
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.WRITE_BUFFER_SIZE_IN_BYTES_FIELD.getPreferredName(),
|
|
||||||
"write_buffer_size",
|
|
||||||
new ByteSizeValue(stats.getWriteBufferSizeInBytes()));
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_MAPPING_VERSION_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerMappingVersion());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_SETTINGS_VERSION_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerSettingsVersion());
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TOTAL_READ_TIME_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"total_read_time",
|
|
||||||
new TimeValue(stats.getTotalReadTimeMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TOTAL_READ_REMOTE_EXEC_TIME_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"total_read_remote_exec_time",
|
|
||||||
new TimeValue(stats.getTotalReadRemoteExecTimeMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
builder.field(ShardFollowStats.SUCCESSFUL_READ_REQUESTS_FIELD.getPreferredName(),
|
|
||||||
stats.getSuccessfulReadRequests());
|
|
||||||
builder.field(ShardFollowStats.FAILED_READ_REQUESTS_FIELD.getPreferredName(),
|
|
||||||
stats.getFailedReadRequests());
|
|
||||||
builder.field(ShardFollowStats.OPERATIONS_READ_FIELD.getPreferredName(), stats.getOperationsReads());
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.BYTES_READ.getPreferredName(),
|
|
||||||
"total_read",
|
|
||||||
new ByteSizeValue(stats.getBytesRead(), ByteSizeUnit.BYTES));
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TOTAL_WRITE_TIME_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"total_write_time",
|
|
||||||
new TimeValue(stats.getTotalWriteTimeMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
builder.field(ShardFollowStats.SUCCESSFUL_WRITE_REQUESTS_FIELD.getPreferredName(),
|
|
||||||
stats.getSuccessfulWriteRequests());
|
|
||||||
builder.field(ShardFollowStats.FAILED_WRITE_REQUEST_FIELD.getPreferredName(),
|
|
||||||
stats.getFailedWriteRequests());
|
|
||||||
builder.field(ShardFollowStats.OPERATIONS_WRITTEN.getPreferredName(), stats.getOperationWritten());
|
|
||||||
builder.startArray(ShardFollowStats.READ_EXCEPTIONS.getPreferredName());
|
|
||||||
{
|
|
||||||
for (final Map.Entry<Long, Tuple<Integer, ElasticsearchException>> entry :
|
|
||||||
stats.getReadExceptions().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(ShardFollowStats.READ_EXCEPTIONS_ENTRY_FROM_SEQ_NO.getPreferredName(),
|
|
||||||
entry.getKey());
|
|
||||||
builder.field(ShardFollowStats.READ_EXCEPTIONS_RETRIES.getPreferredName(),
|
|
||||||
entry.getValue().v1());
|
|
||||||
builder.field(ShardFollowStats.READ_EXCEPTIONS_ENTRY_EXCEPTION.getPreferredName());
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
ElasticsearchException.generateThrowableXContent(builder, ToXContent.EMPTY_PARAMS,
|
|
||||||
entry.getValue().v2());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TIME_SINCE_LAST_READ_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"time_since_last_read",
|
|
||||||
new TimeValue(stats.getTimeSinceLastReadMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
if (stats.getFatalException() != null) {
|
|
||||||
builder.field(ShardFollowStats.FATAL_EXCEPTION.getPreferredName());
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
ElasticsearchException.generateThrowableXContent(builder, ToXContent.EMPTY_PARAMS,
|
|
||||||
stats.getFatalException());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static CcrStatsResponse createTestInstance() {
|
|
||||||
return new CcrStatsResponse(randomAutoFollowStats(), randomIndicesFollowStats());
|
|
||||||
}
|
|
||||||
|
|
||||||
private static AutoFollowStats randomAutoFollowStats() {
|
|
||||||
final int count = randomIntBetween(0, 16);
|
final int count = randomIntBetween(0, 16);
|
||||||
final NavigableMap<String, Tuple<Long, ElasticsearchException>> readExceptions = new TreeMap<>();
|
final NavigableMap<String, Tuple<Long, ElasticsearchException>> readExceptions = new TreeMap<>();
|
||||||
for (int i = 0; i < count; i++) {
|
for (int i = 0; i < count; i++) {
|
||||||
readExceptions.put("" + i, Tuple.tuple(randomNonNegativeLong(),
|
readExceptions.put("" + i, Tuple.tuple(randomNonNegativeLong(),
|
||||||
new ElasticsearchException(new IllegalStateException("index [" + i + "]"))));
|
new ElasticsearchException(new IllegalStateException("index [" + i + "]"))));
|
||||||
}
|
}
|
||||||
final NavigableMap<String, AutoFollowedCluster> autoFollowClusters = new TreeMap<>();
|
return readExceptions;
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
autoFollowClusters.put("" + i, new AutoFollowedCluster(randomLong(), randomNonNegativeLong()));
|
|
||||||
}
|
|
||||||
return new AutoFollowStats(
|
|
||||||
randomNonNegativeLong(),
|
|
||||||
randomNonNegativeLong(),
|
|
||||||
randomNonNegativeLong(),
|
|
||||||
readExceptions,
|
|
||||||
autoFollowClusters
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static IndicesFollowStats randomIndicesFollowStats() {
|
static NavigableMap<String, org.elasticsearch.xpack.core.ccr.AutoFollowStats.AutoFollowedCluster> randomTrackingClusters() {
|
||||||
int numIndices = randomIntBetween(0, 16);
|
|
||||||
NavigableMap<String, List<ShardFollowStats>> shardFollowStats = new TreeMap<>();
|
|
||||||
for (int i = 0; i < numIndices; i++) {
|
|
||||||
String index = randomAlphaOfLength(4);
|
|
||||||
int numShards = randomIntBetween(0, 5);
|
|
||||||
List<ShardFollowStats> stats = new ArrayList<>(numShards);
|
|
||||||
shardFollowStats.put(index, stats);
|
|
||||||
for (int j = 0; j < numShards; j++) {
|
|
||||||
final int count = randomIntBetween(0, 16);
|
final int count = randomIntBetween(0, 16);
|
||||||
final NavigableMap<Long, Tuple<Integer, ElasticsearchException>> readExceptions = new TreeMap<>();
|
final NavigableMap<String, org.elasticsearch.xpack.core.ccr.AutoFollowStats.AutoFollowedCluster> readExceptions = new TreeMap<>();
|
||||||
for (long k = 0; k < count; k++) {
|
for (int i = 0; i < count; i++) {
|
||||||
readExceptions.put(k, new Tuple<>(randomIntBetween(0, Integer.MAX_VALUE),
|
readExceptions.put("" + i,
|
||||||
new ElasticsearchException(new IllegalStateException("index [" + k + "]"))));
|
new org.elasticsearch.xpack.core.ccr.AutoFollowStats.AutoFollowedCluster(randomLong(), randomNonNegativeLong()));
|
||||||
|
}
|
||||||
|
return readExceptions;
|
||||||
}
|
}
|
||||||
|
|
||||||
stats.add(new ShardFollowStats(
|
static FollowStatsAction.StatsResponses createStatsResponse() {
|
||||||
|
int numResponses = randomIntBetween(0, 8);
|
||||||
|
List<FollowStatsAction.StatsResponse> responses = new ArrayList<>(numResponses);
|
||||||
|
for (int i = 0; i < numResponses; i++) {
|
||||||
|
ShardFollowNodeTaskStatus status = new ShardFollowNodeTaskStatus(
|
||||||
randomAlphaOfLength(4),
|
randomAlphaOfLength(4),
|
||||||
randomAlphaOfLength(4),
|
randomAlphaOfLength(4),
|
||||||
randomAlphaOfLength(4),
|
randomAlphaOfLength(4),
|
||||||
|
@ -390,12 +106,127 @@ public class CcrStatsResponseTests extends ESTestCase {
|
||||||
randomNonNegativeLong(),
|
randomNonNegativeLong(),
|
||||||
randomNonNegativeLong(),
|
randomNonNegativeLong(),
|
||||||
randomNonNegativeLong(),
|
randomNonNegativeLong(),
|
||||||
|
Collections.emptyNavigableMap(),
|
||||||
randomLong(),
|
randomLong(),
|
||||||
readExceptions,
|
randomBoolean() ? new ElasticsearchException("fatal error") : null);
|
||||||
randomBoolean() ? new ElasticsearchException("fatal error") : null));
|
responses.add(new FollowStatsAction.StatsResponse(status));
|
||||||
|
}
|
||||||
|
return new FollowStatsAction.StatsResponses(Collections.emptyList(), Collections.emptyList(), responses);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected CcrStatsResponse doParseToClientInstance(XContentParser parser) throws IOException {
|
||||||
|
return CcrStatsResponse.fromXContent(parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void assertInstances(CcrStatsAction.Response serverTestInstance, CcrStatsResponse clientInstance) {
|
||||||
|
{
|
||||||
|
AutoFollowStats newAutoFollowStats = clientInstance.getAutoFollowStats();
|
||||||
|
org.elasticsearch.xpack.core.ccr.AutoFollowStats expectedAutoFollowStats = serverTestInstance.getAutoFollowStats();
|
||||||
|
assertThat(newAutoFollowStats.getNumberOfSuccessfulFollowIndices(),
|
||||||
|
equalTo(expectedAutoFollowStats.getNumberOfSuccessfulFollowIndices()));
|
||||||
|
assertThat(newAutoFollowStats.getNumberOfFailedRemoteClusterStateRequests(),
|
||||||
|
equalTo(expectedAutoFollowStats.getNumberOfFailedRemoteClusterStateRequests()));
|
||||||
|
assertThat(newAutoFollowStats.getNumberOfFailedFollowIndices(),
|
||||||
|
equalTo(expectedAutoFollowStats.getNumberOfFailedFollowIndices()));
|
||||||
|
assertThat(newAutoFollowStats.getRecentAutoFollowErrors().size(),
|
||||||
|
equalTo(expectedAutoFollowStats.getRecentAutoFollowErrors().size()));
|
||||||
|
assertThat(newAutoFollowStats.getRecentAutoFollowErrors().keySet(),
|
||||||
|
equalTo(expectedAutoFollowStats.getRecentAutoFollowErrors().keySet()));
|
||||||
|
for (final Map.Entry<String, Tuple<Long, ElasticsearchException>> entry :
|
||||||
|
newAutoFollowStats.getRecentAutoFollowErrors().entrySet()) {
|
||||||
|
// x-content loses the exception
|
||||||
|
final Tuple<Long, ElasticsearchException> expected =
|
||||||
|
expectedAutoFollowStats.getRecentAutoFollowErrors().get(entry.getKey());
|
||||||
|
assertThat(entry.getValue().v2().getMessage(), containsString(expected.v2().getMessage()));
|
||||||
|
assertThat(entry.getValue().v1(), equalTo(expected.v1()));
|
||||||
|
assertNotNull(entry.getValue().v2().getCause());
|
||||||
|
assertThat(
|
||||||
|
entry.getValue().v2().getCause(),
|
||||||
|
anyOf(instanceOf(ElasticsearchException.class), instanceOf(IllegalStateException.class)));
|
||||||
|
assertThat(entry.getValue().v2().getCause().getMessage(), containsString(expected.v2().getCause().getMessage()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
{
|
||||||
|
IndicesFollowStats newIndicesFollowStats = clientInstance.getIndicesFollowStats();
|
||||||
|
|
||||||
|
// sort by index name, then shard ID
|
||||||
|
final Map<String, Map<Integer, FollowStatsAction.StatsResponse>> expectedIndicesFollowStats = new TreeMap<>();
|
||||||
|
for (final FollowStatsAction.StatsResponse statsResponse : serverTestInstance.getFollowStats().getStatsResponses()) {
|
||||||
|
expectedIndicesFollowStats.computeIfAbsent(
|
||||||
|
statsResponse.status().followerIndex(),
|
||||||
|
k -> new TreeMap<>()).put(statsResponse.status().getShardId(), statsResponse);
|
||||||
|
}
|
||||||
|
assertThat(newIndicesFollowStats.getShardFollowStats().size(),
|
||||||
|
equalTo(expectedIndicesFollowStats.size()));
|
||||||
|
assertThat(newIndicesFollowStats.getShardFollowStats().keySet(),
|
||||||
|
equalTo(expectedIndicesFollowStats.keySet()));
|
||||||
|
for (Map.Entry<String, List<ShardFollowStats>> indexEntry : newIndicesFollowStats.getShardFollowStats().entrySet()) {
|
||||||
|
List<ShardFollowStats> newStats = indexEntry.getValue();
|
||||||
|
Map<Integer, FollowStatsAction.StatsResponse> expectedStats = expectedIndicesFollowStats.get(indexEntry.getKey());
|
||||||
|
assertThat(newStats.size(), equalTo(expectedStats.size()));
|
||||||
|
for (int i = 0; i < newStats.size(); i++) {
|
||||||
|
ShardFollowStats actualShardFollowStats = newStats.get(i);
|
||||||
|
ShardFollowNodeTaskStatus expectedShardFollowStats = expectedStats.get(actualShardFollowStats.getShardId()).status();
|
||||||
|
|
||||||
|
assertThat(actualShardFollowStats.getRemoteCluster(), equalTo(expectedShardFollowStats.getRemoteCluster()));
|
||||||
|
assertThat(actualShardFollowStats.getLeaderIndex(), equalTo(expectedShardFollowStats.leaderIndex()));
|
||||||
|
assertThat(actualShardFollowStats.getFollowerIndex(), equalTo(expectedShardFollowStats.followerIndex()));
|
||||||
|
assertThat(actualShardFollowStats.getShardId(), equalTo(expectedShardFollowStats.getShardId()));
|
||||||
|
assertThat(actualShardFollowStats.getLeaderGlobalCheckpoint(),
|
||||||
|
equalTo(expectedShardFollowStats.leaderGlobalCheckpoint()));
|
||||||
|
assertThat(actualShardFollowStats.getLeaderMaxSeqNo(), equalTo(expectedShardFollowStats.leaderMaxSeqNo()));
|
||||||
|
assertThat(actualShardFollowStats.getFollowerGlobalCheckpoint(),
|
||||||
|
equalTo(expectedShardFollowStats.followerGlobalCheckpoint()));
|
||||||
|
assertThat(actualShardFollowStats.getLastRequestedSeqNo(), equalTo(expectedShardFollowStats.lastRequestedSeqNo()));
|
||||||
|
assertThat(actualShardFollowStats.getOutstandingReadRequests(),
|
||||||
|
equalTo(expectedShardFollowStats.outstandingReadRequests()));
|
||||||
|
assertThat(actualShardFollowStats.getOutstandingWriteRequests(),
|
||||||
|
equalTo(expectedShardFollowStats.outstandingWriteRequests()));
|
||||||
|
assertThat(actualShardFollowStats.getWriteBufferOperationCount(),
|
||||||
|
equalTo(expectedShardFollowStats.writeBufferOperationCount()));
|
||||||
|
assertThat(actualShardFollowStats.getFollowerMappingVersion(),
|
||||||
|
equalTo(expectedShardFollowStats.followerMappingVersion()));
|
||||||
|
assertThat(actualShardFollowStats.getFollowerSettingsVersion(),
|
||||||
|
equalTo(expectedShardFollowStats.followerSettingsVersion()));
|
||||||
|
assertThat(actualShardFollowStats.getTotalReadTimeMillis(),
|
||||||
|
equalTo(expectedShardFollowStats.totalReadTimeMillis()));
|
||||||
|
assertThat(actualShardFollowStats.getSuccessfulReadRequests(),
|
||||||
|
equalTo(expectedShardFollowStats.successfulReadRequests()));
|
||||||
|
assertThat(actualShardFollowStats.getFailedReadRequests(), equalTo(expectedShardFollowStats.failedReadRequests()));
|
||||||
|
assertThat(actualShardFollowStats.getOperationsReads(), equalTo(expectedShardFollowStats.operationsReads()));
|
||||||
|
assertThat(actualShardFollowStats.getBytesRead(), equalTo(expectedShardFollowStats.bytesRead()));
|
||||||
|
assertThat(actualShardFollowStats.getTotalWriteTimeMillis(),
|
||||||
|
equalTo(expectedShardFollowStats.totalWriteTimeMillis()));
|
||||||
|
assertThat(actualShardFollowStats.getSuccessfulWriteRequests(),
|
||||||
|
equalTo(expectedShardFollowStats.successfulWriteRequests()));
|
||||||
|
assertThat(actualShardFollowStats.getFailedWriteRequests(),
|
||||||
|
equalTo(expectedShardFollowStats.failedWriteRequests()));
|
||||||
|
assertThat(actualShardFollowStats.getOperationWritten(), equalTo(expectedShardFollowStats.operationWritten()));
|
||||||
|
assertThat(actualShardFollowStats.getReadExceptions().size(),
|
||||||
|
equalTo(expectedShardFollowStats.readExceptions().size()));
|
||||||
|
assertThat(actualShardFollowStats.getReadExceptions().keySet(),
|
||||||
|
equalTo(expectedShardFollowStats.readExceptions().keySet()));
|
||||||
|
for (final Map.Entry<Long, Tuple<Integer, ElasticsearchException>> entry :
|
||||||
|
actualShardFollowStats.getReadExceptions().entrySet()) {
|
||||||
|
final Tuple<Integer, ElasticsearchException> expectedTuple =
|
||||||
|
expectedShardFollowStats.readExceptions().get(entry.getKey());
|
||||||
|
assertThat(entry.getValue().v1(), equalTo(expectedTuple.v1()));
|
||||||
|
// x-content loses the exception
|
||||||
|
final ElasticsearchException expected = expectedTuple.v2();
|
||||||
|
assertThat(entry.getValue().v2().getMessage(), containsString(expected.getMessage()));
|
||||||
|
assertNotNull(entry.getValue().v2().getCause());
|
||||||
|
assertThat(
|
||||||
|
entry.getValue().v2().getCause(),
|
||||||
|
anyOf(instanceOf(ElasticsearchException.class), instanceOf(IllegalStateException.class)));
|
||||||
|
assertThat(entry.getValue().v2().getCause().getMessage(), containsString(expected.getCause().getMessage()));
|
||||||
|
}
|
||||||
|
assertThat(actualShardFollowStats.getTimeSinceLastReadMillis(),
|
||||||
|
equalTo(expectedShardFollowStats.timeSinceLastReadMillis()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new IndicesFollowStats(shardFollowStats);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,59 +19,89 @@
|
||||||
|
|
||||||
package org.elasticsearch.client.ccr;
|
package org.elasticsearch.client.ccr;
|
||||||
|
|
||||||
import org.elasticsearch.client.ccr.FollowInfoResponse.FollowerInfo;
|
import org.elasticsearch.client.AbstractResponseTestCase;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.common.unit.ByteSizeValue;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
import org.elasticsearch.xpack.core.ccr.action.FollowInfoAction;
|
||||||
|
import org.elasticsearch.xpack.core.ccr.action.FollowParameters;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
import static org.elasticsearch.test.AbstractXContentTestCase.xContentTester;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
|
|
||||||
public class FollowInfoResponseTests extends ESTestCase {
|
public class FollowInfoResponseTests extends AbstractResponseTestCase<FollowInfoAction.Response, FollowInfoResponse> {
|
||||||
|
|
||||||
public void testFromXContent() throws IOException {
|
@Override
|
||||||
xContentTester(this::createParser,
|
protected FollowInfoAction.Response createServerTestInstance() {
|
||||||
FollowInfoResponseTests::createTestInstance,
|
int numInfos = randomIntBetween(0, 32);
|
||||||
FollowInfoResponseTests::toXContent,
|
List<FollowInfoAction.Response.FollowerInfo> infos = new ArrayList<>(numInfos);
|
||||||
FollowInfoResponse::fromXContent)
|
|
||||||
.supportsUnknownFields(true)
|
|
||||||
.test();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void toXContent(FollowInfoResponse response, XContentBuilder builder) throws IOException {
|
|
||||||
builder.startObject();
|
|
||||||
builder.startArray(FollowInfoResponse.FOLLOWER_INDICES_FIELD.getPreferredName());
|
|
||||||
for (FollowerInfo info : response.getInfos()) {
|
|
||||||
builder.startObject();
|
|
||||||
builder.field(FollowerInfo.FOLLOWER_INDEX_FIELD.getPreferredName(), info.getFollowerIndex());
|
|
||||||
builder.field(FollowerInfo.REMOTE_CLUSTER_FIELD.getPreferredName(), info.getRemoteCluster());
|
|
||||||
builder.field(FollowerInfo.LEADER_INDEX_FIELD.getPreferredName(), info.getLeaderIndex());
|
|
||||||
builder.field(FollowerInfo.STATUS_FIELD.getPreferredName(), info.getStatus().getName());
|
|
||||||
if (info.getParameters() != null) {
|
|
||||||
builder.startObject(FollowerInfo.PARAMETERS_FIELD.getPreferredName());
|
|
||||||
{
|
|
||||||
info.getParameters().toXContentFragment(builder, ToXContent.EMPTY_PARAMS);
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static FollowInfoResponse createTestInstance() {
|
|
||||||
int numInfos = randomIntBetween(0, 64);
|
|
||||||
List<FollowerInfo> infos = new ArrayList<>(numInfos);
|
|
||||||
for (int i = 0; i < numInfos; i++) {
|
for (int i = 0; i < numInfos; i++) {
|
||||||
FollowInfoResponse.Status status = randomFrom(FollowInfoResponse.Status.values());
|
FollowParameters followParameters = null;
|
||||||
FollowConfig followConfig = randomBoolean() ? FollowConfigTests.createTestInstance() : null;
|
if (randomBoolean()) {
|
||||||
infos.add(new FollowerInfo(randomAlphaOfLength(4), randomAlphaOfLength(4), randomAlphaOfLength(4), status, followConfig));
|
followParameters = randomFollowParameters();
|
||||||
|
}
|
||||||
|
|
||||||
|
infos.add(new FollowInfoAction.Response.FollowerInfo(randomAlphaOfLength(4), randomAlphaOfLength(4), randomAlphaOfLength(4),
|
||||||
|
randomFrom(FollowInfoAction.Response.Status.values()), followParameters));
|
||||||
|
}
|
||||||
|
return new FollowInfoAction.Response(infos);
|
||||||
|
}
|
||||||
|
|
||||||
|
static FollowParameters randomFollowParameters() {
|
||||||
|
FollowParameters followParameters = new FollowParameters();
|
||||||
|
followParameters.setMaxOutstandingReadRequests(randomIntBetween(0, Integer.MAX_VALUE));
|
||||||
|
followParameters.setMaxOutstandingWriteRequests(randomIntBetween(0, Integer.MAX_VALUE));
|
||||||
|
followParameters.setMaxReadRequestOperationCount(randomIntBetween(0, Integer.MAX_VALUE));
|
||||||
|
followParameters.setMaxWriteRequestOperationCount(randomIntBetween(0, Integer.MAX_VALUE));
|
||||||
|
followParameters.setMaxReadRequestSize(new ByteSizeValue(randomNonNegativeLong()));
|
||||||
|
followParameters.setMaxWriteRequestSize(new ByteSizeValue(randomNonNegativeLong()));
|
||||||
|
followParameters.setMaxWriteBufferCount(randomIntBetween(0, Integer.MAX_VALUE));
|
||||||
|
followParameters.setMaxWriteBufferSize(new ByteSizeValue(randomNonNegativeLong()));
|
||||||
|
followParameters.setMaxRetryDelay(new TimeValue(randomNonNegativeLong()));
|
||||||
|
followParameters.setReadPollTimeout(new TimeValue(randomNonNegativeLong()));
|
||||||
|
return followParameters;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected FollowInfoResponse doParseToClientInstance(XContentParser parser) throws IOException {
|
||||||
|
return FollowInfoResponse.fromXContent(parser);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void assertInstances(FollowInfoAction.Response serverTestInstance, FollowInfoResponse clientInstance) {
|
||||||
|
assertThat(serverTestInstance.getFollowInfos().size(), equalTo(clientInstance.getInfos().size()));
|
||||||
|
for (int i = 0; i < serverTestInstance.getFollowInfos().size(); i++) {
|
||||||
|
FollowInfoAction.Response.FollowerInfo serverFollowInfo = serverTestInstance.getFollowInfos().get(i);
|
||||||
|
FollowInfoResponse.FollowerInfo clientFollowerInfo = clientInstance.getInfos().get(i);
|
||||||
|
|
||||||
|
assertThat(serverFollowInfo.getRemoteCluster(), equalTo(clientFollowerInfo.getRemoteCluster()));
|
||||||
|
assertThat(serverFollowInfo.getLeaderIndex(), equalTo(clientFollowerInfo.getLeaderIndex()));
|
||||||
|
assertThat(serverFollowInfo.getFollowerIndex(), equalTo(clientFollowerInfo.getFollowerIndex()));
|
||||||
|
assertThat(serverFollowInfo.getStatus().toString().toLowerCase(Locale.ROOT),
|
||||||
|
equalTo(clientFollowerInfo.getStatus().getName().toLowerCase(Locale.ROOT)));
|
||||||
|
|
||||||
|
FollowParameters serverParams = serverFollowInfo.getParameters();
|
||||||
|
FollowConfig clientParams = clientFollowerInfo.getParameters();
|
||||||
|
if (serverParams != null) {
|
||||||
|
assertThat(serverParams.getMaxReadRequestOperationCount(), equalTo(clientParams.getMaxReadRequestOperationCount()));
|
||||||
|
assertThat(serverParams.getMaxWriteRequestOperationCount(), equalTo(clientParams.getMaxWriteRequestOperationCount()));
|
||||||
|
assertThat(serverParams.getMaxOutstandingReadRequests(), equalTo(clientParams.getMaxOutstandingReadRequests()));
|
||||||
|
assertThat(serverParams.getMaxOutstandingWriteRequests(), equalTo(clientParams.getMaxOutstandingWriteRequests()));
|
||||||
|
assertThat(serverParams.getMaxReadRequestSize(), equalTo(clientParams.getMaxReadRequestSize()));
|
||||||
|
assertThat(serverParams.getMaxWriteRequestSize(), equalTo(clientParams.getMaxWriteRequestSize()));
|
||||||
|
assertThat(serverParams.getMaxWriteBufferCount(), equalTo(clientParams.getMaxWriteBufferCount()));
|
||||||
|
assertThat(serverParams.getMaxWriteBufferSize(), equalTo(clientParams.getMaxWriteBufferSize()));
|
||||||
|
assertThat(serverParams.getMaxRetryDelay(), equalTo(clientParams.getMaxRetryDelay()));
|
||||||
|
assertThat(serverParams.getReadPollTimeout(), equalTo(clientParams.getReadPollTimeout()));
|
||||||
|
} else {
|
||||||
|
assertThat(clientParams, nullValue());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return new FollowInfoResponse(infos);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,100 +20,101 @@
|
||||||
package org.elasticsearch.client.ccr;
|
package org.elasticsearch.client.ccr;
|
||||||
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
|
import org.elasticsearch.client.AbstractResponseTestCase;
|
||||||
import org.elasticsearch.client.ccr.IndicesFollowStats.ShardFollowStats;
|
import org.elasticsearch.client.ccr.IndicesFollowStats.ShardFollowStats;
|
||||||
import org.elasticsearch.common.collect.Tuple;
|
import org.elasticsearch.common.collect.Tuple;
|
||||||
import org.elasticsearch.common.unit.ByteSizeUnit;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.unit.ByteSizeValue;
|
import org.elasticsearch.xpack.core.ccr.ShardFollowNodeTaskStatus;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.xpack.core.ccr.action.FollowStatsAction;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
|
||||||
import org.elasticsearch.test.ESTestCase;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.TreeMap;
|
||||||
|
|
||||||
import static org.elasticsearch.client.ccr.CcrStatsResponseTests.randomIndicesFollowStats;
|
import static org.elasticsearch.client.ccr.CcrStatsResponseTests.createStatsResponse;
|
||||||
import static org.elasticsearch.test.AbstractXContentTestCase.xContentTester;
|
|
||||||
import static org.hamcrest.Matchers.anyOf;
|
import static org.hamcrest.Matchers.anyOf;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.hamcrest.Matchers.instanceOf;
|
import static org.hamcrest.Matchers.instanceOf;
|
||||||
|
|
||||||
public class FollowStatsResponseTests extends ESTestCase {
|
public class FollowStatsResponseTests extends AbstractResponseTestCase<FollowStatsAction.StatsResponses, FollowStatsResponse> {
|
||||||
|
|
||||||
public void testFromXContent() throws IOException {
|
@Override
|
||||||
xContentTester(this::createParser,
|
protected FollowStatsAction.StatsResponses createServerTestInstance() {
|
||||||
FollowStatsResponseTests::createTestInstance,
|
return createStatsResponse();
|
||||||
FollowStatsResponseTests::toXContent,
|
|
||||||
FollowStatsResponse::fromXContent)
|
|
||||||
.supportsUnknownFields(true)
|
|
||||||
.assertEqualsConsumer(FollowStatsResponseTests::assertEqualInstances)
|
|
||||||
.assertToXContentEquivalence(false)
|
|
||||||
.test();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Needed, because exceptions in IndicesFollowStats cannot be compared
|
@Override
|
||||||
private static void assertEqualInstances(FollowStatsResponse expectedInstance, FollowStatsResponse newInstance) {
|
protected FollowStatsResponse doParseToClientInstance(XContentParser parser) throws IOException {
|
||||||
assertNotSame(expectedInstance, newInstance);
|
return FollowStatsResponse.fromXContent(parser);
|
||||||
{
|
}
|
||||||
IndicesFollowStats newIndicesFollowStats = newInstance.getIndicesFollowStats();
|
|
||||||
IndicesFollowStats expectedIndicesFollowStats = expectedInstance.getIndicesFollowStats();
|
@Override
|
||||||
|
protected void assertInstances(FollowStatsAction.StatsResponses serverTestInstance, FollowStatsResponse clientInstance) {
|
||||||
|
IndicesFollowStats newIndicesFollowStats = clientInstance.getIndicesFollowStats();
|
||||||
|
|
||||||
|
// sort by index name, then shard ID
|
||||||
|
final Map<String, Map<Integer, FollowStatsAction.StatsResponse>> expectedIndicesFollowStats = new TreeMap<>();
|
||||||
|
for (final FollowStatsAction.StatsResponse statsResponse : serverTestInstance.getStatsResponses()) {
|
||||||
|
expectedIndicesFollowStats.computeIfAbsent(
|
||||||
|
statsResponse.status().followerIndex(),
|
||||||
|
k -> new TreeMap<>()).put(statsResponse.status().getShardId(), statsResponse);
|
||||||
|
}
|
||||||
assertThat(newIndicesFollowStats.getShardFollowStats().size(),
|
assertThat(newIndicesFollowStats.getShardFollowStats().size(),
|
||||||
equalTo(expectedIndicesFollowStats.getShardFollowStats().size()));
|
equalTo(expectedIndicesFollowStats.size()));
|
||||||
assertThat(newIndicesFollowStats.getShardFollowStats().keySet(),
|
assertThat(newIndicesFollowStats.getShardFollowStats().keySet(),
|
||||||
equalTo(expectedIndicesFollowStats.getShardFollowStats().keySet()));
|
equalTo(expectedIndicesFollowStats.keySet()));
|
||||||
for (Map.Entry<String, List<ShardFollowStats>> indexEntry : newIndicesFollowStats.getShardFollowStats().entrySet()) {
|
for (Map.Entry<String, List<ShardFollowStats>> indexEntry : newIndicesFollowStats.getShardFollowStats().entrySet()) {
|
||||||
List<ShardFollowStats> newStats = indexEntry.getValue();
|
List<ShardFollowStats> newStats = indexEntry.getValue();
|
||||||
List<ShardFollowStats> expectedStats = expectedIndicesFollowStats.getShardFollowStats(indexEntry.getKey());
|
Map<Integer, FollowStatsAction.StatsResponse> expectedStats = expectedIndicesFollowStats.get(indexEntry.getKey());
|
||||||
assertThat(newStats.size(), equalTo(expectedStats.size()));
|
assertThat(newStats.size(), equalTo(expectedStats.size()));
|
||||||
for (int i = 0; i < newStats.size(); i++) {
|
for (int i = 0; i < newStats.size(); i++) {
|
||||||
ShardFollowStats actualShardFollowStats = newStats.get(i);
|
ShardFollowStats actualShardFollowStats = newStats.get(i);
|
||||||
ShardFollowStats expectedShardFollowStats = expectedStats.get(i);
|
ShardFollowNodeTaskStatus expectedShardFollowStats = expectedStats.get(actualShardFollowStats.getShardId()).status();
|
||||||
|
|
||||||
assertThat(actualShardFollowStats.getRemoteCluster(), equalTo(expectedShardFollowStats.getRemoteCluster()));
|
assertThat(actualShardFollowStats.getRemoteCluster(), equalTo(expectedShardFollowStats.getRemoteCluster()));
|
||||||
assertThat(actualShardFollowStats.getLeaderIndex(), equalTo(expectedShardFollowStats.getLeaderIndex()));
|
assertThat(actualShardFollowStats.getLeaderIndex(), equalTo(expectedShardFollowStats.leaderIndex()));
|
||||||
assertThat(actualShardFollowStats.getFollowerIndex(), equalTo(expectedShardFollowStats.getFollowerIndex()));
|
assertThat(actualShardFollowStats.getFollowerIndex(), equalTo(expectedShardFollowStats.followerIndex()));
|
||||||
assertThat(actualShardFollowStats.getShardId(), equalTo(expectedShardFollowStats.getShardId()));
|
assertThat(actualShardFollowStats.getShardId(), equalTo(expectedShardFollowStats.getShardId()));
|
||||||
assertThat(actualShardFollowStats.getLeaderGlobalCheckpoint(),
|
assertThat(actualShardFollowStats.getLeaderGlobalCheckpoint(),
|
||||||
equalTo(expectedShardFollowStats.getLeaderGlobalCheckpoint()));
|
equalTo(expectedShardFollowStats.leaderGlobalCheckpoint()));
|
||||||
assertThat(actualShardFollowStats.getLeaderMaxSeqNo(), equalTo(expectedShardFollowStats.getLeaderMaxSeqNo()));
|
assertThat(actualShardFollowStats.getLeaderMaxSeqNo(), equalTo(expectedShardFollowStats.leaderMaxSeqNo()));
|
||||||
assertThat(actualShardFollowStats.getFollowerGlobalCheckpoint(),
|
assertThat(actualShardFollowStats.getFollowerGlobalCheckpoint(),
|
||||||
equalTo(expectedShardFollowStats.getFollowerGlobalCheckpoint()));
|
equalTo(expectedShardFollowStats.followerGlobalCheckpoint()));
|
||||||
assertThat(actualShardFollowStats.getLastRequestedSeqNo(), equalTo(expectedShardFollowStats.getLastRequestedSeqNo()));
|
assertThat(actualShardFollowStats.getLastRequestedSeqNo(), equalTo(expectedShardFollowStats.lastRequestedSeqNo()));
|
||||||
assertThat(actualShardFollowStats.getOutstandingReadRequests(),
|
assertThat(actualShardFollowStats.getOutstandingReadRequests(),
|
||||||
equalTo(expectedShardFollowStats.getOutstandingReadRequests()));
|
equalTo(expectedShardFollowStats.outstandingReadRequests()));
|
||||||
assertThat(actualShardFollowStats.getOutstandingWriteRequests(),
|
assertThat(actualShardFollowStats.getOutstandingWriteRequests(),
|
||||||
equalTo(expectedShardFollowStats.getOutstandingWriteRequests()));
|
equalTo(expectedShardFollowStats.outstandingWriteRequests()));
|
||||||
assertThat(actualShardFollowStats.getWriteBufferOperationCount(),
|
assertThat(actualShardFollowStats.getWriteBufferOperationCount(),
|
||||||
equalTo(expectedShardFollowStats.getWriteBufferOperationCount()));
|
equalTo(expectedShardFollowStats.writeBufferOperationCount()));
|
||||||
assertThat(actualShardFollowStats.getFollowerMappingVersion(),
|
assertThat(actualShardFollowStats.getFollowerMappingVersion(),
|
||||||
equalTo(expectedShardFollowStats.getFollowerMappingVersion()));
|
equalTo(expectedShardFollowStats.followerMappingVersion()));
|
||||||
assertThat(actualShardFollowStats.getFollowerSettingsVersion(),
|
assertThat(actualShardFollowStats.getFollowerSettingsVersion(),
|
||||||
equalTo(expectedShardFollowStats.getFollowerSettingsVersion()));
|
equalTo(expectedShardFollowStats.followerSettingsVersion()));
|
||||||
assertThat(actualShardFollowStats.getTotalReadTimeMillis(),
|
assertThat(actualShardFollowStats.getTotalReadTimeMillis(),
|
||||||
equalTo(expectedShardFollowStats.getTotalReadTimeMillis()));
|
equalTo(expectedShardFollowStats.totalReadTimeMillis()));
|
||||||
assertThat(actualShardFollowStats.getSuccessfulReadRequests(),
|
assertThat(actualShardFollowStats.getSuccessfulReadRequests(),
|
||||||
equalTo(expectedShardFollowStats.getSuccessfulReadRequests()));
|
equalTo(expectedShardFollowStats.successfulReadRequests()));
|
||||||
assertThat(actualShardFollowStats.getFailedReadRequests(), equalTo(expectedShardFollowStats.getFailedReadRequests()));
|
assertThat(actualShardFollowStats.getFailedReadRequests(), equalTo(expectedShardFollowStats.failedReadRequests()));
|
||||||
assertThat(actualShardFollowStats.getOperationsReads(), equalTo(expectedShardFollowStats.getOperationsReads()));
|
assertThat(actualShardFollowStats.getOperationsReads(), equalTo(expectedShardFollowStats.operationsReads()));
|
||||||
assertThat(actualShardFollowStats.getBytesRead(), equalTo(expectedShardFollowStats.getBytesRead()));
|
assertThat(actualShardFollowStats.getBytesRead(), equalTo(expectedShardFollowStats.bytesRead()));
|
||||||
assertThat(actualShardFollowStats.getTotalWriteTimeMillis(),
|
assertThat(actualShardFollowStats.getTotalWriteTimeMillis(),
|
||||||
equalTo(expectedShardFollowStats.getTotalWriteTimeMillis()));
|
equalTo(expectedShardFollowStats.totalWriteTimeMillis()));
|
||||||
assertThat(actualShardFollowStats.getSuccessfulWriteRequests(),
|
assertThat(actualShardFollowStats.getSuccessfulWriteRequests(),
|
||||||
equalTo(expectedShardFollowStats.getSuccessfulWriteRequests()));
|
equalTo(expectedShardFollowStats.successfulWriteRequests()));
|
||||||
assertThat(actualShardFollowStats.getFailedWriteRequests(),
|
assertThat(actualShardFollowStats.getFailedWriteRequests(),
|
||||||
equalTo(expectedShardFollowStats.getFailedWriteRequests()));
|
equalTo(expectedShardFollowStats.failedWriteRequests()));
|
||||||
assertThat(actualShardFollowStats.getOperationWritten(), equalTo(expectedShardFollowStats.getOperationWritten()));
|
assertThat(actualShardFollowStats.getOperationWritten(), equalTo(expectedShardFollowStats.operationWritten()));
|
||||||
assertThat(actualShardFollowStats.getReadExceptions().size(),
|
assertThat(actualShardFollowStats.getReadExceptions().size(),
|
||||||
equalTo(expectedShardFollowStats.getReadExceptions().size()));
|
equalTo(expectedShardFollowStats.readExceptions().size()));
|
||||||
assertThat(actualShardFollowStats.getReadExceptions().keySet(),
|
assertThat(actualShardFollowStats.getReadExceptions().keySet(),
|
||||||
equalTo(expectedShardFollowStats.getReadExceptions().keySet()));
|
equalTo(expectedShardFollowStats.readExceptions().keySet()));
|
||||||
for (final Map.Entry<Long, Tuple<Integer, ElasticsearchException>> entry :
|
for (final Map.Entry<Long, Tuple<Integer, ElasticsearchException>> entry :
|
||||||
actualShardFollowStats.getReadExceptions().entrySet()) {
|
actualShardFollowStats.getReadExceptions().entrySet()) {
|
||||||
final Tuple<Integer, ElasticsearchException> expectedTuple =
|
final Tuple<Integer, ElasticsearchException> expectedTuple =
|
||||||
expectedShardFollowStats.getReadExceptions().get(entry.getKey());
|
expectedShardFollowStats.readExceptions().get(entry.getKey());
|
||||||
assertThat(entry.getValue().v1(), equalTo(expectedTuple.v1()));
|
assertThat(entry.getValue().v1(), equalTo(expectedTuple.v1()));
|
||||||
// x-content loses the exception
|
// x-content loses the exception
|
||||||
final ElasticsearchException expected = expectedTuple.v2();
|
final ElasticsearchException expected = expectedTuple.v2();
|
||||||
|
@ -125,129 +126,9 @@ public class FollowStatsResponseTests extends ESTestCase {
|
||||||
assertThat(entry.getValue().v2().getCause().getMessage(), containsString(expected.getCause().getMessage()));
|
assertThat(entry.getValue().v2().getCause().getMessage(), containsString(expected.getCause().getMessage()));
|
||||||
}
|
}
|
||||||
assertThat(actualShardFollowStats.getTimeSinceLastReadMillis(),
|
assertThat(actualShardFollowStats.getTimeSinceLastReadMillis(),
|
||||||
equalTo(expectedShardFollowStats.getTimeSinceLastReadMillis()));
|
equalTo(expectedShardFollowStats.timeSinceLastReadMillis()));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void toXContent(FollowStatsResponse response, XContentBuilder builder) throws IOException {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.startArray(IndicesFollowStats.INDICES_FIELD.getPreferredName());
|
|
||||||
for (Map.Entry<String, List<ShardFollowStats>> indexEntry :
|
|
||||||
response.getIndicesFollowStats().getShardFollowStats().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(IndicesFollowStats.INDEX_FIELD.getPreferredName(), indexEntry.getKey());
|
|
||||||
builder.startArray(IndicesFollowStats.SHARDS_FIELD.getPreferredName());
|
|
||||||
{
|
|
||||||
for (ShardFollowStats stats : indexEntry.getValue()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(ShardFollowStats.LEADER_CLUSTER.getPreferredName(), stats.getRemoteCluster());
|
|
||||||
builder.field(ShardFollowStats.LEADER_INDEX.getPreferredName(), stats.getLeaderIndex());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_INDEX.getPreferredName(), stats.getFollowerIndex());
|
|
||||||
builder.field(ShardFollowStats.SHARD_ID.getPreferredName(), stats.getShardId());
|
|
||||||
builder.field(ShardFollowStats.LEADER_GLOBAL_CHECKPOINT_FIELD.getPreferredName(),
|
|
||||||
stats.getLeaderGlobalCheckpoint());
|
|
||||||
builder.field(ShardFollowStats.LEADER_MAX_SEQ_NO_FIELD.getPreferredName(), stats.getLeaderMaxSeqNo());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_GLOBAL_CHECKPOINT_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerGlobalCheckpoint());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_MAX_SEQ_NO_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerMaxSeqNo());
|
|
||||||
builder.field(ShardFollowStats.LAST_REQUESTED_SEQ_NO_FIELD.getPreferredName(),
|
|
||||||
stats.getLastRequestedSeqNo());
|
|
||||||
builder.field(ShardFollowStats.OUTSTANDING_READ_REQUESTS.getPreferredName(),
|
|
||||||
stats.getOutstandingReadRequests());
|
|
||||||
builder.field(ShardFollowStats.OUTSTANDING_WRITE_REQUESTS.getPreferredName(),
|
|
||||||
stats.getOutstandingWriteRequests());
|
|
||||||
builder.field(ShardFollowStats.WRITE_BUFFER_OPERATION_COUNT_FIELD.getPreferredName(),
|
|
||||||
stats.getWriteBufferOperationCount());
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.WRITE_BUFFER_SIZE_IN_BYTES_FIELD.getPreferredName(),
|
|
||||||
"write_buffer_size",
|
|
||||||
new ByteSizeValue(stats.getWriteBufferSizeInBytes()));
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_MAPPING_VERSION_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerMappingVersion());
|
|
||||||
builder.field(ShardFollowStats.FOLLOWER_SETTINGS_VERSION_FIELD.getPreferredName(),
|
|
||||||
stats.getFollowerSettingsVersion());
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TOTAL_READ_TIME_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"total_read_time",
|
|
||||||
new TimeValue(stats.getTotalReadTimeMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TOTAL_READ_REMOTE_EXEC_TIME_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"total_read_remote_exec_time",
|
|
||||||
new TimeValue(stats.getTotalReadRemoteExecTimeMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
builder.field(ShardFollowStats.SUCCESSFUL_READ_REQUESTS_FIELD.getPreferredName(),
|
|
||||||
stats.getSuccessfulReadRequests());
|
|
||||||
builder.field(ShardFollowStats.FAILED_READ_REQUESTS_FIELD.getPreferredName(),
|
|
||||||
stats.getFailedReadRequests());
|
|
||||||
builder.field(ShardFollowStats.OPERATIONS_READ_FIELD.getPreferredName(), stats.getOperationsReads());
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.BYTES_READ.getPreferredName(),
|
|
||||||
"total_read",
|
|
||||||
new ByteSizeValue(stats.getBytesRead(), ByteSizeUnit.BYTES));
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TOTAL_WRITE_TIME_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"total_write_time",
|
|
||||||
new TimeValue(stats.getTotalWriteTimeMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
builder.field(ShardFollowStats.SUCCESSFUL_WRITE_REQUESTS_FIELD.getPreferredName(),
|
|
||||||
stats.getSuccessfulWriteRequests());
|
|
||||||
builder.field(ShardFollowStats.FAILED_WRITE_REQUEST_FIELD.getPreferredName(),
|
|
||||||
stats.getFailedWriteRequests());
|
|
||||||
builder.field(ShardFollowStats.OPERATIONS_WRITTEN.getPreferredName(), stats.getOperationWritten());
|
|
||||||
builder.startArray(ShardFollowStats.READ_EXCEPTIONS.getPreferredName());
|
|
||||||
{
|
|
||||||
for (final Map.Entry<Long, Tuple<Integer, ElasticsearchException>> entry :
|
|
||||||
stats.getReadExceptions().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(ShardFollowStats.READ_EXCEPTIONS_ENTRY_FROM_SEQ_NO.getPreferredName(),
|
|
||||||
entry.getKey());
|
|
||||||
builder.field(ShardFollowStats.READ_EXCEPTIONS_RETRIES.getPreferredName(),
|
|
||||||
entry.getValue().v1());
|
|
||||||
builder.field(ShardFollowStats.READ_EXCEPTIONS_ENTRY_EXCEPTION.getPreferredName());
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
ElasticsearchException.generateThrowableXContent(builder, ToXContent.EMPTY_PARAMS,
|
|
||||||
entry.getValue().v2());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
builder.humanReadableField(
|
|
||||||
ShardFollowStats.TIME_SINCE_LAST_READ_MILLIS_FIELD.getPreferredName(),
|
|
||||||
"time_since_last_read",
|
|
||||||
new TimeValue(stats.getTimeSinceLastReadMillis(), TimeUnit.MILLISECONDS));
|
|
||||||
if (stats.getFatalException() != null) {
|
|
||||||
builder.field(ShardFollowStats.FATAL_EXCEPTION.getPreferredName());
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
ElasticsearchException.generateThrowableXContent(builder, ToXContent.EMPTY_PARAMS,
|
|
||||||
stats.getFatalException());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
builder.endArray();
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static FollowStatsResponse createTestInstance() {
|
|
||||||
return new FollowStatsResponse(randomIndicesFollowStats());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,99 +19,111 @@
|
||||||
|
|
||||||
package org.elasticsearch.client.ccr;
|
package org.elasticsearch.client.ccr;
|
||||||
|
|
||||||
|
import org.elasticsearch.client.AbstractResponseTestCase;
|
||||||
import org.elasticsearch.common.unit.ByteSizeValue;
|
import org.elasticsearch.common.unit.ByteSizeValue;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.common.xcontent.ToXContent;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.xpack.core.ccr.AutoFollowMetadata;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.xpack.core.ccr.action.GetAutoFollowPatternAction;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NavigableMap;
|
import java.util.NavigableMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
|
|
||||||
import static org.elasticsearch.client.ccr.PutAutoFollowPatternRequest.FOLLOW_PATTERN_FIELD;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
import static org.elasticsearch.client.ccr.PutAutoFollowPatternRequest.LEADER_PATTERNS_FIELD;
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
import static org.elasticsearch.client.ccr.PutFollowRequest.REMOTE_CLUSTER_FIELD;
|
|
||||||
import static org.elasticsearch.test.AbstractXContentTestCase.xContentTester;
|
|
||||||
|
|
||||||
public class GetAutoFollowPatternResponseTests extends ESTestCase {
|
public class GetAutoFollowPatternResponseTests extends AbstractResponseTestCase<
|
||||||
|
GetAutoFollowPatternAction.Response,
|
||||||
|
GetAutoFollowPatternResponse> {
|
||||||
|
|
||||||
public void testFromXContent() throws IOException {
|
@Override
|
||||||
xContentTester(this::createParser,
|
protected GetAutoFollowPatternAction.Response createServerTestInstance() {
|
||||||
this::createTestInstance,
|
|
||||||
GetAutoFollowPatternResponseTests::toXContent,
|
|
||||||
GetAutoFollowPatternResponse::fromXContent)
|
|
||||||
.supportsUnknownFields(true)
|
|
||||||
.test();
|
|
||||||
}
|
|
||||||
|
|
||||||
private GetAutoFollowPatternResponse createTestInstance() {
|
|
||||||
int numPatterns = randomIntBetween(0, 16);
|
int numPatterns = randomIntBetween(0, 16);
|
||||||
NavigableMap<String, GetAutoFollowPatternResponse.Pattern> patterns = new TreeMap<>();
|
NavigableMap<String, AutoFollowMetadata.AutoFollowPattern> patterns = new TreeMap<>();
|
||||||
for (int i = 0; i < numPatterns; i++) {
|
for (int i = 0; i < numPatterns; i++) {
|
||||||
GetAutoFollowPatternResponse.Pattern pattern = new GetAutoFollowPatternResponse.Pattern(
|
String remoteCluster = randomAlphaOfLength(4);
|
||||||
randomAlphaOfLength(4), Collections.singletonList(randomAlphaOfLength(4)), randomAlphaOfLength(4));
|
List<String> leaderIndexPatters = Collections.singletonList(randomAlphaOfLength(4));
|
||||||
|
String followIndexNamePattern = randomAlphaOfLength(4);
|
||||||
|
|
||||||
|
Integer maxOutstandingReadRequests = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxOutstandingReadRequests(randomIntBetween(0, Integer.MAX_VALUE));
|
maxOutstandingReadRequests = randomIntBetween(0, Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
Integer maxOutstandingWriteRequests = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxOutstandingWriteRequests(randomIntBetween(0, Integer.MAX_VALUE));
|
maxOutstandingWriteRequests = randomIntBetween(0, Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
Integer maxReadRequestOperationCount = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxReadRequestOperationCount(randomIntBetween(0, Integer.MAX_VALUE));
|
maxReadRequestOperationCount = randomIntBetween(0, Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
ByteSizeValue maxReadRequestSize = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxReadRequestSize(new ByteSizeValue(randomNonNegativeLong()));
|
maxReadRequestSize = new ByteSizeValue(randomNonNegativeLong());
|
||||||
}
|
}
|
||||||
|
Integer maxWriteBufferCount = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxWriteBufferCount(randomIntBetween(0, Integer.MAX_VALUE));
|
maxWriteBufferCount = randomIntBetween(0, Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
ByteSizeValue maxWriteBufferSize = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxWriteBufferSize(new ByteSizeValue(randomNonNegativeLong()));
|
maxWriteBufferSize = new ByteSizeValue(randomNonNegativeLong());
|
||||||
}
|
}
|
||||||
|
Integer maxWriteRequestOperationCount = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxWriteRequestOperationCount(randomIntBetween(0, Integer.MAX_VALUE));
|
maxWriteRequestOperationCount = randomIntBetween(0, Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
ByteSizeValue maxWriteRequestSize = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxWriteRequestSize(new ByteSizeValue(randomNonNegativeLong()));
|
maxWriteRequestSize = new ByteSizeValue(randomNonNegativeLong());
|
||||||
}
|
}
|
||||||
|
TimeValue maxRetryDelay = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setMaxRetryDelay(new TimeValue(randomNonNegativeLong()));
|
maxRetryDelay = new TimeValue(randomNonNegativeLong());
|
||||||
}
|
}
|
||||||
|
TimeValue readPollTimeout = null;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
pattern.setReadPollTimeout(new TimeValue(randomNonNegativeLong()));
|
readPollTimeout = new TimeValue(randomNonNegativeLong());
|
||||||
}
|
}
|
||||||
patterns.put(randomAlphaOfLength(4), pattern);
|
patterns.put(randomAlphaOfLength(4), new AutoFollowMetadata.AutoFollowPattern(remoteCluster, leaderIndexPatters,
|
||||||
|
followIndexNamePattern, maxReadRequestOperationCount, maxWriteRequestOperationCount, maxOutstandingReadRequests,
|
||||||
|
maxOutstandingWriteRequests, maxReadRequestSize, maxWriteRequestSize, maxWriteBufferCount, maxWriteBufferSize,
|
||||||
|
maxRetryDelay, readPollTimeout));
|
||||||
}
|
}
|
||||||
return new GetAutoFollowPatternResponse(patterns);
|
return new GetAutoFollowPatternAction.Response(patterns);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void toXContent(GetAutoFollowPatternResponse response, XContentBuilder builder) throws IOException {
|
@Override
|
||||||
builder.startObject();
|
protected GetAutoFollowPatternResponse doParseToClientInstance(XContentParser parser) throws IOException {
|
||||||
{
|
return GetAutoFollowPatternResponse.fromXContent(parser);
|
||||||
builder.startArray(GetAutoFollowPatternResponse.PATTERNS_FIELD.getPreferredName());
|
|
||||||
for (Map.Entry<String, GetAutoFollowPatternResponse.Pattern> entry : response.getPatterns().entrySet()) {
|
|
||||||
builder.startObject();
|
|
||||||
{
|
|
||||||
builder.field(GetAutoFollowPatternResponse.NAME_FIELD.getPreferredName(), entry.getKey());
|
|
||||||
builder.startObject(GetAutoFollowPatternResponse.PATTERN_FIELD.getPreferredName());
|
|
||||||
{
|
|
||||||
GetAutoFollowPatternResponse.Pattern pattern = entry.getValue();
|
|
||||||
builder.field(REMOTE_CLUSTER_FIELD.getPreferredName(), pattern.getRemoteCluster());
|
|
||||||
builder.field(LEADER_PATTERNS_FIELD.getPreferredName(), pattern.getLeaderIndexPatterns());
|
|
||||||
if (pattern.getFollowIndexNamePattern()!= null) {
|
|
||||||
builder.field(FOLLOW_PATTERN_FIELD.getPreferredName(), pattern.getFollowIndexNamePattern());
|
|
||||||
}
|
}
|
||||||
entry.getValue().toXContentFragment(builder, ToXContent.EMPTY_PARAMS);
|
|
||||||
}
|
@Override
|
||||||
builder.endObject();
|
protected void assertInstances(GetAutoFollowPatternAction.Response serverTestInstance, GetAutoFollowPatternResponse clientInstance) {
|
||||||
}
|
assertThat(serverTestInstance.getAutoFollowPatterns().size(), equalTo(clientInstance.getPatterns().size()));
|
||||||
builder.endObject();
|
for (Map.Entry<String, AutoFollowMetadata.AutoFollowPattern> entry : serverTestInstance.getAutoFollowPatterns().entrySet()) {
|
||||||
}
|
AutoFollowMetadata.AutoFollowPattern serverPattern = entry.getValue();
|
||||||
builder.endArray();
|
GetAutoFollowPatternResponse.Pattern clientPattern = clientInstance.getPatterns().get(entry.getKey());
|
||||||
}
|
assertThat(clientPattern, notNullValue());
|
||||||
builder.endObject();
|
|
||||||
|
assertThat(serverPattern.getRemoteCluster(), equalTo(clientPattern.getRemoteCluster()));
|
||||||
|
assertThat(serverPattern.getLeaderIndexPatterns(), equalTo(clientPattern.getLeaderIndexPatterns()));
|
||||||
|
assertThat(serverPattern.getFollowIndexPattern(), equalTo(clientPattern.getFollowIndexNamePattern()));
|
||||||
|
assertThat(serverPattern.getMaxOutstandingReadRequests(), equalTo(clientPattern.getMaxOutstandingReadRequests()));
|
||||||
|
assertThat(serverPattern.getMaxOutstandingWriteRequests(), equalTo(clientPattern.getMaxOutstandingWriteRequests()));
|
||||||
|
assertThat(serverPattern.getMaxReadRequestOperationCount(), equalTo(clientPattern.getMaxReadRequestOperationCount()));
|
||||||
|
assertThat(serverPattern.getMaxWriteRequestOperationCount(), equalTo(clientPattern.getMaxWriteRequestOperationCount()));
|
||||||
|
assertThat(serverPattern.getMaxReadRequestSize(), equalTo(clientPattern.getMaxReadRequestSize()));
|
||||||
|
assertThat(serverPattern.getMaxWriteRequestSize(), equalTo(clientPattern.getMaxWriteRequestSize()));
|
||||||
|
assertThat(serverPattern.getMaxWriteBufferCount(), equalTo(clientPattern.getMaxWriteBufferCount()));
|
||||||
|
assertThat(serverPattern.getMaxWriteBufferSize(), equalTo(clientPattern.getMaxWriteBufferSize()));
|
||||||
|
assertThat(serverPattern.getMaxRetryDelay(), equalTo(clientPattern.getMaxRetryDelay()));
|
||||||
|
assertThat(serverPattern.getReadPollTimeout(), equalTo(clientPattern.getReadPollTimeout()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -19,35 +19,30 @@
|
||||||
|
|
||||||
package org.elasticsearch.client.ccr;
|
package org.elasticsearch.client.ccr;
|
||||||
|
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.client.AbstractResponseTestCase;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.common.xcontent.XContentParser;
|
||||||
|
import org.elasticsearch.xpack.core.ccr.action.PutFollowAction;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import static org.elasticsearch.test.AbstractXContentTestCase.xContentTester;
|
import static org.hamcrest.Matchers.is;
|
||||||
|
|
||||||
public class PutFollowResponseTests extends ESTestCase {
|
public class PutFollowResponseTests extends AbstractResponseTestCase<PutFollowAction.Response, PutFollowResponse> {
|
||||||
|
|
||||||
public void testFromXContent() throws IOException {
|
@Override
|
||||||
xContentTester(this::createParser,
|
protected PutFollowAction.Response createServerTestInstance() {
|
||||||
this::createTestInstance,
|
return new PutFollowAction.Response(randomBoolean(), randomBoolean(), randomBoolean());
|
||||||
PutFollowResponseTests::toXContent,
|
|
||||||
PutFollowResponse::fromXContent)
|
|
||||||
.supportsUnknownFields(true)
|
|
||||||
.test();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private PutFollowResponse createTestInstance() {
|
@Override
|
||||||
return new PutFollowResponse(randomBoolean(), randomBoolean(), randomBoolean());
|
protected PutFollowResponse doParseToClientInstance(XContentParser parser) throws IOException {
|
||||||
|
return PutFollowResponse.fromXContent(parser);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void toXContent(PutFollowResponse response, XContentBuilder builder) throws IOException {
|
@Override
|
||||||
builder.startObject();
|
protected void assertInstances(PutFollowAction.Response serverTestInstance, PutFollowResponse clientInstance) {
|
||||||
{
|
assertThat(serverTestInstance.isFollowIndexCreated(), is(clientInstance.isFollowIndexCreated()));
|
||||||
builder.field(PutFollowResponse.FOLLOW_INDEX_CREATED.getPreferredName(), response.isFollowIndexCreated());
|
assertThat(serverTestInstance.isFollowIndexShardsAcked(), is(clientInstance.isFollowIndexShardsAcked()));
|
||||||
builder.field(PutFollowResponse.FOLLOW_INDEX_SHARDS_ACKED.getPreferredName(), response.isFollowIndexShardsAcked());
|
assertThat(serverTestInstance.isIndexFollowingStarted(), is(clientInstance.isIndexFollowingStarted()));
|
||||||
builder.field(PutFollowResponse.INDEX_FOLLOWING_STARTED.getPreferredName(), response.isIndexFollowingStarted());
|
|
||||||
}
|
|
||||||
builder.endObject();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue