Merge pull request #1672 from metamx/derbyRule

Migrate TestDerbyConnector to a JUnit @Rule
This commit is contained in:
Gian Merlino 2015-08-26 22:56:18 -07:00
commit 5b67ec6cda
9 changed files with 167 additions and 215 deletions

View File

@ -19,7 +19,6 @@
package io.druid.indexer.updater; package io.druid.indexer.updater;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.google.common.base.Preconditions; import com.google.common.base.Preconditions;
import com.google.common.base.Supplier; import com.google.common.base.Supplier;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
@ -81,7 +80,6 @@ import java.nio.MappedByteBuffer;
import java.nio.channels.FileChannel; import java.nio.channels.FileChannel;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.sql.SQLException;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.Comparator; import java.util.Comparator;
@ -92,95 +90,14 @@ public class HadoopConverterJobTest
{ {
@Rule @Rule
public final TemporaryFolder temporaryFolder = new TemporaryFolder(); public final TemporaryFolder temporaryFolder = new TemporaryFolder();
@Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private String storageLocProperty = null; private String storageLocProperty = null;
private File tmpSegmentDir = null; private File tmpSegmentDir = null;
private static final String DATASOURCE = "testDatasource"; private static final String DATASOURCE = "testDatasource";
private static final String STORAGE_PROPERTY_KEY = "druid.storage.storageDirectory"; private static final String STORAGE_PROPERTY_KEY = "druid.storage.storageDirectory";
private final MetadataStorageUpdaterJobSpec metadataStorageUpdaterJobSpc = new MetadataStorageUpdaterJobSpec()
{
@Override
@JsonProperty
public String getSegmentTable()
{
return "druid_segments";
}
@Override
@JsonProperty
public String getType()
{
return "derby";
}
@JsonProperty
public String getConnectURI()
{
return "jdbc:derby:memory:druidTest;create=true";
}
@JsonProperty
public String getUser()
{
return "sb";
}
@JsonProperty
public String getPassword()
{
return "sb";
}
@Override
public MetadataStorageConnectorConfig get()
{
return new MetadataStorageConnectorConfig()
{
public boolean isCreateTables()
{
return true;
}
public String getHost()
{
return "localhost";
}
public int getPort()
{
return -1;
}
public String getConnectURI()
{
return "jdbc:derby:memory:druidTest;create=true";
}
public String getUser()
{
return "sb";
}
public String getPassword()
{
return "sb";
}
@Override
public String toString()
{
return "DbConnectorConfig{" +
"createTables=" + isCreateTables() +
", connectURI='" + getConnectURI() + '\'' +
", user='" + getUser() + '\'' +
", passwordProvider=" + getPassword() +
'}';
}
};
}
};
private Supplier<MetadataStorageTablesConfig> metadataStorageTablesConfigSupplier; private Supplier<MetadataStorageTablesConfig> metadataStorageTablesConfigSupplier;
private DerbyConnector connector; private DerbyConnector connector;
@ -201,6 +118,20 @@ public class HadoopConverterJobTest
@Before @Before
public void setUp() throws Exception public void setUp() throws Exception
{ {
final MetadataStorageUpdaterJobSpec metadataStorageUpdaterJobSpec = new MetadataStorageUpdaterJobSpec()
{
@Override
public String getSegmentTable()
{
return derbyConnectorRule.metadataTablesConfigSupplier().get().getSegmentsTable();
}
@Override
public MetadataStorageConnectorConfig get()
{
return derbyConnectorRule.getMetadataConnectorConfig();
}
};
final File scratchFileDir = temporaryFolder.newFolder(); final File scratchFileDir = temporaryFolder.newFolder();
storageLocProperty = System.getProperty(STORAGE_PROPERTY_KEY); storageLocProperty = System.getProperty(STORAGE_PROPERTY_KEY);
tmpSegmentDir = temporaryFolder.newFolder(); tmpSegmentDir = temporaryFolder.newFolder();
@ -249,7 +180,7 @@ public class HadoopConverterJobTest
"type", "static", "type", "static",
"paths", tmpInputFile.getAbsolutePath() "paths", tmpInputFile.getAbsolutePath()
), ),
metadataStorageUpdaterJobSpc, metadataStorageUpdaterJobSpec,
tmpSegmentDir.getAbsolutePath() tmpSegmentDir.getAbsolutePath()
), ),
new HadoopTuningConfig( new HadoopTuningConfig(
@ -273,34 +204,8 @@ public class HadoopConverterJobTest
) )
) )
); );
metadataStorageTablesConfigSupplier = metadataStorageTablesConfigSupplier = derbyConnectorRule.metadataTablesConfigSupplier();
new Supplier<MetadataStorageTablesConfig>() connector = derbyConnectorRule.getConnector();
{
@Override
public MetadataStorageTablesConfig get()
{
return MetadataStorageTablesConfig.fromBase("druid");
}
};
connector = new TestDerbyConnector(
new Supplier<MetadataStorageConnectorConfig>()
{
@Override
public MetadataStorageConnectorConfig get()
{
return metadataStorageUpdaterJobSpc.get();
}
},
new Supplier<MetadataStorageTablesConfig>()
{
@Override
public MetadataStorageTablesConfig get()
{
return new MetadataStorageTablesConfig(null, null, null, null, null, null, null, null);
}
}
);
try { try {
connector.getDBI().withHandle( connector.getDBI().withHandle(
new HandleCallback<Void>() new HandleCallback<Void>()
@ -313,7 +218,8 @@ public class HadoopConverterJobTest
} }
} }
); );
} catch (CallbackFailedException e){ }
catch (CallbackFailedException e) {
// Who cares // Who cares
} }
List<Jobby> jobs = ImmutableList.of( List<Jobby> jobs = ImmutableList.of(
@ -322,7 +228,7 @@ public class HadoopConverterJobTest
@Override @Override
public boolean run() public boolean run()
{ {
connector.createSegmentTable(connector.getDBI(), "druid_segments"); connector.createSegmentTable(connector.getDBI(), metadataStorageUpdaterJobSpec.getSegmentTable());
return true; return true;
} }
}, },

