/** * 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.camel.example.cdi.metrics; import javax.inject.Inject; import com.codahale.metrics.Gauge; import com.codahale.metrics.Meter; import com.codahale.metrics.annotation.Metric; import org.apache.camel.CamelContext; import org.apache.camel.test.cdi.CamelCdiRunner; import org.apache.camel.test.cdi.Order; import org.junit.Test; import org.junit.runner.RunWith; import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.is; import static org.junit.Assert.assertThat; @RunWith(CamelCdiRunner.class) public class CdiMetricsTest { @Inject private Meter generated; @Inject private Meter attempt; @Inject private Meter success; @Inject private Meter redelivery; @Inject private Meter error; @Inject @Metric(name = "success-ratio") private Gauge<Double> ratio; @Test @Order(1) public void stopCamelContext(CamelContext context) throws Exception { // Wait a while so that the timer can kick in Thread.sleep(5000); // And stop the Camel context so that inflight exchanges get completed context.stop(); } @Test @Order(2) public void testMetricsValues() { assertThat("Meter counts are not consistent!", attempt.getCount() - redelivery.getCount() - success.getCount() - error.getCount(), is(equalTo(0L))); assertThat("Success rate gauge value is incorrect!", ratio.getValue(), is(equalTo(success.getOneMinuteRate() / generated.getOneMinuteRate()))); } }