BraveTracingTest.java
/**
* 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.cxf.systest.microprofile.rest.client.tracing.brave;
import java.net.URI;
import brave.ScopedSpan;
import brave.Tracing;
import brave.sampler.Sampler;
import org.apache.cxf.Bus;
import org.apache.cxf.jaxrs.JAXRSServerFactoryBean;
import org.apache.cxf.jaxrs.lifecycle.SingletonResourceProvider;
import org.apache.cxf.jaxrs.model.AbstractResourceInfo;
import org.apache.cxf.systest.microprofile.rest.client.tracing.BookRestClient;
import org.apache.cxf.systest.microprofile.rest.client.tracing.BookStore;
import org.apache.cxf.testutil.common.AbstractClientServerTestBase;
import org.apache.cxf.testutil.common.AbstractServerTestServerBase;
import org.apache.cxf.tracing.brave.TraceScope;
import org.apache.cxf.tracing.brave.jaxrs.BraveClientProvider;
import org.apache.cxf.tracing.brave.jaxrs.BraveFeature;
import org.apache.cxf.transport.http.asyncclient.AsyncHTTPConduit;
import org.eclipse.microprofile.rest.client.RestClientBuilder;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.collection.IsCollectionWithSize.hasSize;
import static org.junit.Assert.assertTrue;
public class BraveTracingTest extends AbstractClientServerTestBase {
public static final String PORT = allocatePort(BraveTracingTest.class);
private Tracing brave;
private BraveClientProvider braveClientProvider;
public static class Server extends AbstractServerTestServerBase {
@Override
protected org.apache.cxf.endpoint.Server createServer(Bus bus) throws Exception {
final Tracing brave = Tracing
.newBuilder()
.addSpanHandler(new TestSpanHandler())
.sampler(Sampler.ALWAYS_SAMPLE)
.build();
final JAXRSServerFactoryBean sf = new JAXRSServerFactoryBean();
sf.setResourceClasses(BookStore.class);
sf.setResourceProvider(BookStore.class, new SingletonResourceProvider(new BookStore<TraceScope>()));
sf.setAddress("http://localhost:" + PORT);
sf.setProvider(new BraveFeature(brave));
return sf.create();
}
}
@BeforeClass
public static void startServers() throws Exception {
AbstractResourceInfo.clearAllMaps();
//keep out of process due to stack traces testing failures
assertTrue("server did not launch correctly", launchServer(Server.class, true));
}
@Before
public void setUp() {
TestSpanHandler.clear();
brave = Tracing
.newBuilder()
.addSpanHandler(new TestSpanHandler())
.sampler(Sampler.ALWAYS_SAMPLE)
.build();
braveClientProvider = new BraveClientProvider(brave);
}
@Test
public void testThatNewSpanIsCreatedWhenNotProvided() {
final BookRestClient client = createRestClient();
assertThat(client.getBooks(), hasSize(2));
assertThat(TestSpanHandler.getAllSpans().size(),
equalTo(3));
assertThat(TestSpanHandler.getAllSpans().get(0).name(),
equalTo("get books"));
assertThat(TestSpanHandler.getAllSpans().get(1).name(),
equalTo("GET /bookstore/books"));
assertThat(TestSpanHandler.getAllSpans().get(2).name(),
equalTo("GET http://localhost:" + PORT + "/bookstore/books"));
}
@Test
public void testThatNewSpanIsCreatedWhenNotProvidedWithAsyncConduit() {
final BookRestClient client = createAsyncRestClient();
assertThat(client.getBooks(), hasSize(2));
assertThat(TestSpanHandler.getAllSpans().size(),
equalTo(3));
assertThat(TestSpanHandler.getAllSpans().get(0).name(),
equalTo("get books"));
assertThat(TestSpanHandler.getAllSpans().get(1).name(),
equalTo("GET /bookstore/books"));
assertThat(TestSpanHandler.getAllSpans().get(2).name(),
equalTo("GET http://localhost:" + PORT + "/bookstore/books"));
}
@Test
public void testThatNewInnerSpanIsCreated() {
final ScopedSpan span = brave.tracer().startScopedSpan("calling book service");
try {
final BookRestClient client = createRestClient();
assertThat(client.getBooks(), hasSize(2));
} finally {
span.finish();
}
assertThat(TestSpanHandler.getAllSpans().size(),
equalTo(4));
assertThat(TestSpanHandler.getAllSpans().get(0).name(),
equalTo("get books"));
assertThat(TestSpanHandler.getAllSpans().get(1).name(),
equalTo("GET /bookstore/books"));
assertThat(TestSpanHandler.getAllSpans().get(2).name(),
equalTo("GET http://localhost:" + PORT + "/bookstore/books"));
assertThat(TestSpanHandler.getAllSpans().get(3).name(),
equalTo("calling book service"));
}
@Test
public void testThatNewInnerSpanIsCreatedWithAsyncConduit() {
final ScopedSpan span = brave.tracer().startScopedSpan("calling book service");
try {
final BookRestClient client = createAsyncRestClient();
assertThat(client.getBooks(), hasSize(2));
} finally {
span.finish();
}
assertThat(TestSpanHandler.getAllSpans().size(),
equalTo(4));
assertThat(TestSpanHandler.getAllSpans().get(0).name(),
equalTo("get books"));
assertThat(TestSpanHandler.getAllSpans().get(1).name(),
equalTo("GET /bookstore/books"));
assertThat(TestSpanHandler.getAllSpans().get(2).name(),
equalTo("GET http://localhost:" + PORT + "/bookstore/books"));
assertThat(TestSpanHandler.getAllSpans().get(3).name(),
equalTo("calling book service"));
}
private BookRestClient createAsyncRestClient() {
return createRestClientBuilder()
.property(AsyncHTTPConduit.USE_ASYNC, Boolean.TRUE)
.build(BookRestClient.class);
}
private BookRestClient createRestClient() {
return createRestClientBuilder()
.build(BookRestClient.class);
}
private RestClientBuilder createRestClientBuilder() {
return RestClientBuilder.newBuilder()
.baseUri(URI.create("http://localhost:" + PORT))
.register(braveClientProvider);
}
}