Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

exporter: add is_remote_parent span flags to OTLP exported spans and links #3881

Merged
merged 3 commits into from
May 9, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
([#3586](https://github.com/open-telemetry/opentelemetry-python/pull/3586))
- Rename test objects to avoid pytest warnings
([#3823] (https://github.com/open-telemetry/opentelemetry-python/pull/3823))
- Add span flags to OLTP spans and links
lzchen marked this conversation as resolved.
Show resolved Hide resolved
([#3881](https://github.com/open-telemetry/opentelemetry-python/pull/3881))

## Version 1.24.0/0.45b0 (2024-03-28)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,27 +17,25 @@
from typing import List, Optional, Sequence

from opentelemetry.exporter.otlp.proto.common._internal import (
_encode_trace_id,
_encode_span_id,
_encode_instrumentation_scope,
_encode_attributes,
_encode_instrumentation_scope,
_encode_resource,
_encode_span_id,
_encode_trace_id,
)
from opentelemetry.proto.collector.trace.v1.trace_service_pb2 import (
ExportTraceServiceRequest as PB2ExportTraceServiceRequest,
)
from opentelemetry.proto.trace.v1.trace_pb2 import (
ScopeSpans as PB2ScopeSpans,
)
from opentelemetry.proto.trace.v1.trace_pb2 import (
ResourceSpans as PB2ResourceSpans,
)
from opentelemetry.proto.trace.v1.trace_pb2 import ScopeSpans as PB2ScopeSpans
from opentelemetry.proto.trace.v1.trace_pb2 import Span as PB2SPan
from opentelemetry.proto.trace.v1.trace_pb2 import SpanFlags as PB2SpanFlags
from opentelemetry.proto.trace.v1.trace_pb2 import Status as PB2Status
from opentelemetry.sdk.trace import Event, ReadableSpan
from opentelemetry.trace import Link
from opentelemetry.trace import SpanKind
from opentelemetry.trace.span import SpanContext, TraceState, Status
from opentelemetry.trace import Link, SpanKind
from opentelemetry.trace.span import SpanContext, Status, TraceState

# pylint: disable=E1101
_SPAN_KIND_MAP = {
Expand Down Expand Up @@ -104,6 +102,13 @@ def _encode_resource_spans(
return pb2_resource_spans


def _span_flags(parent_span_context: Optional[SpanContext]) -> int:
flags = PB2SpanFlags.SPAN_FLAGS_CONTEXT_HAS_IS_REMOTE_MASK
if parent_span_context and parent_span_context.is_remote:
flags |= PB2SpanFlags.SPAN_FLAGS_CONTEXT_IS_REMOTE_MASK
return flags


def _encode_span(sdk_span: ReadableSpan) -> PB2SPan:
span_context = sdk_span.get_span_context()
return PB2SPan(
Expand All @@ -122,6 +127,7 @@ def _encode_span(sdk_span: ReadableSpan) -> PB2SPan:
dropped_attributes_count=sdk_span.dropped_attributes,
dropped_events_count=sdk_span.dropped_events,
dropped_links_count=sdk_span.dropped_links,
flags=_span_flags(sdk_span.parent),
)


Expand Down Expand Up @@ -152,6 +158,7 @@ def _encode_links(links: Sequence[Link]) -> Sequence[PB2SPan.Link]:
span_id=_encode_span_id(link.context.span_id),
attributes=_encode_attributes(link.attributes),
dropped_attributes_count=link.attributes.dropped,
flags=_span_flags(link.context),
)
pb2_links.append(encoded_link)
return pb2_links
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ def get_exhaustive_otel_span_list() -> List[SDKSpan]:
)

parent_span_context = SDKSpanContext(
trace_id, 0x1111111111111111, is_remote=False
trace_id, 0x1111111111111111, is_remote=True
)

other_context = SDKSpanContext(
Expand Down Expand Up @@ -252,12 +252,14 @@ def get_exhaustive_test_spans(
),
),
],
flags=0x100,
)
],
status=PB2Status(
code=SDKStatusCode.ERROR.value,
message="Example description",
),
flags=0x300,
)
],
),
Expand All @@ -284,6 +286,7 @@ def get_exhaustive_test_spans(
events=None,
links=None,
status={},
flags=0x100,
)
],
),
Expand Down Expand Up @@ -321,6 +324,7 @@ def get_exhaustive_test_spans(
events=None,
links=None,
status={},
flags=0x100,
),
PB2SPan(
trace_id=trace_id,
Expand All @@ -346,6 +350,7 @@ def get_exhaustive_test_spans(
events=None,
links=None,
status={},
flags=0x100,
),
],
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -597,8 +597,10 @@ def test_translate_spans(self):
),
),
],
flags=0x300,
)
],
flags=0x300,
)
],
)
Expand Down Expand Up @@ -699,8 +701,10 @@ def test_translate_spans_multi(self):
),
),
],
flags=0x300,
)
],
flags=0x300,
)
],
),
Expand Down Expand Up @@ -730,6 +734,7 @@ def test_translate_spans_multi(self):
OTLPSpan.SpanKind.SPAN_KIND_INTERNAL
),
status=Status(code=0, message=""),
flags=0x300,
)
],
),
Expand Down Expand Up @@ -771,6 +776,7 @@ def test_translate_spans_multi(self):
OTLPSpan.SpanKind.SPAN_KIND_INTERNAL
),
status=Status(code=0, message=""),
flags=0x300,
)
],
)
Expand Down