use of com.facebook.presto.operator.exchange.LocalExchange.LocalExchangeSinkFactoryId in project presto by prestodb.
the class TestLocalExchange method testGatherSingleWriter.
@Test(dataProvider = "executionStrategy")
public void testGatherSingleWriter(PipelineExecutionStrategy executionStrategy) {
LocalExchangeFactory localExchangeFactory = new LocalExchangeFactory(partitioningProviderManager, session, SINGLE_DISTRIBUTION, 8, TYPES, ImmutableList.of(), Optional.empty(), executionStrategy, new DataSize(retainedSizeOfPages(99), BYTE));
LocalExchangeSinkFactoryId localExchangeSinkFactoryId = localExchangeFactory.newSinkFactoryId();
localExchangeFactory.noMoreSinkFactories();
run(localExchangeFactory, executionStrategy, exchange -> {
assertEquals(exchange.getBufferCount(), 1);
assertExchangeTotalBufferedBytes(exchange, 0);
LocalExchangeSinkFactory sinkFactory = exchange.getSinkFactory(localExchangeSinkFactoryId);
LocalExchangeSource source = exchange.getSource(0);
assertSource(source, 0);
LocalExchangeSink sink = sinkFactory.createSink();
sinkFactory.close();
sinkFactory.noMoreSinkFactories();
assertSinkCanWrite(sink);
assertSource(source, 0);
// add the first page which should cause the reader to unblock
ListenableFuture<?> readFuture = source.waitForReading();
assertFalse(readFuture.isDone());
sink.addPage(createPage(0));
assertTrue(readFuture.isDone());
assertExchangeTotalBufferedBytes(exchange, 1);
assertSource(source, 1);
sink.addPage(createPage(1));
assertSource(source, 2);
assertExchangeTotalBufferedBytes(exchange, 2);
assertRemovePage(source, createPage(0));
assertSource(source, 1);
assertExchangeTotalBufferedBytes(exchange, 1);
assertRemovePage(source, createPage(1));
assertSource(source, 0);
assertExchangeTotalBufferedBytes(exchange, 0);
sink.addPage(createPage(2));
sink.addPage(createPage(3));
assertSource(source, 2);
assertExchangeTotalBufferedBytes(exchange, 2);
sink.finish();
assertSinkFinished(sink);
assertSource(source, 2);
assertRemovePage(source, createPage(2));
assertSource(source, 1);
assertSinkFinished(sink);
assertExchangeTotalBufferedBytes(exchange, 1);
assertRemovePage(source, createPage(3));
assertSourceFinished(source);
assertExchangeTotalBufferedBytes(exchange, 0);
});
}
use of com.facebook.presto.operator.exchange.LocalExchange.LocalExchangeSinkFactoryId in project presto by prestodb.
the class TestLocalExchange method testPartition.
@Test(dataProvider = "executionStrategy")
public void testPartition(PipelineExecutionStrategy executionStrategy) {
LocalExchangeFactory localExchangeFactory = new LocalExchangeFactory(partitioningProviderManager, session, FIXED_HASH_DISTRIBUTION, 2, TYPES, ImmutableList.of(0), Optional.empty(), executionStrategy, LOCAL_EXCHANGE_MAX_BUFFERED_BYTES);
LocalExchangeSinkFactoryId localExchangeSinkFactoryId = localExchangeFactory.newSinkFactoryId();
localExchangeFactory.noMoreSinkFactories();
run(localExchangeFactory, executionStrategy, exchange -> {
assertEquals(exchange.getBufferCount(), 2);
assertExchangeTotalBufferedBytes(exchange, 0);
LocalExchangeSinkFactory sinkFactory = exchange.getSinkFactory(localExchangeSinkFactoryId);
LocalExchangeSink sink = sinkFactory.createSink();
assertSinkCanWrite(sink);
sinkFactory.close();
sinkFactory.noMoreSinkFactories();
LocalExchangeSource sourceA = exchange.getSource(0);
assertSource(sourceA, 0);
LocalExchangeSource sourceB = exchange.getSource(1);
assertSource(sourceB, 0);
sink.addPage(createPage(0));
assertSource(sourceA, 1);
assertSource(sourceB, 1);
assertTrue(exchange.getBufferedBytes() >= retainedSizeOfPages(1));
sink.addPage(createPage(0));
assertSource(sourceA, 2);
assertSource(sourceB, 2);
assertTrue(exchange.getBufferedBytes() >= retainedSizeOfPages(2));
assertPartitionedRemovePage(sourceA, 0, 2);
assertSource(sourceA, 1);
assertSource(sourceB, 2);
assertPartitionedRemovePage(sourceA, 0, 2);
assertSource(sourceA, 0);
assertSource(sourceB, 2);
sink.finish();
assertSinkFinished(sink);
assertSourceFinished(sourceA);
assertSource(sourceB, 2);
assertPartitionedRemovePage(sourceB, 1, 2);
assertSourceFinished(sourceA);
assertSource(sourceB, 1);
assertPartitionedRemovePage(sourceB, 1, 2);
assertSourceFinished(sourceA);
assertSourceFinished(sourceB);
assertExchangeTotalBufferedBytes(exchange, 0);
});
}
use of com.facebook.presto.operator.exchange.LocalExchange.LocalExchangeSinkFactoryId in project presto by prestodb.
the class TestLocalExchange method writeUnblockWhenAllReadersFinish.
@Test(dataProvider = "executionStrategy")
public void writeUnblockWhenAllReadersFinish(PipelineExecutionStrategy executionStrategy) {
ImmutableList<Type> types = ImmutableList.of(BIGINT);
LocalExchangeFactory localExchangeFactory = new LocalExchangeFactory(partitioningProviderManager, session, FIXED_BROADCAST_DISTRIBUTION, 2, types, ImmutableList.of(), Optional.empty(), executionStrategy, LOCAL_EXCHANGE_MAX_BUFFERED_BYTES);
LocalExchangeSinkFactoryId localExchangeSinkFactoryId = localExchangeFactory.newSinkFactoryId();
localExchangeFactory.noMoreSinkFactories();
run(localExchangeFactory, executionStrategy, exchange -> {
assertEquals(exchange.getBufferCount(), 2);
assertExchangeTotalBufferedBytes(exchange, 0);
LocalExchangeSinkFactory sinkFactory = exchange.getSinkFactory(localExchangeSinkFactoryId);
LocalExchangeSink sinkA = sinkFactory.createSink();
assertSinkCanWrite(sinkA);
LocalExchangeSink sinkB = sinkFactory.createSink();
assertSinkCanWrite(sinkB);
sinkFactory.close();
sinkFactory.noMoreSinkFactories();
LocalExchangeSource sourceA = exchange.getSource(0);
assertSource(sourceA, 0);
LocalExchangeSource sourceB = exchange.getSource(1);
assertSource(sourceB, 0);
sourceA.finish();
assertSourceFinished(sourceA);
assertSinkCanWrite(sinkA);
assertSinkCanWrite(sinkB);
sourceB.finish();
assertSourceFinished(sourceB);
assertSinkFinished(sinkA);
assertSinkFinished(sinkB);
});
}
Aggregations