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

Merge remote-tracking branch 'upstream/main' #45

Merged
Merged
Changes from 1 commit
Commits
Show all changes
101 commits
Select commit Hold shift + click to select a range
53ad0a4
[chore]: enable bool-compare rule from testifylint (#34912)
mmorel-35 Aug 29, 2024
240ff76
[pkg/ottl] Remove tracing from OTTL (#34910)
TylerHelmuth Aug 29, 2024
29cd095
[chore]: enable len rule from testifylint (#34921)
mmorel-35 Aug 30, 2024
0ec84e6
[chore][receiver/nginx] Update README for consistency (#34923)
crobert-1 Aug 30, 2024
184e954
[processor/redaction] add support for redacting metrics and logs attr…
bacherfl Aug 30, 2024
499cfd8
[chore] Fix linter issues (#34937)
mx-psi Aug 30, 2024
903eec5
[receiver/gitproviderreceiver] rename to githubreceiver (#34731)
adrielp Aug 30, 2024
6b3237a
[chore][CODEOWNERS] Change account references to match new username (…
crobert-1 Aug 30, 2024
2d63c17
[chore] refactor filter processor test to use generated test harness …
codeboten Aug 30, 2024
ea521f7
[chore] use generated test harness for groupbyattrs processor (#34941)
codeboten Aug 30, 2024
0216163
[chore] update core to pull in telemetry settings changes (#34930)
codeboten Aug 30, 2024
90e75d3
[receiver/splunkhec] fix memory leak (#34911)
atoulme Aug 30, 2024
dbf8982
[chore] Updating @MovieStoreGuy affiliation (#34947)
MovieStoreGuy Sep 1, 2024
fd0e9ef
[chore]: Update README.md (#34725)
CharlieTLe Sep 2, 2024
33362ee
[connector/servicegraph]Fix incorrectly reversed latency settings(res…
Frapschen Sep 2, 2024
9f0cac0
[chore]: enable error-nil and nil-compare rules from testifylint (#34…
mmorel-35 Sep 2, 2024
13f0d14
[connector/count] fix typo in metric.datapoint.count (#34961)
lhns Sep 2, 2024
255020c
[chore] Upgrade arvo package (#34962)
MovieStoreGuy Sep 3, 2024
439e41e
Update module github.com/shirou/gopsutil/v4 to v4.24.8 (#34970)
renovate[bot] Sep 3, 2024
4558429
Update module github.com/ClickHouse/clickhouse-go/v2 to v2.28.2 (#34968)
renovate[bot] Sep 3, 2024
1c9e54e
Update All github.com/datadog packages to v0.56.2 (#34965)
renovate[bot] Sep 3, 2024
ad02711
Update module github.com/snowflakedb/gosnowflake to v1.11.1 (#34971)
renovate[bot] Sep 3, 2024
a967d83
[exporter/loki] Document the migration from the Loki Exporter to the …
cyrille-leclerc Sep 3, 2024
9545957
[connector/spanmetrics] Improve consistency between metrics generated…
iblancasa Sep 3, 2024
5822332
Update module google.golang.org/grpc to v1.66.0 (#34978)
renovate[bot] Sep 3, 2024
d25990b
[vcenterreceiver] Updated units on several metrics (#34946)
BominRahmani Sep 3, 2024
c6cda87
Update module github.com/SAP/go-hdb to v1.12.0 (#34973)
renovate[bot] Sep 3, 2024
b128c46
[chore][pkg/stanza] Speed up file deduplication in finder (#34888)
BinaryFissionGames Sep 3, 2024
510a413
[receiver/mysql] client, convert NULL to int64 (#34411)
knarfli Sep 3, 2024
bfdee42
[testbed] - Add scenarios to handle large files (#34417)
VihasMakwana Sep 3, 2024
640adad
Avoid rendering the whole event to get only the provider name (#34914)
pjanotti Sep 3, 2024
119ad9b
[chore] add Tyler to CODEOWNERS for githubreceiver (#34963)
adrielp Sep 3, 2024
58b5bb9
Update README.md (#34990)
gjtorikian Sep 3, 2024
f6156a9
[extension/opamp] Add support for polling interval in HTTP client (#3…
matej-g Sep 3, 2024
a77faff
[receiver/apache] Invalid endpoint should not cause panic (#34992)
pjanotti Sep 3, 2024
1ec7cfe
[chore]: enable compares and empty rules from testifylint (#34976)
mmorel-35 Sep 3, 2024
dabacbd
[receiver/githubreceiver] promote githubreceiver to alpha status (#34…
adrielp Sep 3, 2024
902756e
[connector/datadog] Improve performance in cases with many peer tags …
songy23 Sep 3, 2024
ec049ab
[chore] upgrading pulsar client v0.13.1 (#34951)
MovieStoreGuy Sep 3, 2024
a4aa4e8
[processor/interval] Update config structure for interval processor (…
ArthurSens Sep 3, 2024
d0e5eec
[extension/solarwindsapmsettingsextension] Added remaining implementa…
jerrytfleung Sep 3, 2024
5258d98
feat: Support Prometheus Created Timestamps (#34596)
ArthurSens Sep 4, 2024
3afb802
[receiver/sqlquery] support attributes for logs (#34599)
Grandys Sep 4, 2024
9be1f80
[receiver/kafkareceiver]: allow tunable fetch sizes (#34431)
cxdy Sep 4, 2024
2de5752
[exporter/splunkhec] drop empty log events (#34871)
atoulme Sep 4, 2024
a088f60
[exporter/signalfx] Fix goroutine leaks (#32781)
crobert-1 Sep 4, 2024
1ba4179
[chore] make update-otel to 48b11ba (#34956)
mx-psi Sep 4, 2024
33687ee
[chore][receiver/filelog] Change plaintext name: filelog -> file log …
crobert-1 Sep 4, 2024
9e3a845
[chore] Fix flaky test by ignoring metrics order (#35002)
djaglowski Sep 4, 2024
255aebe
fix: handle OTLPJSON unmarshal error (#34784)
rogercoll Sep 4, 2024
548d95f
[chore] Fix flaky test in filelog receiver (#35012)
djaglowski Sep 4, 2024
e393e02
Bump github.com/opencontainers/runc from 1.1.13 to 1.1.14 in /cmd/ote…
dependabot[bot] Sep 4, 2024
a0ea89c
Clarify google managed prometheus troubleshooting guide (#34986)
dashpole Sep 4, 2024
fa4cac5
Update module github.com/lestrrat-go/strftime to v1.1.0 (#34974)
renovate[bot] Sep 4, 2024
93ba625
[chore] Upgrading msgpack v4 to v5 (#35019)
MovieStoreGuy Sep 5, 2024
cb71224
[exporter/elasticsearch] Fix dynamic mapping for double values storin…
carsonip Sep 5, 2024
4c490fe
[exporter/elasticsearch] Add exponential histogram support (#34818)
carsonip Sep 5, 2024
53152f0
[processor/deltatocumulative]: drop bad samples (#34979)
sh0rez Sep 5, 2024
fa75b6e
fix: avoid using internal empty attribute.Set pointer (#34903)
rogercoll Sep 5, 2024
ceeb395
Update example in readme for convert_sum_to_gauge and convert_gauge_t…
wildum Sep 5, 2024
9a31997
[exporter/elasticsearch] Add span event to traces OTel mapping mode (…
carsonip Sep 5, 2024
a4393cb
[opampsupervisor] Add HealthCheckPort configuration parameter (#34704)
dpaasman00 Sep 5, 2024
e0e6489
[pkg/ottl]: Add Sort converter (#34283)
kaisecheng Sep 5, 2024
6e5fd62
[chore] update module github.com/google/go-github/v63 to v64 (#35016)
adrielp Sep 5, 2024
2bc5b37
Update All github.com/aws packages (#34964)
renovate[bot] Sep 5, 2024
0055e6e
[chore]: enable error-is-as rule from testifylint (#34995)
mmorel-35 Sep 5, 2024
85a2f4f
fix(deps): update module github.com/rs/cors to v1.11.1 (#34969)
renovate[bot] Sep 5, 2024
eb329f4
Update module google.golang.org/api to v0.195.0 (#34977)
renovate[bot] Sep 5, 2024
0bcac4b
[extension/healthcheckv2] Update readme to reflect current status (#3…
mwear Sep 5, 2024
562c01d
[connector/servicegraph] Fix histogram metrics miss unit (#34511)
Frapschen Sep 5, 2024
6eaf284
OTel-Arrow exporter timeout propagation (#34733)
jmacd Sep 5, 2024
9ad4ae3
[receiver/skywalking] add receiver supports version (#34916)
JaredTan95 Sep 5, 2024
52b6807
[exporter/prometheusremotewriteexporter]chore: log warning about remo…
ArthurSens Sep 5, 2024
145145c
[chore]: enable expected-actual rule from testifylint (#34998)
mmorel-35 Sep 5, 2024
a733b01
[pkg/ottl] Add `Decode` function (#33942)
bacherfl Sep 5, 2024
97533e6
[chore] Fix Supervisor test on Windows (#35035)
evan-bradley Sep 5, 2024
93a6bd9
[chore] Share encoding overrides (#35029)
TylerHelmuth Sep 5, 2024
55482cb
[chore] update logging to debug exporter (#35030)
codeboten Sep 5, 2024
7ec6396
[receiver/googlecloudmonitoringreceiver] Transform GCP Timeseries Dat…
abhishek-at-cloudwerx Sep 5, 2024
e9b835f
[receiver/sqlserver] Emit correct database name resource attribute (#…
crobert-1 Sep 6, 2024
abb7604
[exporter/elasticsearch] Workaround TSDB array dimension limitation f…
carsonip Sep 6, 2024
d5595bb
[connector/servicegraph] Extract the `getDimensionValue` function as …
JaredTan95 Sep 6, 2024
f970421
Operators with silent errors will log errors as debug and won't retur…
SamerJ Sep 6, 2024
af21ce7
[internal/otelarrow] Fix test flake (for 34719) (#34889)
jmacd Sep 6, 2024
642cc35
[pkg/ottl] Change grammar to support expressing statements context vi…
edmocosta Sep 6, 2024
25cb194
[pkg/ottl] Add support for localized time parsing into the timeutils …
edmocosta Sep 6, 2024
95ff5f2
[processor/transform] introduce aggregate_on_attribute_value function…
odubajDT Sep 6, 2024
14aa57a
[chore] go version 1.22.6 -> 1.22.7 (#35059)
crobert-1 Sep 6, 2024
8c08765
Use OTel-Arrow v0.26.0 (#35057)
jmacd Sep 6, 2024
0e2bea5
fix(deps): update module github.com/tencentcloud/tencentcloud-sdk-go/…
renovate[bot] Sep 6, 2024
237a96b
Add admission_blocked span to otel-arrow admission controller (#35031)
jmacd Sep 9, 2024
be7ddc3
[chore] Bump github.com/opencontainers/runc from 1.1.13 to 1.1.14 in …
crobert-1 Sep 9, 2024
cc5889d
[receiver/kafkareceiver] Add encoding extensions support (#33888)
thmshmm Sep 9, 2024
45ffc03
[chore] [receiver/datadog] Add support for Service Checks (#34474)
alexgreenbank Sep 9, 2024
5e26464
[receiver/datadog] Add support for sketches (#34662)
carrieedwards Sep 9, 2024
f81fd7a
Marking instanaexporter module as deprecated (#35052)
Frapschen Sep 9, 2024
248b8ec
[chore] Fix flakiness of tests on Windows requiring ports in the dyna…
pjanotti Sep 9, 2024
0ceefaa
[exporter/datadog] Use correct hostname for logs in logs agent pipeli…
liustanley Sep 9, 2024
b3e952f
[exporter/datadogexporter] Add support for custom log source (#35051)
mackjmr Sep 9, 2024
bd66ceb
[chore] Update test expectation to include processorhelper metrics (#…
djaglowski Sep 9, 2024
71ce97e
[chore] Fixing Prom Compliance tests (#35071)
MovieStoreGuy Sep 10, 2024
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
Prev Previous commit
Next Next commit
[connector/servicegraph] Extract the getDimensionValue function as …
…a common function. (open-telemetry#34908)

**Description:** refactoring getDimensionValue func as util func for
spanmetricsconnector,servicegraphconnector,exceptionconnector common
usage
<!--Ex. Fixing a bug - Describe the bug and how this fixes the issue.
Ex. Adding a feature - Explain what this achieves.-->

**Link to tracking Issue:** open-telemetry#34627

**Testing:** <Describe what testing was performed and which tests were
added.>

**Documentation:** <Describe the documentation added.>

---------

Signed-off-by: Jared Tan <jian.tan@daocloud.io>
JaredTan95 authored Sep 6, 2024

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
commit d5595bbfaa6199962b86cb5841b656a08d77f194
27 changes: 27 additions & 0 deletions .chloggen/refactoring_dimenssion_func_as_util_func.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Use this changelog template to create an entry for release notes.

# One of 'breaking', 'deprecation', 'new_component', 'enhancement', 'bug_fix'
change_type: enhancement

# The name of the component, or a single word describing the area of concern, (e.g. filelogreceiver)
component: exceptionsconnector,servicegraphconnector,spanmetricsconnector

# A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`).
note: Extract the `getDimensionValue` function as a common function.

# Mandatory: One or more tracking issues related to the change. You can use the PR number here if no issue exists.
issues: [34627]

# (Optional) One or more lines of additional information to render under the primary note.
# These lines will be padded with 2 spaces and then inserted directly into the document.
# Use pipe (|) for multiline entries.
subtext:

# If your change doesn't affect end users or the exported elements of any package,
# you should instead start your pull request title with [chore] or use the "Skip Changelog" label.
# Optional: The change log or logs in which this entry should be included.
# e.g. '[user]' or '[user, api]'
# Include 'user' if the change is relevant to end users.
# Include 'api' if there is a change to a library API.
# Default: '[user]'
change_logs: []
27 changes: 12 additions & 15 deletions connector/exceptionsconnector/connector.go
Original file line number Diff line number Diff line change
@@ -6,6 +6,8 @@ package exceptionsconnector // import "github.com/open-telemetry/opentelemetry-c
import (
"go.opentelemetry.io/collector/pdata/pcommon"
conventions "go.opentelemetry.io/collector/semconv/v1.18.0"

"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

const (
@@ -20,21 +22,16 @@ const (
eventNameExc = "exception" // OpenTelemetry non-standard constant.
)

type dimension struct {
name string
value *pcommon.Value
}

func newDimensions(cfgDims []Dimension) []dimension {
func newDimensions(cfgDims []Dimension) []pdatautil.Dimension {
if len(cfgDims) == 0 {
return nil
}
dims := make([]dimension, len(cfgDims))
dims := make([]pdatautil.Dimension, len(cfgDims))
for i := range cfgDims {
dims[i].name = cfgDims[i].Name
dims[i].Name = cfgDims[i].Name
if cfgDims[i].Default != nil {
val := pcommon.NewValueStr(*cfgDims[i].Default)
dims[i].value = &val
dims[i].Value = &val
}
}
return dims
@@ -47,21 +44,21 @@ func newDimensions(cfgDims []Dimension) []dimension {
//
// The ok flag indicates if a dimension value was fetched in order to differentiate
// an empty string value from a state where no value was found.
func getDimensionValue(d dimension, spanAttrs pcommon.Map, eventAttrs pcommon.Map, resourceAttr pcommon.Map) (v pcommon.Value, ok bool) {
func getDimensionValue(d pdatautil.Dimension, spanAttrs pcommon.Map, eventAttrs pcommon.Map, resourceAttr pcommon.Map) (v pcommon.Value, ok bool) {
// The more specific span attribute should take precedence.
if attr, exists := spanAttrs.Get(d.name); exists {
if attr, exists := spanAttrs.Get(d.Name); exists {
return attr, true
}
if attr, exists := eventAttrs.Get(d.name); exists {
if attr, exists := eventAttrs.Get(d.Name); exists {
return attr, true
}
// falling back to searching in resource attributes
if attr, exists := resourceAttr.Get(d.name); exists {
if attr, exists := resourceAttr.Get(d.Name); exists {
return attr, true
}
// Set the default if configured, otherwise this metric will have no value set for the dimension.
if d.value != nil {
return *d.value, true
if d.Value != nil {
return *d.Value, true
}
return v, ok
}
18 changes: 6 additions & 12 deletions connector/exceptionsconnector/connector_logs.go
Original file line number Diff line number Diff line change
@@ -15,13 +15,14 @@ import (
"go.uber.org/zap"

"github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal/traceutil"
"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

type logsConnector struct {
config Config

// Additional dimensions to add to logs.
dimensions []dimension
dimensions []pdatautil.Dimension

logsConsumer consumer.Logs
component.StartFunc
@@ -113,20 +114,13 @@ func (c *logsConnector) attrToLogRecord(sl plog.ScopeLogs, serviceName string, s

// Add configured dimension attributes to the log record.
for _, d := range c.dimensions {
if v, ok := getDimensionValue(d, spanAttrs, eventAttrs, resourceAttrs); ok {
logRecord.Attributes().PutStr(d.name, v.Str())
if v, ok := pdatautil.GetDimensionValue(d, spanAttrs, eventAttrs, resourceAttrs); ok {
logRecord.Attributes().PutStr(d.Name, v.Str())
}
}

// Add stacktrace to the log record.
logRecord.Attributes().PutStr(exceptionStacktraceKey, getValue(eventAttrs, exceptionStacktraceKey))
attrVal, _ := pdatautil.GetAttributeValue(exceptionStacktraceKey, eventAttrs)
logRecord.Attributes().PutStr(exceptionStacktraceKey, attrVal)
return logRecord
}

// getValue returns the value of the attribute with the given key.
func getValue(attr pcommon.Map, key string) string {
if attrVal, ok := attr.Get(key); ok {
return attrVal.Str()
}
return ""
}
11 changes: 6 additions & 5 deletions connector/exceptionsconnector/connector_metrics.go
Original file line number Diff line number Diff line change
@@ -18,6 +18,7 @@ import (
"go.uber.org/zap"

"github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal/traceutil"
"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

const (
@@ -29,7 +30,7 @@ type metricsConnector struct {
config Config

// Additional dimensions to add to metrics.
dimensions []dimension
dimensions []pdatautil.Dimension

keyBuf *bytes.Buffer

@@ -175,16 +176,16 @@ func (c *metricsConnector) addExemplar(exc *exception, traceID pcommon.TraceID,
e.SetDoubleValue(float64(exc.count))
}

func buildDimensionKVs(dimensions []dimension, serviceName string, span ptrace.Span, eventAttrs pcommon.Map, resourceAttrs pcommon.Map) pcommon.Map {
func buildDimensionKVs(dimensions []pdatautil.Dimension, serviceName string, span ptrace.Span, eventAttrs pcommon.Map, resourceAttrs pcommon.Map) pcommon.Map {
dims := pcommon.NewMap()
dims.EnsureCapacity(3 + len(dimensions))
dims.PutStr(serviceNameKey, serviceName)
dims.PutStr(spanNameKey, span.Name())
dims.PutStr(spanKindKey, traceutil.SpanKindStr(span.Kind()))
dims.PutStr(statusCodeKey, traceutil.StatusCodeStr(span.Status().Code()))
for _, d := range dimensions {
if v, ok := getDimensionValue(d, span.Attributes(), eventAttrs, resourceAttrs); ok {
v.CopyTo(dims.PutEmpty(d.name))
if v, ok := pdatautil.GetDimensionValue(d, span.Attributes(), eventAttrs, resourceAttrs); ok {
v.CopyTo(dims.PutEmpty(d.Name))
}
}
return dims
@@ -195,7 +196,7 @@ func buildDimensionKVs(dimensions []dimension, serviceName string, span ptrace.S
// or resource attributes. If the dimension exists in both, the span's attributes, being the most specific, takes precedence.
//
// The metric key is a simple concatenation of dimension values, delimited by a null character.
func buildKey(dest *bytes.Buffer, serviceName string, span ptrace.Span, optionalDims []dimension, eventAttrs pcommon.Map, resourceAttrs pcommon.Map) {
func buildKey(dest *bytes.Buffer, serviceName string, span ptrace.Span, optionalDims []pdatautil.Dimension, eventAttrs pcommon.Map, resourceAttrs pcommon.Map) {
concatDimensionValue(dest, serviceName, false)
concatDimensionValue(dest, span.Name(), true)
concatDimensionValue(dest, traceutil.SpanKindStr(span.Kind()), true)
24 changes: 13 additions & 11 deletions connector/exceptionsconnector/connector_metrics_test.go
Original file line number Diff line number Diff line change
@@ -20,6 +20,8 @@ import (
"go.uber.org/zap"
"go.uber.org/zap/zaptest"
"google.golang.org/grpc/metadata"

"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

// metricID represents the minimum attributes that uniquely identifies a metric in our tests.
@@ -277,7 +279,7 @@ func TestBuildKeyWithDimensions(t *testing.T) {
defaultFoo := pcommon.NewValueStr("bar")
for _, tc := range []struct {
name string
optionalDims []dimension
optionalDims []pdatautil.Dimension
resourceAttrMap map[string]any
spanAttrMap map[string]any
wantKey string
@@ -288,22 +290,22 @@ func TestBuildKeyWithDimensions(t *testing.T) {
},
{
name: "neither span nor resource contains key, dim provides default",
optionalDims: []dimension{
{name: "foo", value: &defaultFoo},
optionalDims: []pdatautil.Dimension{
{Name: "foo", Value: &defaultFoo},
},
wantKey: "ab\u0000c\u0000SPAN_KIND_UNSPECIFIED\u0000STATUS_CODE_UNSET\u0000bar",
},
{
name: "neither span nor resource contains key, dim provides no default",
optionalDims: []dimension{
{name: "foo"},
optionalDims: []pdatautil.Dimension{
{Name: "foo"},
},
wantKey: "ab\u0000c\u0000SPAN_KIND_UNSPECIFIED\u0000STATUS_CODE_UNSET",
},
{
name: "span attribute contains dimension",
optionalDims: []dimension{
{name: "foo"},
optionalDims: []pdatautil.Dimension{
{Name: "foo"},
},
spanAttrMap: map[string]any{
"foo": 99,
@@ -312,8 +314,8 @@ func TestBuildKeyWithDimensions(t *testing.T) {
},
{
name: "resource attribute contains dimension",
optionalDims: []dimension{
{name: "foo"},
optionalDims: []pdatautil.Dimension{
{Name: "foo"},
},
resourceAttrMap: map[string]any{
"foo": 99,
@@ -322,8 +324,8 @@ func TestBuildKeyWithDimensions(t *testing.T) {
},
{
name: "both span and resource attribute contains dimension, should prefer span attribute",
optionalDims: []dimension{
{name: "foo"},
optionalDims: []pdatautil.Dimension{
{Name: "foo"},
},
spanAttrMap: map[string]any{
"foo": 100,
10 changes: 6 additions & 4 deletions connector/exceptionsconnector/factory_test.go
Original file line number Diff line number Diff line change
@@ -11,6 +11,8 @@ import (
"go.opentelemetry.io/collector/connector/connectortest"
"go.opentelemetry.io/collector/consumer/consumertest"
"go.opentelemetry.io/collector/pdata/pcommon"

"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

func TestNewConnector(t *testing.T) {
@@ -19,7 +21,7 @@ func TestNewConnector(t *testing.T) {
for _, tc := range []struct {
name string
dimensions []Dimension
wantDimensions []dimension
wantDimensions []pdatautil.Dimension
}{
{
name: "simplest config (use defaults)",
@@ -30,9 +32,9 @@ func TestNewConnector(t *testing.T) {
{Name: "http.method", Default: &defaultMethod},
{Name: "http.status_code"},
},
wantDimensions: []dimension{
{name: "http.method", value: &defaultMethodValue},
{"http.status_code", nil},
wantDimensions: []pdatautil.Dimension{
{Name: "http.method", Value: &defaultMethodValue},
{Name: "http.status_code", Value: nil},
},
},
} {
5 changes: 4 additions & 1 deletion connector/exceptionsconnector/go.mod
Original file line number Diff line number Diff line change
@@ -4,6 +4,7 @@ go 1.22.0

require (
github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal v0.108.0
github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil v0.108.0
github.com/open-telemetry/opentelemetry-collector-contrib/pkg/golden v0.108.0
github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatatest v0.108.0
github.com/stretchr/testify v1.9.0
@@ -67,8 +68,10 @@ require (

replace github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal => ../../internal/coreinternal

replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatautil => ../../pkg/pdatautil
replace github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil => ../../internal/pdatautil

replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatatest => ../../pkg/pdatatest

replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/golden => ../../pkg/golden

replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatautil => ../../pkg/pdatautil
7 changes: 4 additions & 3 deletions connector/servicegraphconnector/connector.go
Original file line number Diff line number Diff line change
@@ -24,6 +24,7 @@ import (

"github.com/open-telemetry/opentelemetry-collector-contrib/connector/servicegraphconnector/internal/metadata"
"github.com/open-telemetry/opentelemetry-collector-contrib/connector/servicegraphconnector/internal/store"
"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

const (
@@ -264,7 +265,7 @@ func (p *serviceGraphConnector) aggregateMetrics(ctx context.Context, td ptrace.

// A database request will only have one span, we don't wait for the server
// span but just copy details from the client span
if dbName, ok := findAttributeValue(p.config.DatabaseNameAttribute, rAttributes, span.Attributes()); ok {
if dbName, ok := pdatautil.GetAttributeValue(p.config.DatabaseNameAttribute, rAttributes, span.Attributes()); ok {
e.ConnectionType = store.Database
e.ServerService = dbName
e.ServerLatencySec = spanDuration(span)
@@ -312,15 +313,15 @@ func (p *serviceGraphConnector) aggregateMetrics(ctx context.Context, td ptrace.

func (p *serviceGraphConnector) upsertDimensions(kind string, m map[string]string, resourceAttr pcommon.Map, spanAttr pcommon.Map) {
for _, dim := range p.config.Dimensions {
if v, ok := findAttributeValue(dim, resourceAttr, spanAttr); ok {
if v, ok := pdatautil.GetAttributeValue(dim, resourceAttr, spanAttr); ok {
m[kind+"_"+dim] = v
}
}
}

func (p *serviceGraphConnector) upsertPeerAttributes(m []string, peers map[string]string, spanAttr pcommon.Map) {
for _, s := range m {
if v, ok := findAttributeValue(s, spanAttr); ok {
if v, ok := pdatautil.GetAttributeValue(s, spanAttr); ok {
peers[s] = v
break
}
3 changes: 3 additions & 0 deletions connector/servicegraphconnector/go.mod
Original file line number Diff line number Diff line change
@@ -3,6 +3,7 @@ module github.com/open-telemetry/opentelemetry-collector-contrib/connector/servi
go 1.22.0

require (
github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil v0.108.0
github.com/open-telemetry/opentelemetry-collector-contrib/pkg/golden v0.108.0
github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatatest v0.108.0
github.com/stretchr/testify v1.9.0
@@ -123,4 +124,6 @@ replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/golden =>

replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatatest => ../../pkg/pdatatest

replace github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil => ../../internal/pdatautil

replace github.com/open-telemetry/opentelemetry-collector-contrib/pkg/pdatautil => ../../pkg/pdatautil
13 changes: 3 additions & 10 deletions connector/servicegraphconnector/util.go
Original file line number Diff line number Diff line change
@@ -6,17 +6,10 @@ package servicegraphconnector // import "github.com/open-telemetry/opentelemetry
import (
"go.opentelemetry.io/collector/pdata/pcommon"
semconv "go.opentelemetry.io/collector/semconv/v1.9.0"
)

func findAttributeValue(key string, attributes ...pcommon.Map) (string, bool) {
for _, attr := range attributes {
if v, ok := attr.Get(key); ok {
return v.AsString(), true
}
}
return "", false
}
"github.com/open-telemetry/opentelemetry-collector-contrib/internal/pdatautil"
)

func findServiceName(attributes pcommon.Map) (string, bool) {
return findAttributeValue(semconv.AttributeServiceName, attributes)
return pdatautil.GetAttributeValue(semconv.AttributeServiceName, attributes)
}
Loading