blob: 9bc7f78ca745cd2a18e145f5b4650ccb60d3232b [file] [log] [blame]
/*
* Copyright (c) 2015 DataTorrent, Inc. ALL Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.datatorrent.lib.partitioner;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import org.junit.Assert;
import org.junit.Test;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.datatorrent.api.*;
import com.datatorrent.lib.util.TestUtils;
/**
* Test for {@link StatelessLatencyBasedPartitioner}
*/
public class StatelessLatencyBasedPartitionerTest
{
public static class DummyOperator implements Operator
{
public final DefaultOutputPort<Integer> output = new DefaultOutputPort<Integer>();
public final DefaultInputPort<Integer> input = new DefaultInputPort<Integer>()
{
@Override
public void process(Integer tuple)
{
}
};
private Integer value;
public DummyOperator()
{
}
public DummyOperator(Integer value)
{
this.value = value;
}
@Override
public void beginWindow(long windowId)
{
//Do nothing
}
@Override
public void endWindow()
{
//Do nothing
}
@Override
public void setup(Context.OperatorContext context)
{
//Do nothing
}
@Override
public void teardown()
{
//Do nothing
}
public void setValue(int value)
{
this.value = value;
}
public int getValue()
{
return value;
}
}
@Test
public void testPartitioner() throws Exception
{
DummyOperator dummyOperator = new DummyOperator(5);
StatelessLatencyBasedPartitioner<DummyOperator> statelessLatencyBasedPartitioner = new StatelessLatencyBasedPartitioner<DummyOperator>();
statelessLatencyBasedPartitioner.setMaximumLatency(10);
statelessLatencyBasedPartitioner.setMinimumLatency(1);
statelessLatencyBasedPartitioner.setCooldownMillis(10);
TestUtils.MockBatchedOperatorStats mockStats = new TestUtils.MockBatchedOperatorStats(2);
mockStats.operatorStats = Lists.newArrayList();
mockStats.latency = 11;
List<Operator.InputPort<?>> ports = Lists.newArrayList();
ports.add(dummyOperator.input);
DefaultPartition<DummyOperator> defaultPartition = new DefaultPartition<DummyOperator>(dummyOperator);
Collection<Partitioner.Partition<DummyOperator>> partitions = Lists.newArrayList();
partitions.add(defaultPartition);
partitions = statelessLatencyBasedPartitioner.definePartitions(partitions, new StatelessPartitionerTest.PartitioningContextImpl(ports, 1));
Assert.assertTrue(1 == partitions.size());
defaultPartition = (DefaultPartition<DummyOperator>) partitions.iterator().next();
Map<Integer, Partitioner.Partition<DummyOperator>> partitionerMap = Maps.newHashMap();
partitionerMap.put(2, defaultPartition);
statelessLatencyBasedPartitioner.partitioned(partitionerMap);
StatsListener.Response response = statelessLatencyBasedPartitioner.processStats(mockStats);
Assert.assertEquals("repartition is false", false, response.repartitionRequired);
Thread.sleep(100);
response = statelessLatencyBasedPartitioner.processStats(mockStats);
Assert.assertEquals("repartition is true", true, response.repartitionRequired);
TestUtils.MockPartition<DummyOperator> mockPartition = new TestUtils.MockPartition<DummyOperator>(defaultPartition, mockStats);
partitions.clear();
partitions.add(mockPartition);
Collection<Partitioner.Partition<DummyOperator>> newPartitions = statelessLatencyBasedPartitioner.definePartitions(partitions,
new StatelessPartitionerTest.PartitioningContextImpl(ports, 5));
Assert.assertEquals("after partition", 2, newPartitions.size());
}
}