Skip to content

Commit

Permalink
feat(autoexport): change WithFallback options signatures (#4891)
Browse files Browse the repository at this point in the history
* feat(autoexport): change WithFallback options signatures

Fixes #4877. Changes the method signatures as requested in the issue.

* chore: apply changelog suggestion

Co-authored-by: Tyler Yahn <[email protected]>

* chore(autoexport): get rid hasFallback flag which became extra after fallbackFactory change

---------

Co-authored-by: Tyler Yahn <[email protected]>
  • Loading branch information
hcelaloner and MrAlias authored Feb 6, 2024
1 parent a1b4b4d commit 144c933
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 16 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,12 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
- Add client metric support to `go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp`. (#4707)
- Add peer attributes to spans recorded by `NewClientHandler`, `NewServerHandler` in `go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc`. (#4873)

### Changed

- The fallback options in `go.opentelemetry.io/contrib/exporters/autoexport` now accept factory functions. (#4891)
- `WithFallbackMetricReader(metric.Reader) MetricOption` is replaced with `func WithFallbackMetricReader(func(ctx context.Context) (metric.Reader, error)) MetricOption`.
- `WithFallbackSpanExporter(trace.SpanExporter) SpanOption` is replaced with `WithFallbackSpanExporter(func(ctx context.Context) (trace.SpanExporter, error)) SpanOption`.

### Deprecated

- The `RequestCount`, `RequestContentLength`, `ResponseContentLength`, `ServerLatency` constants in `go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp` are deprecated. (#4707)
Expand Down
4 changes: 2 additions & 2 deletions exporters/autoexport/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,8 @@ type MetricOption = option[metric.Reader]

// WithFallbackMetricReader sets the fallback exporter to use when no exporter
// is configured through the OTEL_METRICS_EXPORTER environment variable.
func WithFallbackMetricReader(exporter metric.Reader) MetricOption {
return withFallback[metric.Reader](exporter)
func WithFallbackMetricReader(metricReaderFactory func(ctx context.Context) (metric.Reader, error)) MetricOption {
return withFallbackFactory[metric.Reader](metricReaderFactory)
}

// NewMetricReader returns a configured [go.opentelemetry.io/otel/sdk/metric.Reader]
Expand Down
12 changes: 5 additions & 7 deletions exporters/autoexport/signal.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,8 @@ func (s signal[T]) create(ctx context.Context, opts ...option[T]) (T, error) {

expType := os.Getenv(s.envKey)
if expType == "" {
if cfg.hasFallback {
return cfg.fallback, nil
if cfg.fallbackFactory != nil {
return cfg.fallbackFactory(ctx)
}
expType = "otlp"
}
Expand All @@ -51,8 +51,7 @@ func (s signal[T]) create(ctx context.Context, opts ...option[T]) (T, error) {
}

type config[T any] struct {
hasFallback bool
fallback T
fallbackFactory func(ctx context.Context) (T, error)
}

type option[T any] interface {
Expand All @@ -66,9 +65,8 @@ func (fn optionFunc[T]) apply(cfg *config[T]) {
fn(cfg)
}

func withFallback[T any](fallback T) option[T] {
func withFallbackFactory[T any](fallbackFactory func(ctx context.Context) (T, error)) option[T] {
return optionFunc[T](func(cfg *config[T]) {
cfg.hasFallback = true
cfg.fallback = fallback
cfg.fallbackFactory = fallbackFactory
})
}
21 changes: 16 additions & 5 deletions exporters/autoexport/signal_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ package autoexport // import "go.opentelemetry.io/contrib/exporters/autoexport"

import (
"context"
"errors"
"testing"

"github.com/stretchr/testify/assert"
Expand All @@ -31,10 +32,21 @@ func TestOTLPExporterReturnedWhenNoEnvOrFallbackExporterConfigured(t *testing.T)

func TestFallbackExporterReturnedWhenNoEnvExporterConfigured(t *testing.T) {
ts := newSignal[*testType]("TEST_TYPE_KEY")
fallback := testType{"test-fallback-exporter"}
exp, err := ts.create(context.Background(), withFallback(&fallback))
exp, err := ts.create(context.Background(), withFallbackFactory(factory("test-fallback-exporter")))
assert.NoError(t, err)
assert.Same(t, &fallback, exp)
assert.Equal(t, exp.string, "test-fallback-exporter")
}

func TestFallbackExporterFactoryErrorReturnedWhenNoEnvExporterConfiguredAndFallbackFactoryReturnsAnError(t *testing.T) {
ts := newSignal[*testType]("TEST_TYPE_KEY")

expectedErr := errors.New("error expected to return")
errFactory := func(ctx context.Context) (*testType, error) {
return nil, expectedErr
}
exp, err := ts.create(context.Background(), withFallbackFactory(errFactory))
assert.ErrorIs(t, err, expectedErr)
assert.Nil(t, exp)
}

func TestEnvExporterIsPreferredOverFallbackExporter(t *testing.T) {
Expand All @@ -43,10 +55,9 @@ func TestEnvExporterIsPreferredOverFallbackExporter(t *testing.T) {

expName := "test-env-exporter-name"
t.Setenv(envVariable, expName)
fallback := testType{"test-fallback-exporter"}
assert.NoError(t, ts.registry.store(expName, factory("test-env-exporter")))

exp, err := ts.create(context.Background(), withFallback(&fallback))
exp, err := ts.create(context.Background(), withFallbackFactory(factory("test-fallback-exporter")))
assert.NoError(t, err)
assert.Equal(t, exp.string, "test-env-exporter")
}
4 changes: 2 additions & 2 deletions exporters/autoexport/spans.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,8 @@ type Option = SpanOption

// WithFallbackSpanExporter sets the fallback exporter to use when no exporter
// is configured through the OTEL_TRACES_EXPORTER environment variable.
func WithFallbackSpanExporter(exporter trace.SpanExporter) SpanOption {
return withFallback[trace.SpanExporter](exporter)
func WithFallbackSpanExporter(spanExporterFactory func(ctx context.Context) (trace.SpanExporter, error)) SpanOption {
return withFallbackFactory[trace.SpanExporter](spanExporterFactory)
}

// NewSpanExporter returns a configured [go.opentelemetry.io/otel/sdk/trace.SpanExporter]
Expand Down

0 comments on commit 144c933

Please sign in to comment.