Skip to content

Commit

Permalink
Revert back to use constant definition for semcov.
Browse files Browse the repository at this point in the history
  • Loading branch information
zzhlogin committed Jan 6, 2025
1 parent 880d11a commit e281d01
Show file tree
Hide file tree
Showing 10 changed files with 130 additions and 119 deletions.
4 changes: 2 additions & 2 deletions exporter/awsxrayexporter/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,14 @@ require (
github.com/open-telemetry/opentelemetry-collector-contrib/internal/aws/awsutil v0.103.0
github.com/open-telemetry/opentelemetry-collector-contrib/internal/aws/xray v0.103.0
github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal v0.103.0
github.com/stretchr/testify v1.10.0
github.com/stretchr/testify v1.9.0
go.opentelemetry.io/collector/component v0.103.0
go.opentelemetry.io/collector/confmap v0.103.0
go.opentelemetry.io/collector/consumer v0.103.0
go.opentelemetry.io/collector/exporter v0.103.0
go.opentelemetry.io/collector/featuregate v1.10.0
go.opentelemetry.io/collector/pdata v1.10.0
go.opentelemetry.io/collector/semconv v0.116.0
go.opentelemetry.io/collector/semconv v0.103.0
go.opentelemetry.io/otel/metric v1.27.0
go.opentelemetry.io/otel/trace v1.27.0
go.uber.org/goleak v1.3.0
Expand Down
8 changes: 4 additions & 4 deletions exporter/awsxrayexporter/go.sum

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 5 additions & 2 deletions exporter/awsxrayexporter/internal/translator/aws.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,15 @@ import (

"github.com/aws/aws-sdk-go/aws"
"go.opentelemetry.io/collector/pdata/pcommon"
conventionsv127 "go.opentelemetry.io/collector/semconv/v1.27.0"
conventions "go.opentelemetry.io/collector/semconv/v1.6.1"

awsxray "github.com/open-telemetry/opentelemetry-collector-contrib/internal/aws/xray"
)

const (
AttributeTelemetryDistroVersion = "telemetry.distro.version"
)

func makeAws(attributes map[string]pcommon.Value, resource pcommon.Resource, logGroupNames []string) (map[string]pcommon.Value, *awsxray.AWSData) {
var (
cloud string
Expand Down Expand Up @@ -91,7 +94,7 @@ func makeAws(attributes map[string]pcommon.Value, resource pcommon.Resource, log
sdkLanguage = value.Str()
case conventions.AttributeTelemetrySDKVersion:
sdkVersion = value.Str()
case conventions.AttributeTelemetryAutoVersion, conventionsv127.AttributeTelemetryDistroVersion:
case conventions.AttributeTelemetryAutoVersion, AttributeTelemetryDistroVersion:
autoVersion = value.Str()
case conventions.AttributeContainerID:
containerID = value.Str()
Expand Down
9 changes: 4 additions & 5 deletions exporter/awsxrayexporter/internal/translator/aws_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import (
"github.com/aws/aws-sdk-go/aws"
"github.com/stretchr/testify/assert"
"go.opentelemetry.io/collector/pdata/pcommon"
conventionsv127 "go.opentelemetry.io/collector/semconv/v1.27.0"
conventions "go.opentelemetry.io/collector/semconv/v1.6.1"

awsxray "github.com/open-telemetry/opentelemetry-collector-contrib/internal/aws/xray"
Expand Down Expand Up @@ -364,10 +363,10 @@ func TestJavaAutoInstrumentation(t *testing.T) {
func TestJavaAutoInstrumentationStable(t *testing.T) {
attributes := make(map[string]pcommon.Value)
resource := pcommon.NewResource()
resource.Attributes().PutStr(conventionsv127.AttributeTelemetrySDKName, "opentelemetry")
resource.Attributes().PutStr(conventionsv127.AttributeTelemetrySDKLanguage, "java")
resource.Attributes().PutStr(conventionsv127.AttributeTelemetrySDKVersion, "1.2.3")
resource.Attributes().PutStr(conventionsv127.AttributeTelemetryDistroVersion, "3.4.5")
resource.Attributes().PutStr(conventions.AttributeTelemetrySDKName, "opentelemetry")
resource.Attributes().PutStr(conventions.AttributeTelemetrySDKLanguage, "java")
resource.Attributes().PutStr(conventions.AttributeTelemetrySDKVersion, "1.2.3")
resource.Attributes().PutStr(AttributeTelemetryDistroVersion, "3.4.5")

filtered, awsData := makeAws(attributes, resource, nil)

Expand Down
5 changes: 2 additions & 3 deletions exporter/awsxrayexporter/internal/translator/cause.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ import (
"github.com/aws/aws-sdk-go/aws"
"go.opentelemetry.io/collector/pdata/pcommon"
"go.opentelemetry.io/collector/pdata/ptrace"
conventionsv127 "go.opentelemetry.io/collector/semconv/v1.27.0"
conventions "go.opentelemetry.io/collector/semconv/v1.6.1"

awsxray "github.com/open-telemetry/opentelemetry-collector-contrib/internal/aws/xray"
Expand Down Expand Up @@ -88,7 +87,7 @@ func makeCause(span ptrace.Span, attributes map[string]pcommon.Value, resource p
parsed := parseException(exceptionType, message, stacktrace, isRemote, language)
exceptions = append(exceptions, parsed...)
} else if isAwsSdkSpan && event.Name() == AwsIndividualHTTPEventName {
errorCode, ok1 := event.Attributes().Get(conventionsv127.AttributeHTTPResponseStatusCode)
errorCode, ok1 := event.Attributes().Get(AttributeHTTPResponseStatusCode)
errorMessage, ok2 := event.Attributes().Get(AwsIndividualHTTPErrorMsgAttr)
if ok1 && ok2 {
eventEpochTime := event.Timestamp().AsTime().UnixMicro()
Expand Down Expand Up @@ -151,7 +150,7 @@ func makeCause(span ptrace.Span, attributes map[string]pcommon.Value, resource p

val, ok := span.Attributes().Get(conventions.AttributeHTTPStatusCode)
if !ok {
val, ok = span.Attributes().Get(conventionsv127.AttributeHTTPResponseStatusCode)
val, ok = span.Attributes().Get(AttributeHTTPResponseStatusCode)
}

switch {
Expand Down
39 changes: 19 additions & 20 deletions exporter/awsxrayexporter/internal/translator/cause_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import (
"github.com/stretchr/testify/require"
"go.opentelemetry.io/collector/pdata/pcommon"
"go.opentelemetry.io/collector/pdata/ptrace"
conventionsv127 "go.opentelemetry.io/collector/semconv/v1.27.0"
conventions "go.opentelemetry.io/collector/semconv/v1.6.1"
)

Expand Down Expand Up @@ -69,7 +68,7 @@ func TestMakeCauseAwsSdkSpan(t *testing.T) {

event1 := span.Events().AppendEmpty()
event1.SetName(AwsIndividualHTTPEventName)
event1.Attributes().PutStr(conventionsv127.AttributeHTTPResponseStatusCode, "503")
event1.Attributes().PutStr(AttributeHTTPResponseStatusCode, "503")
event1.Attributes().PutStr(AwsIndividualHTTPErrorMsgAttr, "service is temporarily unavailable")
timestamp := pcommon.NewTimestampFromTime(time.UnixMicro(1696954761000001))
event1.SetTimestamp(timestamp)
Expand Down Expand Up @@ -200,9 +199,9 @@ func TestCauseWithStatusMessage(t *testing.T) {
func TestCauseWithStatusMessageStable(t *testing.T) {
errorMsg := "this is a test"
attributes := make(map[string]any)
attributes[conventionsv127.AttributeHTTPRequestMethod] = "POST"
attributes[conventionsv127.AttributeURLFull] = "https://api.example.com/widgets"
attributes[conventionsv127.AttributeHTTPResponseStatusCode] = 500
attributes[AttributeHTTPRequestMethod] = "POST"
attributes[AttributeURLFull] = "https://api.example.com/widgets"
attributes[AttributeHTTPResponseStatusCode] = 500
span := constructExceptionServerSpan(attributes, ptrace.StatusCodeError)
span.Status().SetMessage(errorMsg)
filtered, _ := makeHTTP(span)
Expand Down Expand Up @@ -250,9 +249,9 @@ func TestCauseWithHttpStatusMessage(t *testing.T) {
func TestCauseWithHttpStatusMessageStable(t *testing.T) {
errorMsg := "this is a test"
attributes := make(map[string]any)
attributes[conventions.AttributeHTTPMethod] = "POST"
attributes[conventions.AttributeHTTPURL] = "https://api.example.com/widgets"
attributes[conventionsv127.AttributeHTTPResponseStatusCode] = 500
attributes[AttributeHTTPRequestMethod] = "POST"
attributes[AttributeURLFull] = "https://api.example.com/widgets"
attributes[AttributeHTTPResponseStatusCode] = 500
attributes["http.status_text"] = errorMsg
span := constructExceptionServerSpan(attributes, ptrace.StatusCodeError)
filtered, _ := makeHTTP(span)
Expand Down Expand Up @@ -299,9 +298,9 @@ func TestCauseWithZeroStatusMessageAndFaultHttpCode(t *testing.T) {
func TestCauseWithZeroStatusMessageAndFaultHttpCodeStable(t *testing.T) {
errorMsg := "this is a test"
attributes := make(map[string]any)
attributes[conventionsv127.AttributeHTTPRequestMethod] = "POST"
attributes[conventionsv127.AttributeURLFull] = "https://api.example.com/widgets"
attributes[conventionsv127.AttributeHTTPResponseStatusCode] = 500
attributes[AttributeHTTPRequestMethod] = "POST"
attributes[AttributeURLFull] = "https://api.example.com/widgets"
attributes[AttributeHTTPResponseStatusCode] = 500
attributes["http.status_text"] = errorMsg

span := constructExceptionServerSpan(attributes, ptrace.StatusCodeUnset)
Expand Down Expand Up @@ -416,9 +415,9 @@ func TestCauseWithZeroStatusMessageAndFaultErrorCode(t *testing.T) {
func TestCauseWithZeroStatusMessageAndFaultErrorCodeStable(t *testing.T) {
errorMsg := "this is a test"
attributes := make(map[string]any)
attributes[conventionsv127.AttributeHTTPRequestMethod] = "POST"
attributes[conventionsv127.AttributeURLFull] = "https://api.example.com/widgets"
attributes[conventionsv127.AttributeHTTPResponseStatusCode] = 400
attributes[AttributeHTTPRequestMethod] = "POST"
attributes[AttributeURLFull] = "https://api.example.com/widgets"
attributes[AttributeHTTPResponseStatusCode] = 400
attributes["http.status_text"] = errorMsg

span := constructExceptionServerSpan(attributes, ptrace.StatusCodeUnset)
Expand Down Expand Up @@ -461,9 +460,9 @@ func TestCauseWithClientErrorMessage(t *testing.T) {
func TestCauseWithClientErrorMessageStable(t *testing.T) {
errorMsg := "this is a test"
attributes := make(map[string]any)
attributes[conventionsv127.AttributeHTTPRequestMethod] = "POST"
attributes[conventionsv127.AttributeURLFull] = "https://api.example.com/widgets"
attributes[conventionsv127.AttributeHTTPResponseStatusCode] = 499
attributes[AttributeHTTPRequestMethod] = "POST"
attributes[AttributeURLFull] = "https://api.example.com/widgets"
attributes[AttributeHTTPResponseStatusCode] = 499
attributes["http.status_text"] = errorMsg

span := constructExceptionServerSpan(attributes, ptrace.StatusCodeError)
Expand Down Expand Up @@ -503,9 +502,9 @@ func TestCauseWithThrottled(t *testing.T) {
func TestCauseWithThrottledStable(t *testing.T) {
errorMsg := "this is a test"
attributes := make(map[string]any)
attributes[conventionsv127.AttributeHTTPRequestMethod] = "POST"
attributes[conventionsv127.AttributeURLFull] = "https://api.example.com/widgets"
attributes[conventionsv127.AttributeHTTPResponseStatusCode] = 429
attributes[AttributeHTTPRequestMethod] = "POST"
attributes[AttributeURLFull] = "https://api.example.com/widgets"
attributes[AttributeHTTPResponseStatusCode] = 429
attributes["http.status_text"] = errorMsg

span := constructExceptionServerSpan(attributes, ptrace.StatusCodeError)
Expand Down
43 changes: 28 additions & 15 deletions exporter/awsxrayexporter/internal/translator/http.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,25 @@ import (
"github.com/aws/aws-sdk-go/aws"
"go.opentelemetry.io/collector/pdata/pcommon"
"go.opentelemetry.io/collector/pdata/ptrace"
conventionsv127 "go.opentelemetry.io/collector/semconv/v1.27.0"
conventions "go.opentelemetry.io/collector/semconv/v1.6.1"

awsxray "github.com/open-telemetry/opentelemetry-collector-contrib/internal/aws/xray"
)

const (
AttributeHTTPRequestMethod = "http.request.method"
AttributeHTTPResponseStatusCode = "http.response.status_code"
AttributeServerAddress = "server.address"
AttributeServerPort = "server.port"
AttributeNetworkPeerAddress = "network.peer.address"
AttributeClientAddress = "client.address"
AttributeURLScheme = "url.scheme"
AttributeURLFull = "url.full"
AttributeURLPath = "url.path"
AttributeURLQuery = "url.query"
AttributeUserAgentOriginal = "user_agent.original"
)

func makeHTTP(span ptrace.Span) (map[string]pcommon.Value, *awsxray.HTTPData) {
var (
info = awsxray.HTTPData{
Expand All @@ -36,30 +49,30 @@ func makeHTTP(span ptrace.Span) (map[string]pcommon.Value, *awsxray.HTTPData) {

span.Attributes().Range(func(key string, value pcommon.Value) bool {
switch key {
case conventions.AttributeHTTPMethod, conventionsv127.AttributeHTTPRequestMethod:
case conventions.AttributeHTTPMethod, AttributeHTTPRequestMethod:
info.Request.Method = awsxray.String(value.Str())
hasHTTP = true
case conventions.AttributeHTTPClientIP:
info.Request.ClientIP = awsxray.String(value.Str())
hasHTTP = true
case conventions.AttributeHTTPUserAgent, conventionsv127.AttributeUserAgentOriginal:
case conventions.AttributeHTTPUserAgent, AttributeUserAgentOriginal:
info.Request.UserAgent = awsxray.String(value.Str())
hasHTTP = true
case conventions.AttributeHTTPStatusCode, conventionsv127.AttributeHTTPResponseStatusCode:
case conventions.AttributeHTTPStatusCode, AttributeHTTPResponseStatusCode:
info.Response.Status = aws.Int64(value.Int())
hasHTTP = true
case conventions.AttributeHTTPURL, conventionsv127.AttributeURLFull:
case conventions.AttributeHTTPURL, AttributeURLFull:
urlParts[conventions.AttributeHTTPURL] = value.Str()
hasHTTP = true
hasHTTPRequestURLAttributes = true
case conventions.AttributeHTTPScheme, conventionsv127.AttributeURLScheme:
case conventions.AttributeHTTPScheme, AttributeURLScheme:
urlParts[conventions.AttributeHTTPScheme] = value.Str()
hasHTTP = true
case conventions.AttributeHTTPHost:
urlParts[key] = value.Str()
hasHTTP = true
hasHTTPRequestURLAttributes = true
case conventions.AttributeHTTPTarget, conventionsv127.AttributeURLQuery:
case conventions.AttributeHTTPTarget, AttributeURLQuery:
urlParts[conventions.AttributeHTTPTarget] = value.Str()
hasHTTP = true
case conventions.AttributeHTTPServerName:
Expand Down Expand Up @@ -94,7 +107,7 @@ func makeHTTP(span ptrace.Span) (map[string]pcommon.Value, *awsxray.HTTPData) {
urlParts[key] = value.Str()
hasHTTPRequestURLAttributes = true
hasNetPeerAddr = true
case conventionsv127.AttributeNetworkPeerAddress:
case AttributeNetworkPeerAddress:
// Prefer HTTP forwarded information (AttributeHTTPClientIP) when present.
if net.ParseIP(value.Str()) != nil {
if info.Request.ClientIP == nil {
Expand All @@ -103,17 +116,17 @@ func makeHTTP(span ptrace.Span) (map[string]pcommon.Value, *awsxray.HTTPData) {
hasHTTPRequestURLAttributes = true
hasNetPeerAddr = true
}
case conventionsv127.AttributeClientAddress:
case AttributeClientAddress:
if net.ParseIP(value.Str()) != nil {
info.Request.ClientIP = awsxray.String(value.Str())
}
case conventionsv127.AttributeURLPath:
case AttributeURLPath:
urlParts[key] = value.Str()
hasHTTP = true
case conventionsv127.AttributeServerAddress:
case AttributeServerAddress:
urlParts[key] = value.Str()
hasHTTPRequestURLAttributes = true
case conventionsv127.AttributeServerPort:
case AttributeServerPort:
urlParts[key] = value.Str()
if len(urlParts[key]) == 0 {
urlParts[key] = strconv.FormatInt(value.Int(), 10)
Expand Down Expand Up @@ -234,13 +247,13 @@ func constructServerURL(urlParts map[string]string) string {
if !ok {
host, ok = urlParts[conventions.AttributeHostName]
if !ok {
host = urlParts[conventionsv127.AttributeServerAddress]
host = urlParts[AttributeServerAddress]
}
}
}
port, ok = urlParts[conventions.AttributeNetHostPort]
if !ok {
port, ok = urlParts[conventionsv127.AttributeServerPort]
port, ok = urlParts[AttributeServerPort]
if !ok {
port = ""
}
Expand All @@ -254,7 +267,7 @@ func constructServerURL(urlParts map[string]string) string {
if ok {
url += target
} else {
path, ok := urlParts[conventionsv127.AttributeURLPath]
path, ok := urlParts[AttributeURLPath]
if ok {
url += path
} else {
Expand Down
Loading

0 comments on commit e281d01

Please sign in to comment.