Skip to content

Commit

Permalink
Add test for execute method of task
Browse files Browse the repository at this point in the history
Signed-off-by: Rishab Nahata <rnnahata@amazon.com>
  • Loading branch information
imRishN committed Oct 7, 2022
1 parent 165b961 commit e4e1b5c
Showing 1 changed file with 45 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,51 @@ public void testJoinClusterWithDifferentDecommission() {
JoinTaskExecutor.ensureNodeCommissioned(discoveryNode, metadata);
}

public void testJoinFailedForDecommissionedNode() throws Exception {
final AllocationService allocationService = mock(AllocationService.class);
when(allocationService.adaptAutoExpandReplicas(any())).then(invocationOnMock -> invocationOnMock.getArguments()[0]);
final RerouteService rerouteService = (reason, priority, listener) -> listener.onResponse(null);

final JoinTaskExecutor joinTaskExecutor = new JoinTaskExecutor(Settings.EMPTY, allocationService, logger, rerouteService, null);

final DiscoveryNode clusterManagerNode = new DiscoveryNode(UUIDs.base64UUID(), buildNewFakeTransportAddress(), Version.CURRENT);

DecommissionAttribute decommissionAttribute = new DecommissionAttribute("zone", "zone1");
DecommissionAttributeMetadata decommissionAttributeMetadata = new DecommissionAttributeMetadata(
decommissionAttribute,
DecommissionStatus.SUCCESSFUL
);
final ClusterState clusterManagerClusterState = ClusterState.builder(ClusterName.DEFAULT)
.nodes(
DiscoveryNodes.builder()
.add(clusterManagerNode)
.localNodeId(clusterManagerNode.getId())
.clusterManagerNodeId(clusterManagerNode.getId())
)
.metadata(Metadata.builder().decommissionAttributeMetadata(decommissionAttributeMetadata))
.build();

final DiscoveryNode decommissionedNode = new DiscoveryNode(
UUIDs.base64UUID(),
buildNewFakeTransportAddress(),
Collections.singletonMap("zone", "zone1"),
DiscoveryNodeRole.BUILT_IN_ROLES,
Version.CURRENT
);

String decommissionedNodeID = decommissionedNode.getId();

final ClusterStateTaskExecutor.ClusterTasksResult<JoinTaskExecutor.Task> result = joinTaskExecutor.execute(
clusterManagerClusterState,
List.of(new JoinTaskExecutor.Task(decommissionedNode, "test"))
);
assertThat(result.executionResults.entrySet(), hasSize(1));
final ClusterStateTaskExecutor.TaskResult taskResult = result.executionResults.values().iterator().next();
assertFalse(taskResult.isSuccess());
assertTrue(taskResult.getFailure() instanceof NodeDecommissionedException);
assertFalse(result.resultingState.getNodes().nodeExists(decommissionedNodeID));
}

public void testJoinClusterWithDecommissionFailed() {
Settings.builder().build();
DecommissionAttribute decommissionAttribute = new DecommissionAttribute("zone", "zone-1");
Expand Down

0 comments on commit e4e1b5c

Please sign in to comment.