-
Notifications
You must be signed in to change notification settings - Fork 851
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Co-authored-by: jack-berg <[email protected]>
- Loading branch information
1 parent
f9be682
commit f99e496
Showing
9 changed files
with
308 additions
and
78 deletions.
There are no files selected for viewing
40 changes: 40 additions & 0 deletions
40
exporters/common/src/main/java/io/opentelemetry/exporter/internal/InstrumentationUtil.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.exporter.internal; | ||
|
||
import io.opentelemetry.context.Context; | ||
import io.opentelemetry.context.ContextKey; | ||
import java.util.Objects; | ||
|
||
/** | ||
* This class is internal and is hence not for public use. Its APIs are unstable and can change at | ||
* any time. | ||
*/ | ||
public final class InstrumentationUtil { | ||
private static final ContextKey<Boolean> SUPPRESS_INSTRUMENTATION_KEY = | ||
ContextKey.named("suppress_internal_exporter_instrumentation"); | ||
|
||
private InstrumentationUtil() {} | ||
|
||
/** | ||
* Adds a Context boolean key that will allow to identify HTTP calls coming from OTel exporters. | ||
* The key later be checked by an automatic instrumentation to avoid tracing OTel exporter's | ||
* calls. | ||
*/ | ||
public static void suppressInstrumentation(Runnable runnable) { | ||
Context.current().with(SUPPRESS_INSTRUMENTATION_KEY, true).wrap(runnable).run(); | ||
} | ||
|
||
/** | ||
* Checks if an automatic instrumentation should be suppressed with the provided Context. | ||
* | ||
* @return TRUE to suppress the automatic instrumentation, FALSE to continue with the | ||
* instrumentation. | ||
*/ | ||
public static boolean shouldSuppressInstrumentation(Context context) { | ||
return Objects.equals(context.get(SUPPRESS_INSTRUMENTATION_KEY), true); | ||
} | ||
} |
27 changes: 27 additions & 0 deletions
27
...ters/common/src/test/java/io/opentelemetry/exporter/internal/InstrumentationUtilTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.exporter.internal; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertFalse; | ||
import static org.junit.jupiter.api.Assertions.assertTrue; | ||
|
||
import io.opentelemetry.context.Context; | ||
import org.junit.jupiter.api.Test; | ||
|
||
class InstrumentationUtilTest { | ||
@Test | ||
void verifySuppressInstrumentation() { | ||
// Should be false by default. | ||
assertFalse(InstrumentationUtil.shouldSuppressInstrumentation(Context.current())); | ||
|
||
// Should be true inside the Runnable passed to InstrumentationUtil.suppressInstrumentation. | ||
InstrumentationUtil.suppressInstrumentation( | ||
() -> assertTrue(InstrumentationUtil.shouldSuppressInstrumentation(Context.current()))); | ||
|
||
// Should be false after the runnable finishes. | ||
assertFalse(InstrumentationUtil.shouldSuppressInstrumentation(Context.current())); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
58 changes: 58 additions & 0 deletions
58
.../java/io/opentelemetry/exporter/sender/okhttp/internal/AbstractOkHttpSuppressionTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.exporter.sender.okhttp.internal; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertTrue; | ||
|
||
import io.opentelemetry.context.Context; | ||
import io.opentelemetry.exporter.internal.InstrumentationUtil; | ||
import java.util.concurrent.CountDownLatch; | ||
import java.util.concurrent.atomic.AtomicBoolean; | ||
import org.junit.jupiter.api.AfterEach; | ||
import org.junit.jupiter.api.Assertions; | ||
import org.junit.jupiter.api.BeforeEach; | ||
import org.junit.jupiter.api.Test; | ||
|
||
abstract class AbstractOkHttpSuppressionTest<T> { | ||
|
||
@BeforeEach | ||
void setUp() { | ||
OkHttpUtil.setPropagateContextForTestingInDispatcher(true); | ||
} | ||
|
||
@AfterEach | ||
void tearDown() { | ||
OkHttpUtil.setPropagateContextForTestingInDispatcher(false); | ||
} | ||
|
||
@Test | ||
void testSuppressInstrumentation() throws InterruptedException { | ||
CountDownLatch latch = new CountDownLatch(1); | ||
AtomicBoolean suppressInstrumentation = new AtomicBoolean(false); | ||
|
||
Runnable onSuccess = Assertions::fail; | ||
Runnable onFailure = | ||
() -> { | ||
suppressInstrumentation.set( | ||
InstrumentationUtil.shouldSuppressInstrumentation(Context.current())); | ||
latch.countDown(); | ||
}; | ||
|
||
send(getSender(), onSuccess, onFailure); | ||
|
||
latch.await(); | ||
|
||
assertTrue(suppressInstrumentation.get()); | ||
} | ||
|
||
abstract void send(T sender, Runnable onSuccess, Runnable onFailure); | ||
|
||
private T getSender() { | ||
return createSender("https://none"); | ||
} | ||
|
||
abstract T createSender(String endpoint); | ||
} |
36 changes: 36 additions & 0 deletions
36
...test/java/io/opentelemetry/exporter/sender/okhttp/internal/OkHttpGrpcSuppressionTest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.exporter.sender.okhttp.internal; | ||
|
||
import io.opentelemetry.exporter.internal.marshal.MarshalerWithSize; | ||
import io.opentelemetry.exporter.internal.marshal.Serializer; | ||
import java.util.Collections; | ||
|
||
class OkHttpGrpcSuppressionTest | ||
extends AbstractOkHttpSuppressionTest< | ||
OkHttpGrpcSender<OkHttpGrpcSuppressionTest.DummyMarshaler>> { | ||
|
||
@Override | ||
void send(OkHttpGrpcSender<DummyMarshaler> sender, Runnable onSuccess, Runnable onFailure) { | ||
sender.send(new DummyMarshaler(), onSuccess, (grpcResponse, throwable) -> onFailure.run()); | ||
} | ||
|
||
@Override | ||
OkHttpGrpcSender<DummyMarshaler> createSender(String endpoint) { | ||
return new OkHttpGrpcSender<>( | ||
"https://localhost", false, 10L, Collections.emptyMap(), null, null, null); | ||
} | ||
|
||
protected static class DummyMarshaler extends MarshalerWithSize { | ||
|
||
protected DummyMarshaler() { | ||
super(0); | ||
} | ||
|
||
@Override | ||
protected void writeTo(Serializer output) {} | ||
} | ||
} |
Oops, something went wrong.