mirror of https://github.com/apache/druid.git
Merge pull request #1672 from metamx/derbyRule
Migrate TestDerbyConnector to a JUnit @Rule
This commit is contained in:
commit
5b67ec6cda
|
@ -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;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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()
|
||||||
{
|
{
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
{
|
{
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue