Respect buildV9Directly in PlumberSchools, so it works on standalone realtime nodes.

Also parameterize some tests to run with/without buildV9Directly:

- IndexGeneratorJobTest
- RealtimeIndexTaskTest
- RealtimePlumberSchoolTest
This commit is contained in:
Gian Merlino 2016-01-19 12:15:06 -08:00
parent a2e327ed08
commit 1dcf22edb7
10 changed files with 116 additions and 48 deletions

View File

@ -78,10 +78,10 @@ public class IndexGeneratorJobTest
{ {
@Parameterized.Parameters(name = "partitionType={0}, interval={1}, shardInfoForEachSegment={2}, data={3}, " + @Parameterized.Parameters(name = "partitionType={0}, interval={1}, shardInfoForEachSegment={2}, data={3}, " +
"inputFormatName={4}") "inputFormatName={4}, buildV9Directly={5}")
public static Collection<Object[]> constructFeed() public static Collection<Object[]> constructFeed()
{ {
return Arrays.asList( final List<Object[]> baseConstructors = Arrays.asList(
new Object[][]{ new Object[][]{
{ {
false, false,
@ -273,22 +273,39 @@ public class IndexGeneratorJobTest
} }
} }
); );
// Run each baseConstructor with/without buildV9Directly.
final List<Object[]> constructors = Lists.newArrayList();
for (Object[] baseConstructor : baseConstructors) {
final Object[] c1 = new Object[baseConstructor.length + 1];
final Object[] c2 = new Object[baseConstructor.length + 1];
System.arraycopy(baseConstructor, 0, c1, 0, baseConstructor.length);
System.arraycopy(baseConstructor, 0, c2, 0, baseConstructor.length);
c1[c1.length - 1] = true;
c2[c2.length - 1] = false;
constructors.add(c1);
constructors.add(c2);
}
return constructors;
} }
@Rule @Rule
public final TemporaryFolder temporaryFolder = new TemporaryFolder(); public final TemporaryFolder temporaryFolder = new TemporaryFolder();
private final boolean useCombiner;
private final String partitionType;
private final Interval interval;
private final Object[][][] shardInfoForEachSegment;
private final List<String> data;
private final String inputFormatName;
private final InputRowParser inputRowParser;
private final boolean buildV9Directly;
private ObjectMapper mapper; private ObjectMapper mapper;
private HadoopDruidIndexerConfig config; private HadoopDruidIndexerConfig config;
private File dataFile; private File dataFile;
private File tmpDir; private File tmpDir;
private Interval interval;
private String partitionType;
private Object[][][] shardInfoForEachSegment;
private List<String> data;
private boolean useCombiner;
private String inputFormatName;
private InputRowParser inputRowParser;
public IndexGeneratorJobTest( public IndexGeneratorJobTest(
boolean useCombiner, boolean useCombiner,
@ -297,7 +314,8 @@ public class IndexGeneratorJobTest
Object[][][] shardInfoForEachSegment, Object[][][] shardInfoForEachSegment,
List<String> data, List<String> data,
String inputFormatName, String inputFormatName,
InputRowParser inputRowParser InputRowParser inputRowParser,
boolean buildV9Directly
) throws IOException ) throws IOException
{ {
this.useCombiner = useCombiner; this.useCombiner = useCombiner;
@ -307,6 +325,7 @@ public class IndexGeneratorJobTest
this.data = data; this.data = data;
this.inputFormatName = inputFormatName; this.inputFormatName = inputFormatName;
this.inputRowParser = inputRowParser; this.inputRowParser = inputRowParser;
this.buildV9Directly = buildV9Directly;
} }
private void writeDataToLocalSequenceFile(File outputFile, List<String> data) throws IOException private void writeDataToLocalSequenceFile(File outputFile, List<String> data) throws IOException
@ -396,7 +415,7 @@ public class IndexGeneratorJobTest
false, false,
useCombiner, useCombiner,
null, null,
null buildV9Directly
) )
) )
); );

View File

