/*
* Copyright (C) 2012-2015 DataStax Inc.
*
* 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.datastax.driver.core;
import com.datastax.driver.core.exceptions.ReadTimeoutException;
import com.google.common.collect.Lists;
import com.google.common.util.concurrent.Uninterruptibles;
import org.testng.annotations.Test;
import java.util.List;
import java.util.concurrent.TimeUnit;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.mock;
public class ClusterWidePercentileTrackerTest
extends PercentileTrackerTest<ClusterWidePercentileTracker.Builder, ClusterWidePercentileTracker> {
@Test(groups = "unit")
public void should_track_all_measurements_for_cluster() {
// given - a cluster wide percentile tracker.
Cluster cluster0 = mock(Cluster.class);
ClusterWidePercentileTracker tracker = builder()
.withInterval(1, TimeUnit.SECONDS)
.withMinRecordedValues(100).build();
tracker.onRegister(cluster0);
List<Host> hosts = Lists.newArrayList(mock(Host.class), mock(Host.class), mock(Host.class));
List<Statement> statements = Lists.newArrayList(mock(Statement.class), mock(Statement.class));
List<Exception> exceptions = Lists.newArrayList(new Exception(), null, new ReadTimeoutException(ConsistencyLevel.ANY, 1, 1, true), null, null);
// when - recording latencies over a linear progression with varying hosts, statements and exceptions.
for (int i = 0; i < 100; i++) {
tracker.update(
hosts.get(i % hosts.size()),
statements.get(i % statements.size()),
exceptions.get(i % exceptions.size()), TimeUnit.NANOSECONDS.convert(i + 1, TimeUnit.MILLISECONDS));
}
Uninterruptibles.sleepUninterruptibly(2, TimeUnit.SECONDS);
// then - the resulting tracker's percentiles should represent that linear progression. (x percentile == x)
for (int i = 1; i <= 99; i++) {
long latencyAtPct = tracker.getLatencyAtPercentile(null, null, null, i);
assertThat(latencyAtPct).isEqualTo(i);
}
}
@Override
public ClusterWidePercentileTracker.Builder builder() {
return ClusterWidePercentileTracker.builder(defaultMaxLatency);
}
}