You've already forked opentelemetry-go
mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-12-05 23:28:07 +02:00
Based on the Go version we currently use, the dependency already supports 1.24+, which allows using `t.Context()` and `b.Context()` in unit tests and benchmarks respectively. - Enable `context-background` and `context-todo` in [`usetesting`](https://golangci-lint.run/docs/linters/configuration/#usetesting) - Adjust the code to support linter detection --------- Co-authored-by: Tyler Yahn <MrAlias@users.noreply.github.com> Co-authored-by: Tyler Yahn <codingalias@gmail.com> Co-authored-by: Damien Mathieu <42@dmathieu.com>
86 lines
2.2 KiB
Go
86 lines
2.2 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package baggage
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestContextWithList(t *testing.T) {
|
|
ctx := t.Context()
|
|
l := List{"foo": {Value: "1"}}
|
|
|
|
nCtx := ContextWithList(ctx, l)
|
|
assert.Equal(t, baggageState{list: l}, nCtx.Value(baggageKey))
|
|
assert.Nil(t, ctx.Value(baggageKey))
|
|
}
|
|
|
|
func TestClearContextOfList(t *testing.T) {
|
|
l := List{"foo": {Value: "1"}}
|
|
|
|
ctx := t.Context()
|
|
ctx = context.WithValue(ctx, baggageKey, l)
|
|
|
|
nCtx := ContextWithList(ctx, nil)
|
|
nL, ok := nCtx.Value(baggageKey).(baggageState)
|
|
require.True(t, ok, "wrong type stored in context")
|
|
assert.Nil(t, nL.list)
|
|
assert.Equal(t, l, ctx.Value(baggageKey))
|
|
}
|
|
|
|
func TestListFromContext(t *testing.T) {
|
|
ctx := t.Context()
|
|
assert.Nil(t, ListFromContext(ctx))
|
|
|
|
l := List{"foo": {Value: "1"}}
|
|
ctx = context.WithValue(ctx, baggageKey, baggageState{list: l})
|
|
assert.Equal(t, l, ListFromContext(ctx))
|
|
}
|
|
|
|
func TestContextWithSetHook(t *testing.T) {
|
|
var called bool
|
|
f := func(ctx context.Context, _ List) context.Context {
|
|
called = true
|
|
return ctx
|
|
}
|
|
|
|
ctx := t.Context()
|
|
ctx = ContextWithSetHook(ctx, f)
|
|
assert.False(t, called, "SetHookFunc called when setting hook")
|
|
ctx = ContextWithList(ctx, nil)
|
|
assert.True(t, called, "SetHookFunc not called when setting List")
|
|
|
|
// Ensure resetting the hook works.
|
|
called = false
|
|
ctx = ContextWithSetHook(ctx, f)
|
|
assert.False(t, called, "SetHookFunc called when re-setting hook")
|
|
ContextWithList(ctx, nil)
|
|
assert.True(t, called, "SetHookFunc not called when re-setting List")
|
|
}
|
|
|
|
func TestContextWithGetHook(t *testing.T) {
|
|
var called bool
|
|
f := func(_ context.Context, list List) List {
|
|
called = true
|
|
return list
|
|
}
|
|
|
|
ctx := t.Context()
|
|
ctx = ContextWithGetHook(ctx, f)
|
|
assert.False(t, called, "GetHookFunc called when setting hook")
|
|
_ = ListFromContext(ctx)
|
|
assert.True(t, called, "GetHookFunc not called when getting List")
|
|
|
|
// Ensure resetting the hook works.
|
|
called = false
|
|
ctx = ContextWithGetHook(ctx, f)
|
|
assert.False(t, called, "GetHookFunc called when re-setting hook")
|
|
_ = ListFromContext(ctx)
|
|
assert.True(t, called, "GetHookFunc not called when re-getting List")
|
|
}
|