diff --git a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractAzureInputSourceParallelIndexTest.java b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractAzureInputSourceParallelIndexTest.java index 81852df11c72..b28570cdf9a6 100644 --- a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractAzureInputSourceParallelIndexTest.java +++ b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractAzureInputSourceParallelIndexTest.java @@ -19,11 +19,16 @@ package org.apache.druid.testsEx.indexer; +import com.google.common.collect.ImmutableList; import org.apache.druid.java.util.common.logger.Logger; import org.apache.druid.testsEx.utils.AzureTestUtil; import org.junit.AfterClass; +import org.junit.Assert; import org.junit.BeforeClass; +import java.net.URI; +import java.util.List; + import static org.junit.Assert.fail; /** @@ -69,4 +74,22 @@ public static void deleteDataFilesFromAzure() LOG.warn(e, "Unable to delete container in azure"); } } + + public static void validateAzureSegmentFilesDeleted(String path) + { + List segmentFiles = ImmutableList.of(); + try { + segmentFiles = azure.listFiles(path); + } + catch (Exception e) { + LOG.warn(e, "Failed to validate that azure segment files were deleted."); + } + finally { + Assert.assertEquals( + "Some segment files were not deleted: " + segmentFiles, + segmentFiles.size(), + 0 + ); + } + } } diff --git a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractCloudInputSourceParallelIndexTest.java b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractCloudInputSourceParallelIndexTest.java index a920d928b761..740601a9f9da 100644 --- a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractCloudInputSourceParallelIndexTest.java +++ b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/AbstractCloudInputSourceParallelIndexTest.java @@ -134,8 +134,9 @@ public String getCloudBucket(String inputSourceType) * @param segmentAvailabilityConfirmationPair set lhs in the pair to true if you want to confirm that the task waited longer than 0ms for the task to complete. * set rhs to true to verify that the segment is actually available. * @param inputSourceType Input source type (eg : s3, gcs, azure) + * @return The datasource used to test. */ - void doTest( + String doTest( Pair> inputSource, Pair segmentAvailabilityConfirmationPair, String inputSourceType @@ -200,6 +201,7 @@ void doTest( true, segmentAvailabilityConfirmationPair ); + return indexDatasource; } } diff --git a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/ITAzureV2ParallelIndexTest.java b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/ITAzureV2ParallelIndexTest.java index df539eb59038..3bec5886147f 100644 --- a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/ITAzureV2ParallelIndexTest.java +++ b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/indexer/ITAzureV2ParallelIndexTest.java @@ -47,6 +47,7 @@ public class ITAzureV2ParallelIndexTest extends AbstractAzureInputSourceParallel @Parameters(method = "resources") public void testAzureIndexData(Pair> azureInputSource) throws Exception { - doTest(azureInputSource, new Pair<>(false, false), "azureStorage"); + String dataSource = doTest(azureInputSource, new Pair<>(false, false), "azureStorage"); + AbstractAzureInputSourceParallelIndexTest.validateAzureSegmentFilesDeleted("segments" + "/" + dataSource); } } diff --git a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/utils/AzureTestUtil.java b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/utils/AzureTestUtil.java index 90be0cbd464f..a43fdd48826e 100644 --- a/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/utils/AzureTestUtil.java +++ b/integration-tests-ex/cases/src/test/java/org/apache/druid/testsEx/utils/AzureTestUtil.java @@ -29,10 +29,13 @@ import java.io.File; import java.io.IOException; +import java.net.URI; import java.net.URISyntaxException; import java.nio.file.Files; import java.security.InvalidKeyException; +import java.util.ArrayList; import java.util.Arrays; +import java.util.List; public class AzureTestUtil { @@ -130,4 +133,20 @@ public void uploadFileToContainer(String filePath) throws IOException, URISyntax LOG.info("Uploading file " + DRUID_CLOUD_PATH + '/' + source.getName() + " in azure container " + AZURE_CONTAINER); blob.upload(Files.newInputStream(source.toPath()), source.length()); } + + /** + * Get a list of files under a path to be used for verification of kill tasks. + * + * @param filePath path to look for files under + */ + public List listFiles(String filePath) throws URISyntaxException, StorageException + { + // Retrieve reference to a previously created container. + CloudBlobContainer container = azureStorageClient.getContainerReference(AZURE_CONTAINER); + List activeFiles = new ArrayList<>(); + container.listBlobs(DRUID_CLOUD_PATH + '/' + filePath).iterator().forEachRemaining( + blob -> activeFiles.add(blob.getUri()) + ); + return activeFiles; + } }