diff --git a/integration-tests/opentelemetry/pom.xml b/integration-tests/opentelemetry/pom.xml
index 81095d2c5719..863db7986aae 100644
--- a/integration-tests/opentelemetry/pom.xml
+++ b/integration-tests/opentelemetry/pom.xml
@@ -45,6 +45,10 @@
+
+ org.apache.camel.quarkus
+ camel-quarkus-direct
+
org.apache.camel.quarkus
camel-quarkus-opentelemetry
@@ -53,6 +57,10 @@
org.apache.camel.quarkus
camel-quarkus-platform-http
+
+ org.apache.camel.quarkus
+ camel-quarkus-timer
+
io.quarkus
quarkus-resteasy
@@ -79,6 +87,19 @@
+
+ org.apache.camel.quarkus
+ camel-quarkus-direct-deployment
+ ${project.version}
+ pom
+ test
+
+
+ *
+ *
+
+
+
org.apache.camel.quarkus
camel-quarkus-opentelemetry-deployment
@@ -105,6 +126,19 @@
+
+ org.apache.camel.quarkus
+ camel-quarkus-timer-deployment
+ ${project.version}
+ pom
+ test
+
+
+ *
+ *
+
+
+
diff --git a/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryResource.java b/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryResource.java
index 4525aab1b088..06e8bc2e92f6 100644
--- a/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryResource.java
+++ b/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryResource.java
@@ -16,50 +16,26 @@
*/
package org.apache.camel.quarkus.component.opentelemetry.it;
-import java.util.Map;
-
import javax.enterprise.context.ApplicationScoped;
import javax.inject.Inject;
-import javax.json.Json;
-import javax.json.JsonArray;
-import javax.json.JsonArrayBuilder;
-import javax.json.JsonObjectBuilder;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
-import io.opentelemetry.api.common.AttributeKey;
-import io.opentelemetry.sdk.testing.exporter.InMemorySpanExporter;
-import io.opentelemetry.sdk.trace.data.SpanData;
+import org.apache.camel.ProducerTemplate;
@Path("/opentelemetry")
@ApplicationScoped
public class OpenTelemetryResource {
@Inject
- InMemorySpanExporter exporter;
+ ProducerTemplate producerTemplate;
- @Path("/spans")
+ @Path("/trace")
@GET
- @Produces(MediaType.APPLICATION_JSON)
- public JsonArray getSpans() {
- JsonArrayBuilder arrayBuilder = Json.createArrayBuilder();
-
- for (SpanData span : exporter.getFinishedSpanItems()) {
-
- Map, Object> attributes = span.getAttributes().asMap();
- if (attributes.containsKey(AttributeKey.stringKey("component"))) {
- JsonObjectBuilder objectBuilder = Json.createObjectBuilder();
- objectBuilder.add("spanId", span.getSpanId());
- objectBuilder.add("traceId", span.getTraceId());
-
- attributes.forEach((k, v) -> objectBuilder.add(String.valueOf(k), v.toString()));
-
- arrayBuilder.add(objectBuilder.build());
- }
- }
-
- return arrayBuilder.build();
+ @Produces(MediaType.TEXT_PLAIN)
+ public String traceRoute() {
+ return producerTemplate.requestBody("direct:start", null, String.class);
}
}
diff --git a/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryRouteBuilder.java b/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryRouteBuilder.java
index 12a3a0e3cfe4..375b71f81e4f 100644
--- a/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryRouteBuilder.java
+++ b/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryRouteBuilder.java
@@ -29,5 +29,11 @@ public void configure() throws Exception {
from("platform-http:/opentelemetry/test/trace/filtered")
.setBody(constant("GET: /opentelemetry/test/trace/filtered"));
+
+ from("direct:start")
+ .setBody().constant("Traced direct:start");
+
+ from("timer:filtered?repeatCount=5&delay=-1")
+ .setBody().constant("Route filtered from tracing");
}
}
diff --git a/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/SpanExporterResource.java b/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/SpanExporterResource.java
new file mode 100644
index 000000000000..0fc85b465018
--- /dev/null
+++ b/integration-tests/opentelemetry/src/main/java/org/apache/camel/quarkus/component/opentelemetry/it/SpanExporterResource.java
@@ -0,0 +1,73 @@
+/*
+ * 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.quarkus.component.opentelemetry.it;
+
+import java.util.Map;
+
+import javax.inject.Inject;
+import javax.json.Json;
+import javax.json.JsonArray;
+import javax.json.JsonArrayBuilder;
+import javax.json.JsonObjectBuilder;
+import javax.ws.rs.GET;
+import javax.ws.rs.POST;
+import javax.ws.rs.Path;
+import javax.ws.rs.Produces;
+import javax.ws.rs.core.MediaType;
+
+import io.opentelemetry.api.common.AttributeKey;
+import io.opentelemetry.sdk.testing.exporter.InMemorySpanExporter;
+import io.opentelemetry.sdk.trace.data.SpanData;
+
+@Path("/opentelemetry/exporter")
+public class SpanExporterResource {
+
+ @Inject
+ InMemorySpanExporter exporter;
+
+ @Path("/spans")
+ @GET
+ @Produces(MediaType.APPLICATION_JSON)
+ public JsonArray getSpans() {
+ JsonArrayBuilder arrayBuilder = Json.createArrayBuilder();
+
+ for (SpanData span : exporter.getFinishedSpanItems()) {
+ if (span.getName().contains("exporter")) {
+ // Ignore any trace events on this resource
+ continue;
+ }
+
+ Map, Object> attributes = span.getAttributes().asMap();
+ JsonObjectBuilder objectBuilder = Json.createObjectBuilder();
+ objectBuilder.add("spanId", span.getSpanId());
+ objectBuilder.add("traceId", span.getTraceId());
+ objectBuilder.add("parentId", span.getParentSpanId());
+
+ attributes.forEach((k, v) -> objectBuilder.add(String.valueOf(k), v.toString()));
+
+ arrayBuilder.add(objectBuilder.build());
+ }
+
+ return arrayBuilder.build();
+ }
+
+ @POST
+ @Path("/spans/reset")
+ public void resetSpanExporter() {
+ exporter.reset();
+ }
+}
diff --git a/integration-tests/opentelemetry/src/main/resources/application.properties b/integration-tests/opentelemetry/src/main/resources/application.properties
index 0d36a0a6d096..e819cd6f00bd 100644
--- a/integration-tests/opentelemetry/src/main/resources/application.properties
+++ b/integration-tests/opentelemetry/src/main/resources/application.properties
@@ -15,4 +15,8 @@
## limitations under the License.
## ---------------------------------------------------------------------------
-quarkus.camel.opentelemetry.exclude-patterns = platform-http:/opentelemetry/test/trace/filtered
+# TODO: Reinstate this when platform-http route excludes are fixed
+# https://github.com/apache/camel-quarkus/issues/2897
+#quarkus.camel.opentelemetry.exclude-patterns = platform-http:/opentelemetry/test/trace/filtered
+
+quarkus.camel.opentelemetry.exclude-patterns = timer:filtered*
diff --git a/integration-tests/opentelemetry/src/test/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryTest.java b/integration-tests/opentelemetry/src/test/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryTest.java
index 3419a4c7f949..3e785567d59e 100644
--- a/integration-tests/opentelemetry/src/test/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryTest.java
+++ b/integration-tests/opentelemetry/src/test/java/org/apache/camel/quarkus/component/opentelemetry/it/OpenTelemetryTest.java
@@ -21,15 +21,23 @@
import io.quarkus.test.junit.QuarkusTest;
import io.restassured.RestAssured;
-import io.restassured.path.json.JsonPath;
+import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
+import static org.hamcrest.CoreMatchers.equalTo;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertTrue;
@QuarkusTest
class OpenTelemetryTest {
+ @AfterEach
+ public void afterEach() {
+ RestAssured.post("/opentelemetry/exporter/spans/reset")
+ .then()
+ .statusCode(204);
+ }
+
@Test
public void testTraceRoute() {
// Generate messages
@@ -40,21 +48,15 @@ public void testTraceRoute() {
// No spans should be recorded for this route as they are excluded by camel.opentelemetry.exclude-patterns in
// application.properties
- RestAssured.get("/opentelemetry/test/trace/filtered")
- .then()
- .statusCode(200);
+ // TODO: Reinstate this when platform-http route excludes are fixed. For now, a timer endpoint stands in for filter tests
+ // https://github.com/apache/camel-quarkus/issues/2897
+ // RestAssured.get("/opentelemetry/test/trace/filtered")
+ // .then()
+ // .statusCode(200);
}
// Retrieve recorded spans
- JsonPath jsonPath = RestAssured.given()
- .get("/opentelemetry/spans")
- .then()
- .statusCode(200)
- .extract()
- .body()
- .jsonPath();
-
- List