View File

@ -26,7 +26,6 @@ import com.google.common.base.Function;
import com.google.common.base.Optional; import com.google.common.base.Optional;
import com.google.common.base.Preconditions; import com.google.common.base.Preconditions;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.common.base.Suppliers;
import com.google.common.base.Throwables; import com.google.common.base.Throwables;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
@ -74,8 +73,6 @@ import io.druid.indexing.common.task.TaskResource;
import io.druid.indexing.overlord.config.TaskQueueConfig; import io.druid.indexing.overlord.config.TaskQueueConfig;
import io.druid.jackson.DefaultObjectMapper; import io.druid.jackson.DefaultObjectMapper;
import io.druid.metadata.IndexerSQLMetadataStorageCoordinator; import io.druid.metadata.IndexerSQLMetadataStorageCoordinator;
import io.druid.metadata.MetadataStorageConnectorConfig;
import io.druid.metadata.MetadataStorageTablesConfig;
import io.druid.metadata.SQLMetadataStorageActionHandlerFactory; import io.druid.metadata.SQLMetadataStorageActionHandlerFactory;
import io.druid.metadata.TestDerbyConnector; import io.druid.metadata.TestDerbyConnector;
import io.druid.query.QueryRunnerFactoryConglomerate; import io.druid.query.QueryRunnerFactoryConglomerate;
@ -165,6 +162,9 @@ public class TaskLifecycleTest
IR("2010-01-02T01", "a", "c", 1) IR("2010-01-02T01", "a", "c", 1)
); );
@Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private final String taskStorageType; private final String taskStorageType;
private ObjectMapper mapper; private ObjectMapper mapper;
@ -343,15 +343,7 @@ public class TaskLifecycleTest
} }
); );
} else if (taskStorageType.equals("MetadataTaskStorage")) { } else if (taskStorageType.equals("MetadataTaskStorage")) {
MetadataStorageTablesConfig tablesConfig = MetadataStorageTablesConfig.fromBase("test"); testDerbyConnector = derbyConnectorRule.getConnector();
testDerbyConnector = new TestDerbyConnector(
Suppliers.ofInstance(
new MetadataStorageConnectorConfig()
),
Suppliers.ofInstance(
tablesConfig
)
);
mapper = new DefaultObjectMapper(); mapper = new DefaultObjectMapper();
mapper.registerSubtypes( mapper.registerSubtypes(
new NamedType(MockExceptionalFirehoseFactory.class, "mockExcepFirehoseFactory"), new NamedType(MockExceptionalFirehoseFactory.class, "mockExcepFirehoseFactory"),
@ -363,7 +355,7 @@ public class TaskLifecycleTest
ts = new MetadataTaskStorage( ts = new MetadataTaskStorage(
testDerbyConnector, testDerbyConnector,
new TaskStorageConfig(null), new TaskStorageConfig(null),
new SQLMetadataStorageActionHandlerFactory(testDerbyConnector, tablesConfig, mapper) new SQLMetadataStorageActionHandlerFactory(testDerbyConnector, derbyConnectorRule.metadataTablesConfigSupplier().get(), mapper)
); );
} else { } else {
throw new RuntimeException(String.format("Unknown task storage type [%s]", taskStorageType)); throw new RuntimeException(String.format("Unknown task storage type [%s]", taskStorageType));
@ -470,9 +462,6 @@ public class TaskLifecycleTest
public void tearDown() public void tearDown()
{ {
tq.stop(); tq.stop();
if (testDerbyConnector != null) {
testDerbyConnector.tearDown();
}
} }
@Test @Test

View File

@ -20,7 +20,6 @@
package io.druid.metadata; package io.druid.metadata;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.base.Suppliers;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
@ -28,9 +27,9 @@ import io.druid.jackson.DefaultObjectMapper;
import io.druid.timeline.DataSegment; import io.druid.timeline.DataSegment;
import io.druid.timeline.partition.LinearShardSpec; import io.druid.timeline.partition.LinearShardSpec;
import org.joda.time.Interval; import org.joda.time.Interval;
import org.junit.After;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.Handle;
import org.skife.jdbi.v2.tweak.HandleCallback; import org.skife.jdbi.v2.tweak.HandleCallback;
@ -40,12 +39,8 @@ import java.util.Set;
public class IndexerSQLMetadataStorageCoordinatorTest public class IndexerSQLMetadataStorageCoordinatorTest
{ {
@Rule
private final MetadataStorageTablesConfig tablesConfig = MetadataStorageTablesConfig.fromBase("test"); public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private final TestDerbyConnector derbyConnector = new TestDerbyConnector(
Suppliers.ofInstance(new MetadataStorageConnectorConfig()),
Suppliers.ofInstance(tablesConfig)
);
private final ObjectMapper mapper = new DefaultObjectMapper(); private final ObjectMapper mapper = new DefaultObjectMapper();
private final DataSegment defaultSegment = new DataSegment( private final DataSegment defaultSegment = new DataSegment(
"dataSource", "dataSource",
@ -72,26 +67,22 @@ public class IndexerSQLMetadataStorageCoordinatorTest
); );
private final Set<DataSegment> segments = ImmutableSet.of(defaultSegment, defaultSegment2); private final Set<DataSegment> segments = ImmutableSet.of(defaultSegment, defaultSegment2);
IndexerSQLMetadataStorageCoordinator coordinator; IndexerSQLMetadataStorageCoordinator coordinator;
private TestDerbyConnector derbyConnector;
@Before @Before
public void setUp() public void setUp()
{ {
derbyConnector = derbyConnectorRule.getConnector();
mapper.registerSubtypes(LinearShardSpec.class); mapper.registerSubtypes(LinearShardSpec.class);
derbyConnector.createTaskTables(); derbyConnector.createTaskTables();
derbyConnector.createSegmentTable(); derbyConnector.createSegmentTable();
coordinator = new IndexerSQLMetadataStorageCoordinator( coordinator = new IndexerSQLMetadataStorageCoordinator(
mapper, mapper,
tablesConfig, derbyConnectorRule.metadataTablesConfigSupplier().get(),
derbyConnector derbyConnector
); );
} }
@After
public void tearDown()
{
derbyConnector.tearDown();
}
private void unUseSegment() private void unUseSegment()
{ {
for (final DataSegment segment : segments) { for (final DataSegment segment : segments) {
@ -103,10 +94,11 @@ public class IndexerSQLMetadataStorageCoordinatorTest
public Integer withHandle(Handle handle) throws Exception public Integer withHandle(Handle handle) throws Exception
{ {
return handle.createStatement( return handle.createStatement(
String.format("UPDATE %s SET used = false WHERE id = :id", tablesConfig.getSegmentsTable()) String.format(
) "UPDATE %s SET used = false WHERE id = :id",
.bind("id", segment.getIdentifier()) derbyConnectorRule.metadataTablesConfigSupplier().get().getSegmentsTable()
.execute(); )
).bind("id", segment.getIdentifier()).execute();
} }
} }
) )
@ -121,7 +113,7 @@ public class IndexerSQLMetadataStorageCoordinatorTest
Assert.assertArrayEquals( Assert.assertArrayEquals(
mapper.writeValueAsString(defaultSegment).getBytes("UTF-8"), mapper.writeValueAsString(defaultSegment).getBytes("UTF-8"),
derbyConnector.lookup( derbyConnector.lookup(
tablesConfig.getSegmentsTable(), derbyConnectorRule.metadataTablesConfigSupplier().get().getSegmentsTable(),
"id", "id",
"payload", "payload",
defaultSegment.getIdentifier() defaultSegment.getIdentifier()

View File

@ -18,7 +18,6 @@
package io.druid.metadata; package io.druid.metadata;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.base.Supplier;
import com.google.common.base.Suppliers; import com.google.common.base.Suppliers;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
@ -30,13 +29,16 @@ import org.joda.time.Interval;
import org.junit.After; import org.junit.After;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
public class MetadataSegmentManagerTest public class MetadataSegmentManagerTest
{ {
@Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private SQLMetadataSegmentManager manager; private SQLMetadataSegmentManager manager;
private TestDerbyConnector connector;
private final ObjectMapper jsonMapper = new DefaultObjectMapper(); private final ObjectMapper jsonMapper = new DefaultObjectMapper();
private final DataSegment segment1 = new DataSegment( private final DataSegment segment1 = new DataSegment(
@ -74,23 +76,18 @@ public class MetadataSegmentManagerTest
@Before @Before
public void setUp() throws Exception public void setUp() throws Exception
{ {
final Supplier<MetadataStorageTablesConfig> dbTables = Suppliers.ofInstance(MetadataStorageTablesConfig.fromBase("test")); TestDerbyConnector connector = derbyConnectorRule.getConnector();
connector = new TestDerbyConnector(
Suppliers.ofInstance(new MetadataStorageConnectorConfig()),
dbTables
);
manager = new SQLMetadataSegmentManager( manager = new SQLMetadataSegmentManager(
jsonMapper, jsonMapper,
Suppliers.ofInstance(new MetadataSegmentManagerConfig()), Suppliers.ofInstance(new MetadataSegmentManagerConfig()),
dbTables, derbyConnectorRule.metadataTablesConfigSupplier(),
connector connector
); );
SQLMetadataSegmentPublisher publisher = new SQLMetadataSegmentPublisher( SQLMetadataSegmentPublisher publisher = new SQLMetadataSegmentPublisher(
jsonMapper, jsonMapper,
dbTables.get(), derbyConnectorRule.metadataTablesConfigSupplier().get(),
connector connector
); );
@ -100,12 +97,6 @@ public class MetadataSegmentManagerTest
publisher.publishSegment(segment2); publisher.publishSegment(segment2);
} }
@After
public void tearDown() throws Exception
{
connector.tearDown();
}
@Test @Test
public void testPoll() public void testPoll()
{ {

View File

@ -19,6 +19,7 @@ package io.druid.metadata;
import com.google.common.base.Suppliers; import com.google.common.base.Suppliers;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.Handle;
import org.skife.jdbi.v2.tweak.HandleCallback; import org.skife.jdbi.v2.tweak.HandleCallback;
@ -28,15 +29,16 @@ import java.util.LinkedList;
public class SQLMetadataConnectorTest public class SQLMetadataConnectorTest
{ {
@Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private TestDerbyConnector connector; private TestDerbyConnector connector;
private MetadataStorageTablesConfig tablesConfig = MetadataStorageTablesConfig.fromBase("test"); private MetadataStorageTablesConfig tablesConfig;
@Before @Before
public void setUp() throws Exception { public void setUp() throws Exception {
connector = new TestDerbyConnector( connector = derbyConnectorRule.getConnector();
Suppliers.ofInstance(new MetadataStorageConnectorConfig()), tablesConfig = derbyConnectorRule.metadataTablesConfigSupplier().get();
Suppliers.ofInstance(tablesConfig)
);
} }
@Test @Test

View File

@ -32,9 +32,9 @@ import io.druid.server.coordinator.rules.Rule;
import io.druid.server.metrics.NoopServiceEmitter; import io.druid.server.metrics.NoopServiceEmitter;
import org.joda.time.Interval; import org.joda.time.Interval;
import org.junit.After; import org.junit.After;
import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.Assert;
import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.Handle;
import org.skife.jdbi.v2.tweak.HandleCallback; import org.skife.jdbi.v2.tweak.HandleCallback;
@ -44,8 +44,10 @@ import java.util.Map;
public class SQLMetadataRuleManagerTest public class SQLMetadataRuleManagerTest
{ {
@org.junit.Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private TestDerbyConnector connector; private TestDerbyConnector connector;
private MetadataStorageTablesConfig tablesConfig = MetadataStorageTablesConfig.fromBase("test"); private MetadataStorageTablesConfig tablesConfig;
private SQLMetadataRuleManager ruleManager; private SQLMetadataRuleManager ruleManager;
private AuditManager auditManager; private AuditManager auditManager;
private final ObjectMapper mapper = new DefaultObjectMapper(); private final ObjectMapper mapper = new DefaultObjectMapper();
@ -54,10 +56,8 @@ public class SQLMetadataRuleManagerTest
@Before @Before
public void setUp() public void setUp()
{ {
connector = new TestDerbyConnector( connector = derbyConnectorRule.getConnector();
Suppliers.ofInstance(new MetadataStorageConnectorConfig()), tablesConfig = derbyConnectorRule.metadataTablesConfigSupplier().get();
Suppliers.ofInstance(tablesConfig)
);
connector.createAuditTable(); connector.createAuditTable();
auditManager = new SQLAuditManager( auditManager = new SQLAuditManager(
connector, connector,
@ -116,7 +116,7 @@ public class SQLMetadataRuleManagerTest
ruleManager.overrideRule( ruleManager.overrideRule(
"test_dataSource", "test_dataSource",
rules, rules,
auditInfo auditInfo
); );
// fetch rules from metadata storage // fetch rules from metadata storage
ruleManager.poll(); ruleManager.poll();
@ -127,8 +127,8 @@ public class SQLMetadataRuleManagerTest
List<AuditEntry> auditEntries = auditManager.fetchAuditHistory("test_dataSource", "rules", null); List<AuditEntry> auditEntries = auditManager.fetchAuditHistory("test_dataSource", "rules", null);
Assert.assertEquals(1, auditEntries.size()); Assert.assertEquals(1, auditEntries.size());
AuditEntry entry = auditEntries.get(0); AuditEntry entry = auditEntries.get(0);
Assert.assertEquals(mapper.writeValueAsString(rules),entry.getPayload()); Assert.assertEquals(mapper.writeValueAsString(rules), entry.getPayload());
Assert.assertEquals(auditInfo,entry.getAuditInfo()); Assert.assertEquals(auditInfo, entry.getAuditInfo());
Assert.assertEquals("test_dataSource", entry.getKey()); Assert.assertEquals("test_dataSource", entry.getKey());
} }

View File

@ -20,16 +20,15 @@ package io.druid.metadata;
import com.fasterxml.jackson.core.type.TypeReference; import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.base.Optional; import com.google.common.base.Optional;
import com.google.common.base.Suppliers;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet; import com.google.common.collect.ImmutableSet;
import com.metamx.common.Pair; import com.metamx.common.Pair;
import io.druid.jackson.DefaultObjectMapper; import io.druid.jackson.DefaultObjectMapper;
import org.joda.time.DateTime; import org.joda.time.DateTime;
import org.junit.After;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import java.util.HashSet; import java.util.HashSet;
@ -37,20 +36,16 @@ import java.util.Map;
public class SQLMetadataStorageActionHandlerTest public class SQLMetadataStorageActionHandlerTest
{ {
@Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private static final ObjectMapper jsonMapper = new DefaultObjectMapper(); private static final ObjectMapper jsonMapper = new DefaultObjectMapper();
private TestDerbyConnector connector;
private MetadataStorageTablesConfig tablesConfig = MetadataStorageTablesConfig.fromBase("test");
private SQLMetadataStorageActionHandler<Map<String, Integer>, Map<String, Integer>, Map<String, String>, Map<String, Integer>> handler; private SQLMetadataStorageActionHandler<Map<String, Integer>, Map<String, Integer>, Map<String, String>, Map<String, Integer>> handler;
@Before @Before
public void setUp() throws Exception public void setUp() throws Exception
{ {
MetadataStorageConnectorConfig config = new MetadataStorageConnectorConfig(); TestDerbyConnector connector = derbyConnectorRule.getConnector();
connector = new TestDerbyConnector(
Suppliers.ofInstance(config),
Suppliers.ofInstance(tablesConfig)
);
final String entryType = "entry"; final String entryType = "entry";
final String entryTable = "entries"; final String entryTable = "entries";
@ -107,12 +102,6 @@ public class SQLMetadataStorageActionHandlerTest
); );
} }
@After
public void tearDown()
{
connector.tearDown();
}
@Test @Test
public void testEntryAndStatus() throws Exception public void testEntryAndStatus() throws Exception
{ {

View File

@ -18,31 +18,112 @@
package io.druid.metadata; package io.druid.metadata;
import com.google.common.base.Supplier; import com.google.common.base.Supplier;
import com.google.common.base.Suppliers;
import io.druid.metadata.storage.derby.DerbyConnector; import io.druid.metadata.storage.derby.DerbyConnector;
import org.junit.Assert; import org.junit.Assert;
import org.junit.rules.ExternalResource;
import org.skife.jdbi.v2.DBI; import org.skife.jdbi.v2.DBI;
import org.skife.jdbi.v2.exceptions.UnableToObtainConnectionException; import org.skife.jdbi.v2.exceptions.UnableToObtainConnectionException;
import java.sql.SQLException; import java.sql.SQLException;
import java.util.UUID;
public class TestDerbyConnector extends DerbyConnector public class TestDerbyConnector extends DerbyConnector
{ {
private final String jdbcUri;
public TestDerbyConnector( public TestDerbyConnector(
Supplier<MetadataStorageConnectorConfig> config, Supplier<MetadataStorageConnectorConfig> config,
Supplier<MetadataStorageTablesConfig> dbTables Supplier<MetadataStorageTablesConfig> dbTables
) )
{ {
super(config, dbTables, new DBI("jdbc:derby:memory:druidTest;create=true")); this(config, dbTables, "jdbc:derby:memory:druidTest" + dbSafeUUID());
}
protected TestDerbyConnector(
Supplier<MetadataStorageConnectorConfig> config,
Supplier<MetadataStorageTablesConfig> dbTables,
String jdbcUri
)
{
super(config, dbTables, new DBI(jdbcUri + ";create=true"));
this.jdbcUri = jdbcUri;
} }
public void tearDown() public void tearDown()
{ {
try { try {
new DBI("jdbc:derby:memory:druidTest;drop=true").open().close(); new DBI(jdbcUri + ";drop=true").open().close();
} catch(UnableToObtainConnectionException e) { }
catch (UnableToObtainConnectionException e) {
SQLException cause = (SQLException) e.getCause(); SQLException cause = (SQLException) e.getCause();
// error code "08006" indicates proper shutdown // error code "08006" indicates proper shutdown
Assert.assertEquals("08006", cause.getSQLState()); Assert.assertEquals(String.format("Derby not shutdown: [%s]", cause.toString()), "08006", cause.getSQLState());
}
}
private static String dbSafeUUID()
{
return UUID.randomUUID().toString().replace("-", "");
}
public String getJdbcUri()
{
return jdbcUri;
}
public static class DerbyConnectorRule extends ExternalResource
{
private TestDerbyConnector connector;
private final Supplier<MetadataStorageTablesConfig> dbTables;
private final MetadataStorageConnectorConfig connectorConfig;
public DerbyConnectorRule()
{
this(Suppliers.ofInstance(MetadataStorageTablesConfig.fromBase("druidTest")));
}
public DerbyConnectorRule(
Supplier<MetadataStorageTablesConfig> dbTables
)
{
this.dbTables = dbTables;
this.connectorConfig = new MetadataStorageConnectorConfig()
{
@Override
public String getConnectURI()
{
return connector.getJdbcUri();
}
};
}
@Override
protected void before() throws Throwable
{
connector = new TestDerbyConnector(Suppliers.ofInstance(connectorConfig), dbTables);
connector.getDBI().open().close(); // create db
}
@Override
protected void after()
{
connector.tearDown();
}
public TestDerbyConnector getConnector()
{
return connector;
}
public MetadataStorageConnectorConfig getMetadataConnectorConfig()
{
return connectorConfig;
}
public Supplier<MetadataStorageTablesConfig> metadataTablesConfigSupplier()
{
return dbTables;
} }
} }
} }

View File

@ -18,20 +18,18 @@
package io.druid.server.audit; package io.druid.server.audit;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.base.Suppliers;
import io.druid.audit.AuditEntry; import io.druid.audit.AuditEntry;
import io.druid.audit.AuditInfo; import io.druid.audit.AuditInfo;
import io.druid.audit.AuditManager; import io.druid.audit.AuditManager;
import io.druid.jackson.DefaultObjectMapper; import io.druid.jackson.DefaultObjectMapper;
import io.druid.metadata.MetadataStorageConnectorConfig;
import io.druid.metadata.MetadataStorageTablesConfig;
import io.druid.metadata.TestDerbyConnector; import io.druid.metadata.TestDerbyConnector;
import io.druid.server.metrics.NoopServiceEmitter; import io.druid.server.metrics.NoopServiceEmitter;
import junit.framework.Assert;
import org.joda.time.DateTime; import org.joda.time.DateTime;
import org.joda.time.Interval; import org.joda.time.Interval;
import org.junit.After; import org.junit.After;
import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.Handle;
import org.skife.jdbi.v2.tweak.HandleCallback; import org.skife.jdbi.v2.tweak.HandleCallback;
@ -41,8 +39,10 @@ import java.util.List;
public class SQLAuditManagerTest public class SQLAuditManagerTest
{ {
@Rule
public final TestDerbyConnector.DerbyConnectorRule derbyConnectorRule = new TestDerbyConnector.DerbyConnectorRule();
private TestDerbyConnector connector; private TestDerbyConnector connector;
private MetadataStorageTablesConfig tablesConfig = MetadataStorageTablesConfig.fromBase("test");
private AuditManager auditManager; private AuditManager auditManager;
private final ObjectMapper mapper = new DefaultObjectMapper(); private final ObjectMapper mapper = new DefaultObjectMapper();
@ -51,14 +51,11 @@ public class SQLAuditManagerTest
@Before @Before
public void setUp() throws Exception public void setUp() throws Exception
{ {
connector = new TestDerbyConnector( connector = derbyConnectorRule.getConnector();
Suppliers.ofInstance(new MetadataStorageConnectorConfig()),
Suppliers.ofInstance(tablesConfig)
);
connector.createAuditTable(); connector.createAuditTable();
auditManager = new SQLAuditManager( auditManager = new SQLAuditManager(
connector, connector,
Suppliers.ofInstance(tablesConfig), derbyConnectorRule.metadataTablesConfigSupplier(),
new NoopServiceEmitter(), new NoopServiceEmitter(),
mapper, mapper,
new SQLAuditManagerConfig() new SQLAuditManagerConfig()
@ -99,7 +96,12 @@ public class SQLAuditManagerTest
new DateTime("2013-01-01T00:00:00Z") new DateTime("2013-01-01T00:00:00Z")
); );
auditManager.doAudit(entry); auditManager.doAudit(entry);
byte[] payload = connector.lookup(tablesConfig.getAuditTable(), "audit_key", "payload", "testKey"); byte[] payload = connector.lookup(
derbyConnectorRule.metadataTablesConfigSupplier().get().getAuditTable(),
"audit_key",
"payload",
"testKey"
);
AuditEntry dbEntry = mapper.readValue(payload, AuditEntry.class); AuditEntry dbEntry = mapper.readValue(payload, AuditEntry.class);
Assert.assertEquals(entry, dbEntry); Assert.assertEquals(entry, dbEntry);
@ -136,7 +138,7 @@ public class SQLAuditManagerTest
@After @After
public void cleanup() public void cleanup()
{ {
dropTable(tablesConfig.getAuditTable()); dropTable(derbyConnectorRule.metadataTablesConfigSupplier().get().getAuditTable());
} }
private void dropTable(final String tableName) private void dropTable(final String tableName)