Clear send behavior rule in CloseWhileRelocatingShardsIT (#38159)
The current CloseWhileRelocatingShardsIT test adds some "send behavior" rule to a target node's mocked transport service in order to detect when shard relocating are started. These rules are never cleared and prevent the test to complete normally after the rebalance is re-enabled again. This commit changes the test so that rules are cleared and most verifications are done before the rebalance is reenabled again. Closes #38090
This commit is contained in:
parent
ce469cfda5
commit
029e4b6278
|
@ -119,6 +119,8 @@ public class CloseWhileRelocatingShardsIT extends ESIntegTestCase {
|
|||
|
||||
final String targetNode = internalCluster().startDataOnlyNode();
|
||||
ensureClusterSizeConsistency(); // wait for the master to finish processing join.
|
||||
final MockTransportService targetTransportService =
|
||||
(MockTransportService) internalCluster().getInstance(TransportService.class, targetNode);
|
||||
|
||||
final Set<String> acknowledgedCloses = ConcurrentCollections.newConcurrentSet();
|
||||
try {
|
||||
|
@ -146,8 +148,7 @@ public class CloseWhileRelocatingShardsIT extends ESIntegTestCase {
|
|||
}
|
||||
|
||||
final DiscoveryNode sourceNode = clusterService.state().nodes().resolveNode(primary.currentNodeId());
|
||||
((MockTransportService) internalCluster().getInstance(TransportService.class, targetNode))
|
||||
.addSendBehavior(internalCluster().getInstance(TransportService.class, sourceNode.getName()),
|
||||
targetTransportService.addSendBehavior(internalCluster().getInstance(TransportService.class, sourceNode.getName()),
|
||||
(connection, requestId, action, request, options) -> {
|
||||
if (PeerRecoverySourceService.Actions.START_RECOVERY.equals(action)) {
|
||||
logger.debug("blocking recovery of shard {}", ((StartRecoveryRequest) request).shardId());
|
||||
|
@ -210,11 +211,6 @@ public class CloseWhileRelocatingShardsIT extends ESIntegTestCase {
|
|||
}
|
||||
}
|
||||
}
|
||||
} finally {
|
||||
assertAcked(client().admin().cluster().prepareUpdateSettings()
|
||||
.setTransientSettings(Settings.builder()
|
||||
.putNull(EnableAllocationDecider.CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey())));
|
||||
}
|
||||
|
||||
for (String index : indices) {
|
||||
if (acknowledgedCloses.contains(index)) {
|
||||
|
@ -224,6 +220,8 @@ public class CloseWhileRelocatingShardsIT extends ESIntegTestCase {
|
|||
}
|
||||
}
|
||||
|
||||
targetTransportService.clearAllRules();
|
||||
|
||||
assertThat("Consider that the test failed if no indices were successfully closed", acknowledgedCloses.size(), greaterThan(0));
|
||||
assertAcked(client().admin().indices().prepareOpen("index-*"));
|
||||
ensureGreen(indices);
|
||||
|
@ -233,5 +231,10 @@ public class CloseWhileRelocatingShardsIT extends ESIntegTestCase {
|
|||
assertEquals("Expected " + docsPerIndex.get(index) + " docs in index " + index + " but got " + docsCount
|
||||
+ " (close acknowledged=" + acknowledgedCloses.contains(index) + ")", (long) docsPerIndex.get(index), docsCount);
|
||||
}
|
||||
} finally {
|
||||
assertAcked(client().admin().cluster().prepareUpdateSettings()
|
||||
.setTransientSettings(Settings.builder()
|
||||
.putNull(EnableAllocationDecider.CLUSTER_ROUTING_REBALANCE_ENABLE_SETTING.getKey())));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue