Merge pull request #1080 from metamx/fix-cost-balancer-strategy

fix integer value overflow and add test
This commit is contained in:
Xavier Léauté 2015-02-03 11:45:03 -08:00
commit ffb180e29d
2 changed files with 39 additions and 5 deletions

View File

@ -35,9 +35,9 @@ import java.util.concurrent.Executors;
public class CostBalancerStrategy implements BalancerStrategy public class CostBalancerStrategy implements BalancerStrategy
{ {
private static final EmittingLogger log = new EmittingLogger(CostBalancerStrategy.class); private static final EmittingLogger log = new EmittingLogger(CostBalancerStrategy.class);
private static final int DAY_IN_MILLIS = 1000 * 60 * 60 * 24; private static final long DAY_IN_MILLIS = 1000 * 60 * 60 * 24;
private static final int SEVEN_DAYS_IN_MILLIS = 7 * DAY_IN_MILLIS; private static final long SEVEN_DAYS_IN_MILLIS = 7 * DAY_IN_MILLIS;
private static final int THIRTY_DAYS_IN_MILLIS = 30 * DAY_IN_MILLIS; private static final long THIRTY_DAYS_IN_MILLIS = 30 * DAY_IN_MILLIS;
private final long referenceTimestamp; private final long referenceTimestamp;
private final int threadCount; private final int threadCount;

View File

@ -98,10 +98,15 @@ public class CostBalancerStrategyTest
* @return segment * @return segment
*/ */
private DataSegment getSegment(int index) private DataSegment getSegment(int index)
{
return getSegment(index, "DUMMY", day);
}
private DataSegment getSegment(int index, String dataSource, Interval interval)
{ {
// Not using EasyMock as it hampers the performance of multithreads. // Not using EasyMock as it hampers the performance of multithreads.
DataSegment segment = new DataSegment( DataSegment segment = new DataSegment(
"DUMMY", day, String.valueOf(index), Maps.<String, Object>newConcurrentMap(), dataSource, interval, String.valueOf(index), Maps.<String, Object>newConcurrentMap(),
Lists.<String>newArrayList(), Lists.<String>newArrayList(), null, 0, index * 100L Lists.<String>newArrayList(), Lists.<String>newArrayList(), null, 0, index * 100L
); );
return segment; return segment;
@ -133,7 +138,8 @@ public class CostBalancerStrategyTest
Assert.assertEquals("Best Server should be BEST_SERVER", "BEST_SERVER", holder.getServer().getName()); Assert.assertEquals("Best Server should be BEST_SERVER", "BEST_SERVER", holder.getServer().getName());
} }
@Test @Ignore @Test
@Ignore
public void testBenchmark() throws InterruptedException public void testBenchmark() throws InterruptedException
{ {
setupDummyCluster(100, 500); setupDummyCluster(100, 500);
@ -154,4 +160,32 @@ public class CostBalancerStrategyTest
System.err.println("Latency - Single Threaded (ms): " + latencySingleThread); System.err.println("Latency - Single Threaded (ms): " + latencySingleThread);
System.err.println("Latency - Multi Threaded (ms): " + latencyMultiThread); System.err.println("Latency - Multi Threaded (ms): " + latencyMultiThread);
} }
@Test
public void testComputeJointSegmentCost()
{
DateTime referenceTime = new DateTime("2014-01-01T00:00:00");
CostBalancerStrategy strategy = new CostBalancerStrategy(referenceTime, 4);
double segmentCost = strategy.computeJointSegmentCosts(
getSegment(
100,
"DUMMY",
new Interval(
referenceTime,
referenceTime.plusHours(1)
)
),
getSegment(
101,
"DUMMY",
new Interval(
referenceTime.minusDays(2),
referenceTime.minusDays(2).plusHours(1)
)
)
);
Assert.assertEquals(138028.62811791385d, segmentCost, 0);
}
} }