assertEquals(basicCounterVal, (1 / 3.0) * rates[3]);
}
@Test
public void testExpiration() {
BasicCounter c1 = new BasicCounter(MonitorConfig.builder("c1").build());
BasicCounter c2 = new BasicCounter(MonitorConfig.builder("c2").build());
BasicCounter c3 = new BasicCounter(MonitorConfig.builder("c3").build());
ManualClock manualClock = new ManualClock(0);
MemoryMetricObserver observer = new MemoryMetricObserver("normalization-test", 1);
NormalizationTransform normalizationTransform = new NormalizationTransform(observer, 60,
120, TimeUnit.SECONDS, manualClock);
CounterToRateMetricTransform toRateMetricTransform =
new CounterToRateMetricTransform(normalizationTransform, 60,
120, TimeUnit.SECONDS, manualClock);
manualClock.set(30000L);
c1.increment();
Metric m1 = new Metric(c1.getConfig(), manualClock.now(), c1.getValue(0));
toRateMetricTransform.update(ImmutableList.of(m1));
assertEquals(NormalizationTransform.HEARTBEAT_EXCEEDED.getValue(0).longValue(), 0);
List<Metric> o = observer.getObservations().get(0);
assertEquals(o.size(), 1);
manualClock.set(100000L);
Metric m2 = new Metric(c2.getConfig(), manualClock.now(), c2.getValue());
toRateMetricTransform.update(ImmutableList.of(m2));
assertEquals(NormalizationTransform.HEARTBEAT_EXCEEDED.getValue(0).longValue(), 0);
manualClock.set(160000L);
Metric m3 = new Metric(c3.getConfig(), manualClock.now(), c3.getValue());
toRateMetricTransform.update(ImmutableList.of(m3));
assertEquals(NormalizationTransform.HEARTBEAT_EXCEEDED.getValue(0).longValue(), 1);
}