/** * 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.opentracing.decorators; import io.opentracing.mock.MockSpan; import io.opentracing.mock.MockTracer; import org.apache.camel.Endpoint; import org.apache.camel.Exchange; import org.apache.camel.Message; import org.apache.camel.opentracing.SpanDecorator; import org.junit.Test; import org.mockito.Mockito; import static org.junit.Assert.assertEquals; public class KafkaSpanDecoratorTest { @Test public void testGetDestinationHeaderTopic() { Exchange exchange = Mockito.mock(Exchange.class); Message message = Mockito.mock(Message.class); Mockito.when(exchange.getIn()).thenReturn(message); Mockito.when(message.getHeader(KafkaSpanDecorator.TOPIC)).thenReturn("test"); KafkaSpanDecorator decorator = new KafkaSpanDecorator(); assertEquals("test", decorator.getDestination(exchange, null)); } @Test public void testGetDestinationNoHeaderTopic() { Exchange exchange = Mockito.mock(Exchange.class); Message message = Mockito.mock(Message.class); Endpoint endpoint = Mockito.mock(Endpoint.class); Mockito.when(exchange.getIn()).thenReturn(message); Mockito.when(endpoint.getEndpointUri()) .thenReturn("kafka:localhost:9092?topic=test&groupId=testing&consumersCount=1"); KafkaSpanDecorator decorator = new KafkaSpanDecorator(); assertEquals("test", decorator.getDestination(exchange, endpoint)); } @Test public void testPre() { String testKey = "TestKey"; String testOffset = "TestOffset"; String testPartition = "TestPartition"; String testPartitionKey = "TestPartitionKey"; Endpoint endpoint = Mockito.mock(Endpoint.class); Exchange exchange = Mockito.mock(Exchange.class); Message message = Mockito.mock(Message.class); Mockito.when(endpoint.getEndpointUri()).thenReturn("test"); Mockito.when(exchange.getIn()).thenReturn(message); Mockito.when(message.getHeader(KafkaSpanDecorator.KEY)).thenReturn(testKey); Mockito.when(message.getHeader(KafkaSpanDecorator.OFFSET)).thenReturn(testOffset); Mockito.when(message.getHeader(KafkaSpanDecorator.PARTITION)).thenReturn(testPartition); Mockito.when(message.getHeader(KafkaSpanDecorator.PARTITION_KEY)).thenReturn(testPartitionKey); SpanDecorator decorator = new KafkaSpanDecorator(); MockTracer tracer = new MockTracer(); MockSpan span = tracer.buildSpan("TestSpan").start(); decorator.pre(span, exchange, endpoint); assertEquals(testKey, span.tags().get(KafkaSpanDecorator.KAFKA_KEY_TAG)); assertEquals(testOffset, span.tags().get(KafkaSpanDecorator.KAFKA_OFFSET_TAG)); assertEquals(testPartition, span.tags().get(KafkaSpanDecorator.KAFKA_PARTITION_TAG)); assertEquals(testPartitionKey, span.tags().get(KafkaSpanDecorator.KAFKA_PARTITION_KEY_TAG)); } }