blob: 898626c575465064af7e7ef9f88b8c43ca19e64e [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.sling.metrics.internal;
import java.util.concurrent.TimeUnit;
import com.codahale.metrics.Counter;
import com.codahale.metrics.ExponentiallyDecayingReservoir;
import com.codahale.metrics.Histogram;
import com.codahale.metrics.Meter;
import com.codahale.metrics.MetricRegistry;
import com.codahale.metrics.Timer;
import org.junit.Test;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertSame;
public class MetricWrapperTest {
private MetricRegistry registry = new MetricRegistry();
@Test
public void counter() throws Exception {
Counter counter = registry.counter("test");
CounterImpl counterStats = new CounterImpl(counter);
counterStats.inc();
assertEquals(1, counterStats.getCount());
assertEquals(1, counter.getCount());
assertEquals(1, counterStats.getCount());
counterStats.inc();
counterStats.inc();
assertEquals(3, counterStats.getCount());
counterStats.dec();
assertEquals(2, counterStats.getCount());
assertEquals(2, counter.getCount());
counterStats.inc(7);
assertEquals(9, counterStats.getCount());
assertEquals(9, counter.getCount());
counterStats.dec(5);
assertEquals(4, counterStats.getCount());
assertEquals(4, counter.getCount());
assertSame(counter, counterStats.adaptTo(Counter.class));
}
@Test
public void meter() throws Exception {
Meter meter = registry.meter("test");
MeterImpl meterStats = new MeterImpl(meter);
meterStats.mark();
assertEquals(1, meterStats.getCount());
assertEquals(1, meter.getCount());
meterStats.mark(5);
assertEquals(6, meterStats.getCount());
assertEquals(6, meter.getCount());
assertSame(meter, meterStats.adaptTo(Meter.class));
}
@Test
public void timer() throws Exception {
Timer time = registry.timer("test");
TimerImpl timerStats = new TimerImpl(time);
timerStats.update(100, TimeUnit.SECONDS);
assertEquals(1, time.getCount());
assertEquals(TimeUnit.SECONDS.toNanos(100), time.getSnapshot().getMax());
timerStats.update(100, TimeUnit.SECONDS);
assertEquals(2, timerStats.getCount());
assertSame(time, timerStats.adaptTo(Timer.class));
}
@Test
public void histogram() throws Exception {
Histogram histo = registry.histogram("test");
HistogramImpl histoStats = new HistogramImpl(histo);
histoStats.update(100);
assertEquals(1, histo.getCount());
assertEquals(1, histoStats.getCount());
assertEquals(100, histo.getSnapshot().getMax());
assertSame(histo, histoStats.adaptTo(Histogram.class));
}
@Test
public void timerContext() throws Exception{
VirtualClock clock = new VirtualClock();
Timer time = new Timer(new ExponentiallyDecayingReservoir(), clock);
TimerImpl timerStats = new TimerImpl(time);
org.apache.sling.metrics.Timer.Context context = timerStats.time();
clock.tick = TimeUnit.SECONDS.toNanos(314);
context.close();
assertEquals(1, time.getCount());
assertEquals(TimeUnit.SECONDS.toNanos(314), time.getSnapshot().getMax());
}
private static class VirtualClock extends com.codahale.metrics.Clock {
long tick;
@Override
public long getTick() {
return tick;
}
}
}