@ -37,6 +37,7 @@ import io.druid.query.Query;
import io.druid.query.QueryRunner; import io.druid.query.QueryRunner;
import io.druid.segment.IndexIO; import io.druid.segment.IndexIO;
import io.druid.segment.IndexMerger; import io.druid.segment.IndexMerger;
import io.druid.segment.IndexMergerV9;
import io.druid.segment.QueryableIndex; import io.druid.segment.QueryableIndex;
import io.druid.segment.SegmentUtils; import io.druid.segment.SegmentUtils;
import io.druid.segment.incremental.IndexSizeExceededException; import io.druid.segment.incremental.IndexSizeExceededException;
@ -68,6 +69,7 @@ public class YeOldePlumberSchool implements PlumberSchool
private final DataSegmentPusher dataSegmentPusher; private final DataSegmentPusher dataSegmentPusher;
private final File tmpSegmentDir; private final File tmpSegmentDir;
private final IndexMerger indexMerger; private final IndexMerger indexMerger;
private final IndexMergerV9 indexMergerV9;
private final IndexIO indexIO; private final IndexIO indexIO;
private static final Logger log = new Logger(YeOldePlumberSchool.class); private static final Logger log = new Logger(YeOldePlumberSchool.class);
@ -79,6 +81,7 @@ public class YeOldePlumberSchool implements PlumberSchool
@JacksonInject("segmentPusher") DataSegmentPusher dataSegmentPusher, @JacksonInject("segmentPusher") DataSegmentPusher dataSegmentPusher,
@JacksonInject("tmpSegmentDir") File tmpSegmentDir, @JacksonInject("tmpSegmentDir") File tmpSegmentDir,
@JacksonInject IndexMerger indexMerger, @JacksonInject IndexMerger indexMerger,
@JacksonInject IndexMergerV9 indexMergerV9,
@JacksonInject IndexIO indexIO @JacksonInject IndexIO indexIO
) )
{ {
@ -87,6 +90,7 @@ public class YeOldePlumberSchool implements PlumberSchool
this.dataSegmentPusher = dataSegmentPusher; this.dataSegmentPusher = dataSegmentPusher;
this.tmpSegmentDir = tmpSegmentDir; this.tmpSegmentDir = tmpSegmentDir;
this.indexMerger = Preconditions.checkNotNull(indexMerger, "Null IndexMerger"); this.indexMerger = Preconditions.checkNotNull(indexMerger, "Null IndexMerger");
this.indexMergerV9 = Preconditions.checkNotNull(indexMergerV9, "Null IndexMergerV9");
this.indexIO = Preconditions.checkNotNull(indexIO, "Null IndexIO"); this.indexIO = Preconditions.checkNotNull(indexIO, "Null IndexIO");
} }
@ -106,6 +110,9 @@ public class YeOldePlumberSchool implements PlumberSchool
// Set of spilled segments. Will be merged at the end. // Set of spilled segments. Will be merged at the end.
final Set<File> spilled = Sets.newHashSet(); final Set<File> spilled = Sets.newHashSet();
// IndexMerger implementation.
final IndexMerger theIndexMerger = config.getBuildV9Directly() ? indexMergerV9 : indexMerger;
return new Plumber() return new Plumber()
{ {
@Override @Override
@ -174,7 +181,7 @@ public class YeOldePlumberSchool implements PlumberSchool
} }
fileToUpload = new File(tmpSegmentDir, "merged"); fileToUpload = new File(tmpSegmentDir, "merged");
indexMerger.mergeQueryableIndex(indexes, schema.getAggregators(), fileToUpload, config.getIndexSpec()); theIndexMerger.mergeQueryableIndex(indexes, schema.getAggregators(), fileToUpload, config.getIndexSpec());
} }
// Map merged segment so we can extract dimensions // Map merged segment so we can extract dimensions
@ -219,7 +226,7 @@ public class YeOldePlumberSchool implements PlumberSchool
log.info("Spilling index[%d] with rows[%d] to: %s", indexToPersist.getCount(), rowsToPersist, dirToPersist); log.info("Spilling index[%d] with rows[%d] to: %s", indexToPersist.getCount(), rowsToPersist, dirToPersist);
try { try {
indexMerger.persist( theIndexMerger.persist(
indexToPersist.getIndex(), indexToPersist.getIndex(),
dirToPersist, dirToPersist,
null, null,

View File

@ -124,7 +124,12 @@ public class IndexTask extends AbstractFixedIntervalTask
); );
} }
static RealtimeTuningConfig convertTuningConfig(ShardSpec shardSpec, int rowFlushBoundary, IndexSpec indexSpec) static RealtimeTuningConfig convertTuningConfig(
ShardSpec shardSpec,
int rowFlushBoundary,
IndexSpec indexSpec,
boolean buildV9Directly
)
{ {
return new RealtimeTuningConfig( return new RealtimeTuningConfig(
rowFlushBoundary, rowFlushBoundary,
@ -136,7 +141,7 @@ public class IndexTask extends AbstractFixedIntervalTask
null, null,
shardSpec, shardSpec,
indexSpec, indexSpec,
null buildV9Directly
); );
} }
@ -355,19 +360,22 @@ public class IndexTask extends AbstractFixedIntervalTask
final FireDepartmentMetrics metrics = new FireDepartmentMetrics(); final FireDepartmentMetrics metrics = new FireDepartmentMetrics();
final Firehose firehose = firehoseFactory.connect(ingestionSchema.getDataSchema().getParser()); final Firehose firehose = firehoseFactory.connect(ingestionSchema.getDataSchema().getParser());
final Supplier<Committer> committerSupplier = Committers.supplierFromFirehose(firehose); final Supplier<Committer> committerSupplier = Committers.supplierFromFirehose(firehose);
final IndexMerger indexMerger = ingestionSchema.getTuningConfig().getBuildV9Directly()
? toolbox.getIndexMergerV9()
: toolbox.getIndexMerger();
final Plumber plumber = new YeOldePlumberSchool( final Plumber plumber = new YeOldePlumberSchool(
interval, interval,
version, version,
wrappedDataSegmentPusher, wrappedDataSegmentPusher,
tmpDir, tmpDir,
indexMerger, toolbox.getIndexMerger(),
toolbox.getIndexMergerV9(),
toolbox.getIndexIO() toolbox.getIndexIO()
).findPlumber( ).findPlumber(
schema, schema,
convertTuningConfig(shardSpec, myRowFlushBoundary, ingestionSchema.getTuningConfig().getIndexSpec()), convertTuningConfig(
shardSpec,
myRowFlushBoundary,
ingestionSchema.getTuningConfig().getIndexSpec(),
ingestionSchema.tuningConfig.getBuildV9Directly()
),
metrics metrics
); );

