com.scalar.db.api.DistributedStorageAdminImportTableIntegrationTestBase Maven / Gradle / Ivy
package com.scalar.db.api;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.assertThatThrownBy;
import com.scalar.db.exception.storage.ExecutionException;
import com.scalar.db.service.StorageFactory;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Properties;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.TestInstance;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@TestInstance(TestInstance.Lifecycle.PER_CLASS)
public abstract class DistributedStorageAdminImportTableIntegrationTestBase {
private static final Logger logger =
LoggerFactory.getLogger(DistributedStorageAdminImportTableIntegrationTestBase.class);
private static final String TEST_NAME = "storage_admin_import_table";
private static final String NAMESPACE = "int_test_" + TEST_NAME;
private final Map tables = new HashMap<>();
protected DistributedStorageAdmin admin;
@BeforeAll
public void beforeAll() throws Exception {
initialize(TEST_NAME);
}
protected void initialize(String testName) throws Exception {}
protected abstract Properties getProperties(String testName);
protected String getNamespace() {
return NAMESPACE;
}
protected Map getCreationOptions() {
return Collections.emptyMap();
}
private void dropTable() throws Exception {
for (Entry entry : tables.entrySet()) {
String table = entry.getKey();
TableMetadata metadata = entry.getValue();
if (metadata == null) {
dropNonImportableTable(table);
} else {
admin.dropTable(getNamespace(), table);
}
}
admin.dropNamespace(getNamespace());
}
@BeforeEach
protected void setUp() throws Exception {
StorageFactory factory = StorageFactory.create(getProperties(TEST_NAME));
admin = factory.getStorageAdmin();
}
@AfterEach
protected void afterEach() {
try {
dropTable();
} catch (Exception e) {
logger.warn("Failed to drop tables", e);
}
try {
if (admin != null) {
admin.close();
}
} catch (Exception e) {
logger.warn("Failed to close admin", e);
}
}
@AfterAll
protected void afterAll() throws Exception {}
protected abstract Map createExistingDatabaseWithAllDataTypes()
throws Exception;
protected abstract void dropNonImportableTable(String table) throws Exception;
@Test
public void importTable_ShouldWorkProperly() throws Exception {
// Arrange
admin.createNamespace(getNamespace(), getCreationOptions());
tables.putAll(createExistingDatabaseWithAllDataTypes());
// Act Assert
for (Entry entry : tables.entrySet()) {
String table = entry.getKey();
TableMetadata metadata = entry.getValue();
if (metadata == null) {
importTable_ForNonImportableTable_ShouldThrowIllegalArgumentException(table);
} else {
importTable_ForImportableTable_ShouldImportProperly(table, metadata);
}
}
importTable_ForNonExistingTable_ShouldThrowIllegalArgumentException();
}
@Test
public void importTable_ForUnsupportedDatabase_ShouldThrowUnsupportedOperationException()
throws ExecutionException {
// Arrange
admin.createNamespace(getNamespace(), getCreationOptions());
// Act Assert
assertThatThrownBy(
() -> admin.importTable(getNamespace(), "unsupported_db", Collections.emptyMap()))
.isInstanceOf(UnsupportedOperationException.class);
}
private void importTable_ForImportableTable_ShouldImportProperly(
String table, TableMetadata metadata) throws ExecutionException {
// Act
admin.importTable(getNamespace(), table, Collections.emptyMap());
// Assert
assertThat(admin.tableExists(getNamespace(), table)).isTrue();
assertThat(admin.getTableMetadata(getNamespace(), table)).isEqualTo(metadata);
}
private void importTable_ForNonImportableTable_ShouldThrowIllegalArgumentException(String table) {
// Act Assert
assertThatThrownBy(
() -> admin.importTable(getNamespace(), table, Collections.emptyMap()),
"non-importable data type test failed: " + table)
.isInstanceOf(IllegalArgumentException.class);
}
private void importTable_ForNonExistingTable_ShouldThrowIllegalArgumentException() {
// Act Assert
assertThatThrownBy(
() -> admin.importTable(getNamespace(), "non-existing-table", Collections.emptyMap()))
.isInstanceOf(IllegalArgumentException.class);
}
}