Search in sources :

Example 1 with HDFSStorageFactory

use of io.pravega.storage.hdfs.HDFSStorageFactory in project pravega by pravega.

the class StorageFactoryTests method testHDFSStorageFactoryCreator.

@Test
public void testHDFSStorageFactoryCreator() {
    StorageFactoryCreator factoryCreator = new HDFSStorageFactoryCreator();
    val expected = new StorageFactoryInfo[] { StorageFactoryInfo.builder().name("HDFS").storageLayoutType(StorageLayoutType.CHUNKED_STORAGE).build(), StorageFactoryInfo.builder().name("HDFS").storageLayoutType(StorageLayoutType.ROLLING_STORAGE).build() };
    val factoryInfoList = factoryCreator.getStorageFactories();
    Assert.assertEquals(2, factoryInfoList.length);
    Assert.assertArrayEquals(expected, factoryInfoList);
    // Simple Storage
    ConfigSetup configSetup1 = mock(ConfigSetup.class);
    when(configSetup1.getConfig(any())).thenReturn(ChunkedSegmentStorageConfig.DEFAULT_CONFIG, HDFSStorageConfig.builder().build());
    val factory1 = factoryCreator.createFactory(expected[0], configSetup1, executorService());
    Assert.assertTrue(factory1 instanceof HDFSSimpleStorageFactory);
    @Cleanup Storage storage1 = ((HDFSSimpleStorageFactory) factory1).createStorageAdapter(42, new InMemoryMetadataStore(ChunkedSegmentStorageConfig.DEFAULT_CONFIG, executorService()));
    Assert.assertTrue(storage1 instanceof ChunkedSegmentStorage);
    Assert.assertTrue(((ChunkedSegmentStorage) storage1).getChunkStorage() instanceof HDFSChunkStorage);
    // Legacy Storage
    ConfigSetup configSetup2 = mock(ConfigSetup.class);
    when(configSetup2.getConfig(any())).thenReturn(HDFSStorageConfig.builder().build());
    val factory2 = factoryCreator.createFactory(expected[1], configSetup2, executorService());
    Assert.assertTrue(factory2 instanceof HDFSStorageFactory);
    @Cleanup Storage storage2 = factory2.createStorageAdapter();
    Assert.assertTrue(storage2 instanceof AsyncStorageWrapper);
    SyncStorage syncStorage = factory2.createSyncStorage();
    Assert.assertNotNull(syncStorage);
    AssertExtensions.assertThrows("createStorageAdapter should throw UnsupportedOperationException.", () -> factory1.createStorageAdapter(), ex -> ex instanceof UnsupportedOperationException);
}
Also used : lombok.val(lombok.val) SyncStorage(io.pravega.segmentstore.storage.SyncStorage) HDFSChunkStorage(io.pravega.storage.hdfs.HDFSChunkStorage) HDFSStorageFactoryCreator(io.pravega.storage.hdfs.HDFSStorageFactoryCreator) StorageFactoryInfo(io.pravega.segmentstore.storage.StorageFactoryInfo) ChunkedSegmentStorage(io.pravega.segmentstore.storage.chunklayer.ChunkedSegmentStorage) Cleanup(lombok.Cleanup) HDFSSimpleStorageFactory(io.pravega.storage.hdfs.HDFSSimpleStorageFactory) HDFSStorageFactory(io.pravega.storage.hdfs.HDFSStorageFactory) Storage(io.pravega.segmentstore.storage.Storage) ChunkedSegmentStorage(io.pravega.segmentstore.storage.chunklayer.ChunkedSegmentStorage) ExtendedS3ChunkStorage(io.pravega.storage.extendeds3.ExtendedS3ChunkStorage) HDFSChunkStorage(io.pravega.storage.hdfs.HDFSChunkStorage) S3ChunkStorage(io.pravega.storage.s3.S3ChunkStorage) SyncStorage(io.pravega.segmentstore.storage.SyncStorage) FileSystemChunkStorage(io.pravega.storage.filesystem.FileSystemChunkStorage) AsyncStorageWrapper(io.pravega.segmentstore.storage.AsyncStorageWrapper) InMemoryMetadataStore(io.pravega.segmentstore.storage.mocks.InMemoryMetadataStore) S3StorageFactoryCreator(io.pravega.storage.s3.S3StorageFactoryCreator) HDFSStorageFactoryCreator(io.pravega.storage.hdfs.HDFSStorageFactoryCreator) StorageFactoryCreator(io.pravega.segmentstore.storage.StorageFactoryCreator) ExtendedS3StorageFactoryCreator(io.pravega.storage.extendeds3.ExtendedS3StorageFactoryCreator) FileSystemStorageFactoryCreator(io.pravega.storage.filesystem.FileSystemStorageFactoryCreator) ConfigSetup(io.pravega.segmentstore.storage.ConfigSetup) Test(org.junit.Test)