View File

@ -47,7 +47,6 @@ import io.druid.query.QueryRunner;
import io.druid.query.QueryRunnerFactory; import io.druid.query.QueryRunnerFactory;
import io.druid.query.QueryRunnerFactoryConglomerate; import io.druid.query.QueryRunnerFactoryConglomerate;
import io.druid.query.QueryToolChest; import io.druid.query.QueryToolChest;
import io.druid.segment.IndexMerger;
import io.druid.segment.indexing.DataSchema; import io.druid.segment.indexing.DataSchema;
import io.druid.segment.indexing.RealtimeIOConfig; import io.druid.segment.indexing.RealtimeIOConfig;
import io.druid.segment.indexing.RealtimeTuningConfig; import io.druid.segment.indexing.RealtimeTuningConfig;
@ -287,9 +286,6 @@ public class RealtimeIndexTask extends AbstractTask
); );
this.queryRunnerFactoryConglomerate = toolbox.getQueryRunnerFactoryConglomerate(); this.queryRunnerFactoryConglomerate = toolbox.getQueryRunnerFactoryConglomerate();
IndexMerger indexMerger = spec.getTuningConfig().getBuildV9Directly()
? toolbox.getIndexMergerV9()
: toolbox.getIndexMerger();
// NOTE: This pusher selects path based purely on global configuration and the DataSegment, which means // NOTE: This pusher selects path based purely on global configuration and the DataSegment, which means
// NOTE: that redundant realtime tasks will upload to the same location. This can cause index.zip and // NOTE: that redundant realtime tasks will upload to the same location. This can cause index.zip and
// NOTE: descriptor.json to mismatch, or it can cause historical nodes to load different instances of the // NOTE: descriptor.json to mismatch, or it can cause historical nodes to load different instances of the
@ -302,7 +298,8 @@ public class RealtimeIndexTask extends AbstractTask
segmentPublisher, segmentPublisher,
toolbox.getSegmentHandoffNotifierFactory(), toolbox.getSegmentHandoffNotifierFactory(),
toolbox.getQueryExecutorService(), toolbox.getQueryExecutorService(),
indexMerger, toolbox.getIndexMerger(),
toolbox.getIndexMergerV9(),
toolbox.getIndexIO(), toolbox.getIndexIO(),
toolbox.getCache(), toolbox.getCache(),
toolbox.getCacheConfig(), toolbox.getCacheConfig(),

