package software.amazon.shield.drtaccess; import java.time.Duration; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.mockito.Mock; import org.mockito.junit.jupiter.MockitoExtension; import software.amazon.awssdk.services.shield.ShieldClient; import software.amazon.awssdk.services.shield.model.DescribeDrtAccessRequest; import software.amazon.awssdk.services.shield.model.DescribeDrtAccessResponse; import software.amazon.cloudformation.proxy.AmazonWebServicesClientProxy; import software.amazon.cloudformation.proxy.Credentials; import software.amazon.cloudformation.proxy.HandlerErrorCode; import software.amazon.cloudformation.proxy.Logger; import software.amazon.cloudformation.proxy.LoggerProxy; import software.amazon.cloudformation.proxy.OperationStatus; import software.amazon.cloudformation.proxy.ProgressEvent; import software.amazon.cloudformation.proxy.ResourceHandlerRequest; import software.amazon.shield.common.ShieldAPIChainableRemoteCall; import software.amazon.shield.drtaccess.helper.DrtAccessTestBase; import static org.assertj.core.api.Assertions.assertThat; import static org.mockito.ArgumentMatchers.any; import static org.mockito.Mockito.doReturn; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.spy; @ExtendWith(MockitoExtension.class) public class DeleteHandlerTest extends DrtAccessTestBase { @Mock private AmazonWebServicesClientProxy proxy; @Mock private Logger logger; private ResourceModel resourceModel; private DeleteHandler deleteHandler; @BeforeEach public void setup() { proxy = spy(new AmazonWebServicesClientProxy(new LoggerProxy(), new Credentials("accessKey", "secretKey", "token"), () -> Duration.ofSeconds(600).toMillis())); logger = mock(Logger.class); resourceModel = getTestResourceModel(); deleteHandler = new DeleteHandler(mock(ShieldClient.class)); ShieldAPIChainableRemoteCall.JITTER_SECONDS = 0; } @Test public void handleRequest_SimpleSuccess() { final DescribeDrtAccessResponse describeDrtAccessResponse = DescribeDrtAccessResponse.builder() .roleArn(resourceModel.getRoleArn()) .logBucketList(resourceModel.getLogBucketList()) .build(); doReturn(describeDrtAccessResponse).when(proxy).injectCredentialsAndInvokeV2(any(DescribeDrtAccessRequest.class), any()); final ResourceHandlerRequest request = ResourceHandlerRequest.builder() .awsAccountId(accountId) .desiredResourceState(ResourceModel.builder().accountId(accountId).build()) .build(); final ProgressEvent response = deleteHandler.handleRequest(proxy, request, null, logger); assertThat(response).isNotNull(); assertThat(response.getStatus()).isEqualTo(OperationStatus.SUCCESS); assertThat(response.getCallbackContext()).isNull(); assertThat(response.getCallbackDelaySeconds()).isEqualTo(0); assertThat(response.getMessage()).isNull(); assertThat(response.getErrorCode()).isNull(); } @Test public void handleRequest_NoDrtAccessFailure() { final DescribeDrtAccessResponse describeDrtAccessResponse = DescribeDrtAccessResponse.builder() .build(); doReturn(describeDrtAccessResponse).when(proxy).injectCredentialsAndInvokeV2(any(DescribeDrtAccessRequest.class), any()); final ResourceHandlerRequest request = ResourceHandlerRequest.builder() .awsAccountId(accountId) .desiredResourceState(ResourceModel.builder().accountId(accountId).build()) .nextToken("randomNextToken") .build(); final ProgressEvent response = deleteHandler.handleRequest(proxy, request, null, logger); assertThat(response).isNotNull(); assertThat(response.getStatus()).isEqualTo(OperationStatus.FAILED); assertThat(response.getErrorCode()).isEqualTo(HandlerErrorCode.NotFound); } @Test public void handleRequest_AccountNotFoundFailure() { final ResourceModel model = ResourceModel.builder() .accountId(accountId) .build(); final ResourceHandlerRequest request = ResourceHandlerRequest.builder() .desiredResourceState(model) .build(); final ProgressEvent response = deleteHandler.handleRequest(proxy, request, null, logger); assertThat(response).isNotNull(); assertThat(response.getStatus()).isEqualTo(OperationStatus.FAILED); assertThat(response.getErrorCode()).isEqualTo(HandlerErrorCode.NotFound); } }