Example 2 with HDFSStorageFactory

use of io.pravega.storage.hdfs.HDFSStorageFactory in project pravega by pravega.

the class StorageLoaderTest method testHDFSStorage.

@Test
public void testHDFSStorage() throws Exception {
    val storageType = ServiceConfig.StorageType.HDFS;
    ConfigSetup configSetup = mock(ConfigSetup.class);
    val extraConfig = StorageExtraConfig.builder().with(StorageExtraConfig.STORAGE_NO_OP_MODE, false).build();
    when(configSetup.getConfig(any())).thenReturn(extraConfig, HDFSStorageConfig.builder().build());
    val factory = getStorageFactory(configSetup, storageType, "HDFS", StorageLayoutType.ROLLING_STORAGE);
    assertTrue(factory instanceof HDFSStorageFactory);
}
Also used : lombok.val(lombok.val) HDFSStorageFactory(io.pravega.storage.hdfs.HDFSStorageFactory) ConfigSetup(io.pravega.segmentstore.storage.ConfigSetup) Test(org.junit.Test)

Aggregations

ConfigSetup (io.pravega.segmentstore.storage.ConfigSetup)2 HDFSStorageFactory (io.pravega.storage.hdfs.HDFSStorageFactory)2 lombok.val (lombok.val)2 Test (org.junit.Test)2 AsyncStorageWrapper (io.pravega.segmentstore.storage.AsyncStorageWrapper)1 Storage (io.pravega.segmentstore.storage.Storage)1 StorageFactoryCreator (io.pravega.segmentstore.storage.StorageFactoryCreator)1 StorageFactoryInfo (io.pravega.segmentstore.storage.StorageFactoryInfo)1 SyncStorage (io.pravega.segmentstore.storage.SyncStorage)1 ChunkedSegmentStorage (io.pravega.segmentstore.storage.chunklayer.ChunkedSegmentStorage)1 InMemoryMetadataStore (io.pravega.segmentstore.storage.mocks.InMemoryMetadataStore)1 ExtendedS3ChunkStorage (io.pravega.storage.extendeds3.ExtendedS3ChunkStorage)1 ExtendedS3StorageFactoryCreator (io.pravega.storage.extendeds3.ExtendedS3StorageFactoryCreator)1 FileSystemChunkStorage (io.pravega.storage.filesystem.FileSystemChunkStorage)1 FileSystemStorageFactoryCreator (io.pravega.storage.filesystem.FileSystemStorageFactoryCreator)1 HDFSChunkStorage (io.pravega.storage.hdfs.HDFSChunkStorage)1 HDFSSimpleStorageFactory (io.pravega.storage.hdfs.HDFSSimpleStorageFactory)1 HDFSStorageFactoryCreator (io.pravega.storage.hdfs.HDFSStorageFactoryCreator)1 S3ChunkStorage (io.pravega.storage.s3.S3ChunkStorage)1 S3StorageFactoryCreator (io.pravega.storage.s3.S3StorageFactoryCreator)1