View File

@ -34,7 +34,6 @@ import io.druid.indexing.common.TestUtils;
import io.druid.indexing.common.actions.LockListAction; import io.druid.indexing.common.actions.LockListAction;
import io.druid.indexing.common.actions.TaskAction; import io.druid.indexing.common.actions.TaskAction;
import io.druid.indexing.common.actions.TaskActionClient; import io.druid.indexing.common.actions.TaskActionClient;
import io.druid.indexing.common.actions.TaskActionClientFactory;
import io.druid.query.aggregation.AggregatorFactory; import io.druid.query.aggregation.AggregatorFactory;
import io.druid.query.aggregation.LongSumAggregatorFactory; import io.druid.query.aggregation.LongSumAggregatorFactory;
import io.druid.segment.IndexIO; import io.druid.segment.IndexIO;
@ -342,7 +341,8 @@ public class IndexTaskTest
RealtimeTuningConfig realtimeTuningConfig = IndexTask.convertTuningConfig( RealtimeTuningConfig realtimeTuningConfig = IndexTask.convertTuningConfig(
spec, spec,
config.getRowFlushBoundary(), config.getRowFlushBoundary(),
config.getIndexSpec() config.getIndexSpec(),
config.getBuildV9Directly()
); );
Assert.assertEquals(realtimeTuningConfig.getMaxRowsInMemory(), config.getRowFlushBoundary()); Assert.assertEquals(realtimeTuningConfig.getMaxRowsInMemory(), config.getRowFlushBoundary());
Assert.assertEquals(realtimeTuningConfig.getShardSpec(), spec); Assert.assertEquals(realtimeTuningConfig.getShardSpec(), spec);

View File

