-
Notifications
You must be signed in to change notification settings - Fork 879
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Move X-Ray Env Variable propagation to span link instead of parent (#…
…7970) open-telemetry/opentelemetry-specification#3166 Per discussion in the FAAS SIG, we decided that the AWS X-Ray environment variable should be moved to a span link to avoid interfering with the configured propagators. Also related to #5167.
- Loading branch information
1 parent
4d6ef78
commit 083acdd
Showing
9 changed files
with
228 additions
and
214 deletions.
There are no files selected for viewing
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
74 changes: 74 additions & 0 deletions
74
...entelemetry/instrumentation/awslambdacore/v1_0/internal/AwsXrayEnvSpanLinksExtractor.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,74 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.instrumentation.awslambdacore.v1_0.internal; | ||
|
||
import io.opentelemetry.api.common.AttributeKey; | ||
import io.opentelemetry.api.common.Attributes; | ||
import io.opentelemetry.api.trace.Span; | ||
import io.opentelemetry.api.trace.SpanContext; | ||
import io.opentelemetry.context.Context; | ||
import io.opentelemetry.context.propagation.TextMapGetter; | ||
import io.opentelemetry.contrib.awsxray.propagator.AwsXrayPropagator; | ||
import io.opentelemetry.instrumentation.api.instrumenter.SpanLinksBuilder; | ||
import io.opentelemetry.instrumentation.api.instrumenter.SpanLinksExtractor; | ||
import io.opentelemetry.instrumentation.awslambdacore.v1_0.AwsLambdaRequest; | ||
import java.util.Collections; | ||
import java.util.Locale; | ||
import java.util.Map; | ||
|
||
/** | ||
* This class is internal and is hence not for public use. Its APIs are unstable and can change at | ||
* any time. | ||
*/ | ||
final class AwsXrayEnvSpanLinksExtractor implements SpanLinksExtractor<AwsLambdaRequest> { | ||
|
||
private static final String AWS_TRACE_HEADER_ENV_KEY = "_X_AMZN_TRACE_ID"; | ||
|
||
// lower-case map getter used for extraction | ||
private static final String AWS_TRACE_HEADER_PROPAGATOR_KEY = "x-amzn-trace-id"; | ||
|
||
private static final Attributes LINK_ATTRIBUTES = | ||
Attributes.of(AttributeKey.stringKey("source"), "x-ray-env"); | ||
|
||
@Override | ||
public void extract( | ||
SpanLinksBuilder spanLinks, | ||
io.opentelemetry.context.Context parentContext, | ||
AwsLambdaRequest awsLambdaRequest) { | ||
extract(spanLinks); | ||
} | ||
|
||
public static void extract(SpanLinksBuilder spanLinks) { | ||
String parentTraceHeader = System.getenv(AWS_TRACE_HEADER_ENV_KEY); | ||
if (parentTraceHeader == null || parentTraceHeader.isEmpty()) { | ||
return; | ||
} | ||
Context xrayContext = | ||
AwsXrayPropagator.getInstance() | ||
.extract( | ||
Context.root(), | ||
Collections.singletonMap(AWS_TRACE_HEADER_PROPAGATOR_KEY, parentTraceHeader), | ||
MapGetter.INSTANCE); | ||
SpanContext envVarSpanCtx = Span.fromContext(xrayContext).getSpanContext(); | ||
if (envVarSpanCtx.isValid()) { | ||
spanLinks.addLink(envVarSpanCtx, LINK_ATTRIBUTES); | ||
} | ||
} | ||
|
||
private enum MapGetter implements TextMapGetter<Map<String, String>> { | ||
INSTANCE; | ||
|
||
@Override | ||
public Iterable<String> keys(Map<String, String> map) { | ||
return map.keySet(); | ||
} | ||
|
||
@Override | ||
public String get(Map<String, String> map, String s) { | ||
return map.get(s.toLowerCase(Locale.ROOT)); | ||
} | ||
} | ||
} |
81 changes: 0 additions & 81 deletions
81
.../io/opentelemetry/instrumentation/awslambdacore/v1_0/internal/ParentContextExtractor.java
This file was deleted.
Oops, something went wrong.
87 changes: 87 additions & 0 deletions
87
...lemetry/instrumentation/awslambdacore/v1_0/internal/AwsXrayEnvSpanLinksExtractorTest.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,87 @@ | ||
/* | ||
* Copyright The OpenTelemetry Authors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
package io.opentelemetry.instrumentation.awslambdacore.v1_0.internal; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.mockito.ArgumentMatchers.eq; | ||
import static org.mockito.Mockito.mock; | ||
import static org.mockito.Mockito.verify; | ||
import static org.mockito.Mockito.verifyNoInteractions; | ||
|
||
import io.opentelemetry.api.common.AttributeKey; | ||
import io.opentelemetry.api.common.Attributes; | ||
import io.opentelemetry.api.trace.SpanContext; | ||
import io.opentelemetry.instrumentation.api.instrumenter.SpanLinksBuilder; | ||
import org.junit.jupiter.api.Test; | ||
import org.junit.jupiter.api.extension.ExtendWith; | ||
import org.mockito.ArgumentCaptor; | ||
import uk.org.webcompere.systemstubs.environment.EnvironmentVariables; | ||
import uk.org.webcompere.systemstubs.jupiter.SystemStub; | ||
import uk.org.webcompere.systemstubs.jupiter.SystemStubsExtension; | ||
|
||
/** | ||
* This class is internal and is hence not for public use. Its APIs are unstable and can change at | ||
* any time. | ||
*/ | ||
@ExtendWith(SystemStubsExtension.class) | ||
class AwsXrayEnvSpanLinksExtractorTest { | ||
private static final Attributes EXPECTED_LINK_ATTRIBUTES = | ||
Attributes.of(AttributeKey.stringKey("source"), "x-ray-env"); | ||
|
||
@SystemStub final EnvironmentVariables environmentVariables = new EnvironmentVariables(); | ||
|
||
@Test | ||
void shouldIgnoreIfEnvVarEmpty() { | ||
// given | ||
SpanLinksBuilder spanLinksBuilder = mock(SpanLinksBuilder.class); | ||
environmentVariables.set("_X_AMZN_TRACE_ID", ""); | ||
|
||
// when | ||
AwsXrayEnvSpanLinksExtractor.extract(spanLinksBuilder); | ||
// then | ||
verifyNoInteractions(spanLinksBuilder); | ||
} | ||
|
||
@Test | ||
void shouldLinkAwsParentHeaderIfValidAndNotSampled() { | ||
// given | ||
SpanLinksBuilder spanLinksBuilder = mock(SpanLinksBuilder.class); | ||
environmentVariables.set( | ||
"_X_AMZN_TRACE_ID", | ||
"Root=1-8a3c60f7-d188f8fa79d48a391a778fa6;Parent=0000000000000456;Sampled=0"); | ||
|
||
// when | ||
AwsXrayEnvSpanLinksExtractor.extract(spanLinksBuilder); | ||
// then | ||
ArgumentCaptor<SpanContext> captor = ArgumentCaptor.forClass(SpanContext.class); | ||
verify(spanLinksBuilder).addLink(captor.capture(), eq(EXPECTED_LINK_ATTRIBUTES)); | ||
SpanContext spanContext = captor.getValue(); | ||
assertThat(spanContext.isValid()).isTrue(); | ||
assertThat(spanContext.isSampled()).isFalse(); | ||
assertThat(spanContext.getSpanId()).isEqualTo("0000000000000456"); | ||
assertThat(spanContext.getTraceId()).isEqualTo("8a3c60f7d188f8fa79d48a391a778fa6"); | ||
} | ||
|
||
@Test | ||
void shouldLinkAwsParentHeaderIfValidAndSampled() { | ||
// given | ||
SpanLinksBuilder spanLinksBuilder = mock(SpanLinksBuilder.class); | ||
environmentVariables.set( | ||
"_X_AMZN_TRACE_ID", | ||
"Root=1-8a3c60f7-d188f8fa79d48a391a778fa6;Parent=0000000000000456;Sampled=1"); | ||
|
||
// when | ||
AwsXrayEnvSpanLinksExtractor.extract(spanLinksBuilder); | ||
// then | ||
ArgumentCaptor<SpanContext> captor = ArgumentCaptor.forClass(SpanContext.class); | ||
verify(spanLinksBuilder).addLink(captor.capture(), eq(EXPECTED_LINK_ATTRIBUTES)); | ||
SpanContext spanContext = captor.getValue(); | ||
assertThat(spanContext.isValid()).isTrue(); | ||
assertThat(spanContext.isSampled()).isTrue(); | ||
assertThat(spanContext.getSpanId()).isEqualTo("0000000000000456"); | ||
assertThat(spanContext.getTraceId()).isEqualTo("8a3c60f7d188f8fa79d48a391a778fa6"); | ||
} | ||
} |
Oops, something went wrong.