@ -109,15 +109,20 @@ import org.junit.Before;
import org.junit.Rule; import org.junit.Rule;
import org.junit.Test; import org.junit.Test;
import org.junit.rules.TemporaryFolder; import org.junit.rules.TemporaryFolder;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import java.io.File; import java.io.File;
import java.io.IOException;
import java.nio.file.Files; import java.nio.file.Files;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.Executor; import java.util.concurrent.Executor;
@RunWith(Parameterized.class)
public class RealtimeIndexTaskTest public class RealtimeIndexTaskTest
{ {
private static final Logger log = new Logger(RealtimeIndexTaskTest.class); private static final Logger log = new Logger(RealtimeIndexTaskTest.class);
@ -143,10 +148,25 @@ public class RealtimeIndexTaskTest
@Rule @Rule
public final TemporaryFolder tempFolder = new TemporaryFolder(); public final TemporaryFolder tempFolder = new TemporaryFolder();
private final boolean buildV9Directly;
private DateTime now; private DateTime now;
private ListeningExecutorService taskExec; private ListeningExecutorService taskExec;
private Map<SegmentDescriptor, Pair<Executor, Runnable>> handOffCallbacks; private Map<SegmentDescriptor, Pair<Executor, Runnable>> handOffCallbacks;
private SegmentHandoffNotifierFactory handoffNotifierFactory;
@Parameterized.Parameters(name = "buildV9Directly = {0}")
public static Collection<?> constructorFeeder() throws IOException
{
return ImmutableList.of(
new Object[]{true},
new Object[]{false}
);
}
public RealtimeIndexTaskTest(boolean buildV9Directly)
{
this.buildV9Directly = buildV9Directly;
}
@Before @Before
public void setUp() public void setUp()
@ -572,7 +592,7 @@ public class RealtimeIndexTaskTest
null, null,
null, null,
null, null,
null buildV9Directly
); );
return new RealtimeIndexTask( return new RealtimeIndexTask(
taskId, taskId,
@ -650,7 +670,7 @@ public class RealtimeIndexTaskTest
) )
); );
handOffCallbacks = Maps.newConcurrentMap(); handOffCallbacks = Maps.newConcurrentMap();
handoffNotifierFactory = new SegmentHandoffNotifierFactory() final SegmentHandoffNotifierFactory handoffNotifierFactory = new SegmentHandoffNotifierFactory()
{ {
@Override @Override
public SegmentHandoffNotifier createSegmentHandoffNotifier(String dataSource) public SegmentHandoffNotifier createSegmentHandoffNotifier(String dataSource)

View File

@ -31,6 +31,7 @@ import io.druid.guice.annotations.Processing;
import io.druid.query.QueryRunnerFactoryConglomerate; import io.druid.query.QueryRunnerFactoryConglomerate;
import io.druid.segment.IndexIO; import io.druid.segment.IndexIO;
import io.druid.segment.IndexMerger; import io.druid.segment.IndexMerger;
import io.druid.segment.IndexMergerV9;
import io.druid.segment.indexing.DataSchema; import io.druid.segment.indexing.DataSchema;
import io.druid.segment.indexing.RealtimeTuningConfig; import io.druid.segment.indexing.RealtimeTuningConfig;
import io.druid.segment.realtime.FireDepartmentMetrics; import io.druid.segment.realtime.FireDepartmentMetrics;
@ -54,6 +55,7 @@ public class FlushingPlumberSchool extends RealtimePlumberSchool
private final DataSegmentAnnouncer segmentAnnouncer; private final DataSegmentAnnouncer segmentAnnouncer;
private final ExecutorService queryExecutorService; private final ExecutorService queryExecutorService;
private final IndexMerger indexMerger; private final IndexMerger indexMerger;
private final IndexMergerV9 indexMergerV9;
private final IndexIO indexIO; private final IndexIO indexIO;
private final Cache cache; private final Cache cache;
private final CacheConfig cacheConfig; private final CacheConfig cacheConfig;
@ -67,6 +69,7 @@ public class FlushingPlumberSchool extends RealtimePlumberSchool
@JacksonInject DataSegmentAnnouncer segmentAnnouncer, @JacksonInject DataSegmentAnnouncer segmentAnnouncer,
@JacksonInject @Processing ExecutorService queryExecutorService, @JacksonInject @Processing ExecutorService queryExecutorService,
@JacksonInject IndexMerger indexMerger, @JacksonInject IndexMerger indexMerger,
@JacksonInject IndexMergerV9 indexMergerV9,
@JacksonInject IndexIO indexIO, @JacksonInject IndexIO indexIO,
@JacksonInject Cache cache, @JacksonInject Cache cache,
@JacksonInject CacheConfig cacheConfig, @JacksonInject CacheConfig cacheConfig,
@ -82,6 +85,7 @@ public class FlushingPlumberSchool extends RealtimePlumberSchool
null, null,
queryExecutorService, queryExecutorService,
indexMerger, indexMerger,
indexMergerV9,
indexIO, indexIO,
cache, cache,
cacheConfig, cacheConfig,
@ -94,6 +98,7 @@ public class FlushingPlumberSchool extends RealtimePlumberSchool
this.segmentAnnouncer = segmentAnnouncer; this.segmentAnnouncer = segmentAnnouncer;
this.queryExecutorService = queryExecutorService; this.queryExecutorService = queryExecutorService;
this.indexMerger = Preconditions.checkNotNull(indexMerger, "Null IndexMerger"); this.indexMerger = Preconditions.checkNotNull(indexMerger, "Null IndexMerger");
this.indexMergerV9 = Preconditions.checkNotNull(indexMergerV9, "Null IndexMergerV9");
this.indexIO = Preconditions.checkNotNull(indexIO, "Null IndexIO"); this.indexIO = Preconditions.checkNotNull(indexIO, "Null IndexIO");
this.cache = cache; this.cache = cache;
this.cacheConfig = cacheConfig; this.cacheConfig = cacheConfig;
@ -118,7 +123,7 @@ public class FlushingPlumberSchool extends RealtimePlumberSchool
conglomerate, conglomerate,
segmentAnnouncer, segmentAnnouncer,
queryExecutorService, queryExecutorService,
indexMerger, config.getBuildV9Directly() ? indexMergerV9 : indexMerger,
indexIO, indexIO,
cache, cache,
cacheConfig, cacheConfig,

View File

@ -30,6 +30,7 @@ import io.druid.guice.annotations.Processing;
import io.druid.query.QueryRunnerFactoryConglomerate; import io.druid.query.QueryRunnerFactoryConglomerate;
import io.druid.segment.IndexIO; import io.druid.segment.IndexIO;
import io.druid.segment.IndexMerger; import io.druid.segment.IndexMerger;
import io.druid.segment.IndexMergerV9;
import io.druid.segment.indexing.DataSchema; import io.druid.segment.indexing.DataSchema;
import io.druid.segment.indexing.RealtimeTuningConfig; import io.druid.segment.indexing.RealtimeTuningConfig;
import io.druid.segment.loading.DataSegmentPusher; import io.druid.segment.loading.DataSegmentPusher;
@ -51,6 +52,7 @@ public class RealtimePlumberSchool implements PlumberSchool
private final SegmentHandoffNotifierFactory handoffNotifierFactory; private final SegmentHandoffNotifierFactory handoffNotifierFactory;
private final ExecutorService queryExecutorService; private final ExecutorService queryExecutorService;
private final IndexMerger indexMerger; private final IndexMerger indexMerger;
private final IndexMergerV9 indexMergerV9;
private final IndexIO indexIO; private final IndexIO indexIO;
private final Cache cache; private final Cache cache;
private final CacheConfig cacheConfig; private final CacheConfig cacheConfig;
@ -66,6 +68,7 @@ public class RealtimePlumberSchool implements PlumberSchool
@JacksonInject SegmentHandoffNotifierFactory handoffNotifierFactory, @JacksonInject SegmentHandoffNotifierFactory handoffNotifierFactory,
@JacksonInject @Processing ExecutorService executorService, @JacksonInject @Processing ExecutorService executorService,
@JacksonInject IndexMerger indexMerger, @JacksonInject IndexMerger indexMerger,
@JacksonInject IndexMergerV9 indexMergerV9,
@JacksonInject IndexIO indexIO, @JacksonInject IndexIO indexIO,
@JacksonInject Cache cache, @JacksonInject Cache cache,
@JacksonInject CacheConfig cacheConfig, @JacksonInject CacheConfig cacheConfig,
@ -80,6 +83,7 @@ public class RealtimePlumberSchool implements PlumberSchool
this.handoffNotifierFactory = handoffNotifierFactory; this.handoffNotifierFactory = handoffNotifierFactory;
this.queryExecutorService = executorService; this.queryExecutorService = executorService;
this.indexMerger = Preconditions.checkNotNull(indexMerger, "Null IndexMerger"); this.indexMerger = Preconditions.checkNotNull(indexMerger, "Null IndexMerger");
this.indexMergerV9 = Preconditions.checkNotNull(indexMergerV9, "Null IndexMergerV9");
this.indexIO = Preconditions.checkNotNull(indexIO, "Null IndexIO"); this.indexIO = Preconditions.checkNotNull(indexIO, "Null IndexIO");
this.cache = cache; this.cache = cache;
@ -107,7 +111,7 @@ public class RealtimePlumberSchool implements PlumberSchool
dataSegmentPusher, dataSegmentPusher,
segmentPublisher, segmentPublisher,
handoffNotifierFactory.createSegmentHandoffNotifier(schema.getDataSource()), handoffNotifierFactory.createSegmentHandoffNotifier(schema.getDataSource()),
indexMerger, config.getBuildV9Directly() ? indexMergerV9 : indexMerger,
indexIO, indexIO,
cache, cache,
cacheConfig, cacheConfig,

View File

@ -107,6 +107,7 @@ public class FireDepartmentTest
null, null,
null, null,
TestHelper.getTestIndexMerger(), TestHelper.getTestIndexMerger(),
TestHelper.getTestIndexMergerV9(),
TestHelper.getTestIndexIO(), TestHelper.getTestIndexIO(),
MapCache.create(0), MapCache.create(0),
NO_CACHE_CONFIG, NO_CACHE_CONFIG,

View File

@ -68,7 +68,6 @@ import org.junit.runners.Parameterized;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -82,6 +81,7 @@ import java.util.concurrent.atomic.AtomicBoolean;
public class RealtimePlumberSchoolTest public class RealtimePlumberSchoolTest
{ {
private final RejectionPolicyFactory rejectionPolicy; private final RejectionPolicyFactory rejectionPolicy;
private final boolean buildV9Directly;
private RealtimePlumber plumber; private RealtimePlumber plumber;
private RealtimePlumberSchool realtimePlumberSchool; private RealtimePlumberSchool realtimePlumberSchool;
private DataSegmentAnnouncer announcer; private DataSegmentAnnouncer announcer;
@ -95,24 +95,28 @@ public class RealtimePlumberSchoolTest
private DataSchema schema2; private DataSchema schema2;
private FireDepartmentMetrics metrics; private FireDepartmentMetrics metrics;
public RealtimePlumberSchoolTest(RejectionPolicyFactory rejectionPolicy) public RealtimePlumberSchoolTest(RejectionPolicyFactory rejectionPolicy, boolean buildV9Directly)
{ {
this.rejectionPolicy = rejectionPolicy; this.rejectionPolicy = rejectionPolicy;
this.buildV9Directly = buildV9Directly;
} }
@Parameterized.Parameters @Parameterized.Parameters(name = "rejectionPolicy = {0}, buildV9Directly = {1}")
public static Collection<?> constructorFeeder() throws IOException public static Collection<?> constructorFeeder() throws IOException
{ {
return Arrays.asList( final RejectionPolicyFactory[] rejectionPolicies = new RejectionPolicyFactory[]{
new Object[][]{ new NoopRejectionPolicyFactory(),
{
new NoopRejectionPolicyFactory()
},
{
new MessageTimeRejectionPolicyFactory() new MessageTimeRejectionPolicyFactory()
};
final boolean[] buildV9Directlies = new boolean[]{true, false};
final List<Object[]> constructors = Lists.newArrayList();
for (RejectionPolicyFactory rejectionPolicy : rejectionPolicies) {
for (boolean buildV9Directly : buildV9Directlies) {
constructors.add(new Object[]{rejectionPolicy, buildV9Directly});
} }
} }
); return constructors;
} }
@Before @Before
@ -163,7 +167,9 @@ public class RealtimePlumberSchoolTest
dataSegmentPusher = EasyMock.createNiceMock(DataSegmentPusher.class); dataSegmentPusher = EasyMock.createNiceMock(DataSegmentPusher.class);
handoffNotifierFactory = EasyMock.createNiceMock(SegmentHandoffNotifierFactory.class); handoffNotifierFactory = EasyMock.createNiceMock(SegmentHandoffNotifierFactory.class);
handoffNotifier = EasyMock.createNiceMock(SegmentHandoffNotifier.class); handoffNotifier = EasyMock.createNiceMock(SegmentHandoffNotifier.class);
EasyMock.expect(handoffNotifierFactory.createSegmentHandoffNotifier(EasyMock.anyString())).andReturn(handoffNotifier).anyTimes(); EasyMock.expect(handoffNotifierFactory.createSegmentHandoffNotifier(EasyMock.anyString()))
.andReturn(handoffNotifier)
.anyTimes();
EasyMock.expect( EasyMock.expect(
handoffNotifier.registerSegmentHandoffCallback( handoffNotifier.registerSegmentHandoffCallback(
EasyMock.<SegmentDescriptor>anyObject(), EasyMock.<SegmentDescriptor>anyObject(),
@ -186,7 +192,7 @@ public class RealtimePlumberSchoolTest
null, null,
null, null,
null, null,
null buildV9Directly
); );
realtimePlumberSchool = new RealtimePlumberSchool( realtimePlumberSchool = new RealtimePlumberSchool(
@ -198,6 +204,7 @@ public class RealtimePlumberSchoolTest
handoffNotifierFactory, handoffNotifierFactory,
MoreExecutors.sameThreadExecutor(), MoreExecutors.sameThreadExecutor(),
TestHelper.getTestIndexMerger(), TestHelper.getTestIndexMerger(),
TestHelper.getTestIndexMergerV9(),
TestHelper.getTestIndexIO(), TestHelper.getTestIndexIO(),
MapCache.create(0), MapCache.create(0),
FireDepartmentTest.NO_CACHE_CONFIG, FireDepartmentTest.NO_CACHE_CONFIG,