1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2025-01-24 03:47:19 +02:00
opentelemetry-go/propagators/b3_data_test.go
Tyler Yahn f1dad21e47
Move propagators out of API and into their own package (#1118)
* Add new propagators package

* Move B3 propagator to propagators

Update all `api/trace` dependencies in the propagator.

Export the isDeferred and isDebug methods of the SpanContext. These are
needed by the B3 propagator to track trace state.

* Move W3C trace context propagator to propagators

* Update package docs with supported encodings

* Move unified propagators code to own file

* Update b3 exported documentation

* Update trace_context exported documentation

* Add code examples for B3 propagator

* Add TraceContext example code

* Remove internal package

Move common testing declarations to the propagators_test.go file.

* Add changes to Changelog

* Add test to check default propagators
2020-09-08 19:07:59 -04:00

1022 lines
22 KiB
Go

// Copyright The OpenTelemetry Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package propagators_test
import (
"fmt"
"go.opentelemetry.io/otel/api/trace"
"go.opentelemetry.io/otel/propagators"
)
const (
b3Context = "b3"
b3Flags = "x-b3-flags"
b3TraceID = "x-b3-traceid"
b3SpanID = "x-b3-spanid"
b3Sampled = "x-b3-sampled"
b3ParentSpanID = "x-b3-parentspanid"
)
type extractTest struct {
name string
headers map[string]string
wantSc trace.SpanContext
}
var (
traceID64bitPadded = mustTraceIDFromHex("0000000000000000a3ce929d0e0e4736")
)
var extractHeaders = []extractTest{
{
name: "empty",
headers: map[string]string{},
wantSc: trace.EmptySpanContext(),
},
{
name: "multiple: sampling state defer",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
},
{
name: "multiple: sampling state deny",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
},
{
name: "multiple: sampling state accept",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "1",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "multiple: sampling state as a boolean: true",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "true",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "multiple: sampling state as a boolean: false",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "false",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
},
{
name: "multiple: debug flag set",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred | trace.FlagsDebug,
},
},
{
name: "multiple: debug flag set to not 1 (ignored)",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "1",
b3Flags: "2",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
// spec explicitly states "Debug implies an accept decision, so don't
// also send the X-B3-Sampled header", make sure sampling is
// deferred.
name: "multiple: debug flag set and sampling state is deny",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
b3Flags: "1",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDebug,
},
},
{
name: "multiple: with parent span id",
headers: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "1",
b3ParentSpanID: "00f067aa0ba90200",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "multiple: with only sampled state header",
headers: map[string]string{
b3Sampled: "0",
},
wantSc: trace.EmptySpanContext(),
},
{
name: "multiple: left-padding 64-bit traceID",
headers: map[string]string{
b3TraceID: "a3ce929d0e0e4736",
b3SpanID: spanIDStr,
},
wantSc: trace.SpanContext{
TraceID: traceID64bitPadded,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
},
{
name: "single: sampling state defer",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s", traceIDStr, spanIDStr),
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
},
{
name: "single: sampling state deny",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-0", traceIDStr, spanIDStr),
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
},
{
name: "single: sampling state accept",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-1", traceIDStr, spanIDStr),
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "single: sampling state debug",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-d", traceIDStr, spanIDStr),
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDebug,
},
},
{
name: "single: with parent span id",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-1-00000000000000cd", traceIDStr, spanIDStr),
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "single: with only sampling state deny",
headers: map[string]string{
b3Context: "0",
},
wantSc: trace.EmptySpanContext(),
},
{
name: "single: left-padding 64-bit traceID",
headers: map[string]string{
b3Context: fmt.Sprintf("a3ce929d0e0e4736-%s", spanIDStr),
},
wantSc: trace.SpanContext{
TraceID: traceID64bitPadded,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
},
{
name: "both single and multiple: single priority",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-1", traceIDStr, spanIDStr),
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
// An invalid Single Headers should fallback to multiple.
{
name: "both single and multiple: invalid single",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-", traceIDStr, spanIDStr),
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
},
// Invalid Mult Header should not be noticed as Single takes precedence.
{
name: "both single and multiple: invalid multiple",
headers: map[string]string{
b3Context: fmt.Sprintf("%s-%s-1", traceIDStr, spanIDStr),
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "invalid",
},
wantSc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
}
var extractInvalidHeaders = []extractTest{
{
name: "multiple: trace ID length > 32",
headers: map[string]string{
b3TraceID: "ab00000000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: trace ID length >16 and <32",
headers: map[string]string{
b3TraceID: "ab0000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: trace ID length <16",
headers: map[string]string{
b3TraceID: "ab0000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: wrong span ID length",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3SpanID: "cd0000000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: wrong sampled flag length",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "10",
},
},
{
name: "multiple: bogus trace ID",
headers: map[string]string{
b3TraceID: "qw000000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: bogus span ID",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3SpanID: "qw00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: bogus sampled flag",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "d",
},
},
{
name: "multiple: upper case trace ID",
headers: map[string]string{
b3TraceID: "AB000000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: upper case span ID",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3SpanID: "CD00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: zero trace ID",
headers: map[string]string{
b3TraceID: "00000000000000000000000000000000",
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: zero span ID",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3SpanID: "0000000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: missing span ID",
headers: map[string]string{
b3TraceID: "ab000000000000000000000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: missing trace ID",
headers: map[string]string{
b3SpanID: "cd00000000000000",
b3Sampled: "1",
},
},
{
name: "multiple: sampled header set to 1 but trace ID and span ID are missing",
headers: map[string]string{
b3Sampled: "1",
},
},
{
name: "single: wrong trace ID length",
headers: map[string]string{
b3Context: "ab00000000000000000000000000000000-cd00000000000000-1",
},
},
{
name: "single: wrong span ID length",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-cd0000000000000000-1",
},
},
{
name: "single: wrong sampled state length",
headers: map[string]string{
b3Context: "00-ab000000000000000000000000000000-cd00000000000000-01",
},
},
{
name: "single: wrong parent span ID length",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-cd00000000000000-1-cd0000000000000000",
},
},
{
name: "single: bogus trace ID",
headers: map[string]string{
b3Context: "qw000000000000000000000000000000-cd00000000000000-1",
},
},
{
name: "single: bogus span ID",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-qw00000000000000-1",
},
},
{
name: "single: bogus sampled flag",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-cd00000000000000-q",
},
},
{
name: "single: bogus parent span ID",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-cd00000000000000-1-qw00000000000000",
},
},
{
name: "single: upper case trace ID",
headers: map[string]string{
b3Context: "AB000000000000000000000000000000-cd00000000000000-1",
},
},
{
name: "single: upper case span ID",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-CD00000000000000-1",
},
},
{
name: "single: upper case parent span ID",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-cd00000000000000-1-EF00000000000000",
},
},
{
name: "single: zero trace ID and span ID",
headers: map[string]string{
b3Context: "00000000000000000000000000000000-0000000000000000-1",
},
},
{
name: "single: with sampling set to true",
headers: map[string]string{
b3Context: "ab000000000000000000000000000000-cd00000000000000-true",
},
},
}
type injectTest struct {
name string
encoding propagators.B3Encoding
sc trace.SpanContext
wantHeaders map[string]string
doNotWantHeaders []string
}
var injectHeader = []injectTest{
{
name: "none: sampled",
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "1",
},
doNotWantHeaders: []string{
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "none: not sampled",
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
},
doNotWantHeaders: []string{
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "none: unset sampled",
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "none: sampled only",
sc: trace.SpanContext{
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3Sampled: "1",
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "none: debug",
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Context,
},
},
{
name: "none: debug omitting sample",
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled | trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Context,
},
},
{
name: "multiple: sampled",
encoding: propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "1",
},
doNotWantHeaders: []string{
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "multiple: not sampled",
encoding: propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
},
doNotWantHeaders: []string{
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "multiple: unset sampled",
encoding: propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "multiple: sampled only",
encoding: propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3Sampled: "1",
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "multiple: debug",
encoding: propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Context,
},
},
{
name: "multiple: debug omitting sample",
encoding: propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled | trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Context,
},
},
{
name: "single: sampled",
encoding: propagators.B3SingleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3Context: fmt.Sprintf("%s-%s-1", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3Sampled,
b3ParentSpanID,
b3Flags,
},
},
{
name: "single: not sampled",
encoding: propagators.B3SingleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
wantHeaders: map[string]string{
b3Context: fmt.Sprintf("%s-%s-0", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3Sampled,
b3ParentSpanID,
b3Flags,
},
},
{
name: "single: unset sampled",
encoding: propagators.B3SingleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
wantHeaders: map[string]string{
b3Context: fmt.Sprintf("%s-%s", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3Sampled,
b3ParentSpanID,
b3Flags,
},
},
{
name: "single: sampled only",
encoding: propagators.B3SingleHeader,
sc: trace.SpanContext{
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3Context: "1",
},
doNotWantHeaders: []string{
b3Sampled,
b3TraceID,
b3SpanID,
b3ParentSpanID,
b3Flags,
b3Context,
},
},
{
name: "single: debug",
encoding: propagators.B3SingleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3Context: fmt.Sprintf("%s-%s-d", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3Flags,
b3Sampled,
b3ParentSpanID,
b3Context,
},
},
{
name: "single: debug omitting sample",
encoding: propagators.B3SingleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled | trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3Context: fmt.Sprintf("%s-%s-d", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3Flags,
b3Sampled,
b3ParentSpanID,
b3Context,
},
},
{
name: "single+multiple: sampled",
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "1",
b3Context: fmt.Sprintf("%s-%s-1", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3ParentSpanID,
b3Flags,
},
},
{
name: "single+multiple: not sampled",
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Sampled: "0",
b3Context: fmt.Sprintf("%s-%s-0", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3ParentSpanID,
b3Flags,
},
},
{
name: "single+multiple: unset sampled",
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDeferred,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Context: fmt.Sprintf("%s-%s", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
b3Flags,
},
},
{
name: "single+multiple: sampled only",
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceFlags: trace.FlagsSampled,
},
wantHeaders: map[string]string{
b3Context: "1",
b3Sampled: "1",
},
doNotWantHeaders: []string{
b3TraceID,
b3SpanID,
b3ParentSpanID,
b3Flags,
},
},
{
name: "single+multiple: debug",
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
b3Context: fmt.Sprintf("%s-%s-d", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
},
},
{
name: "single+multiple: debug omitting sample",
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: trace.SpanContext{
TraceID: traceID,
SpanID: spanID,
TraceFlags: trace.FlagsSampled | trace.FlagsDebug,
},
wantHeaders: map[string]string{
b3TraceID: traceIDStr,
b3SpanID: spanIDStr,
b3Flags: "1",
b3Context: fmt.Sprintf("%s-%s-d", traceIDStr, spanIDStr),
},
doNotWantHeaders: []string{
b3Sampled,
b3ParentSpanID,
},
},
}
var injectInvalidHeaderGenerator = []injectTest{
{
name: "empty",
sc: trace.SpanContext{},
},
{
name: "missing traceID",
sc: trace.SpanContext{
SpanID: spanID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "missing spanID",
sc: trace.SpanContext{
TraceID: traceID,
TraceFlags: trace.FlagsSampled,
},
},
{
name: "missing traceID and spanID",
sc: trace.SpanContext{
TraceFlags: trace.FlagsSampled,
},
},
}
var injectInvalidHeader []injectTest
func init() {
// Preform a test for each invalid injectTest with all combinations of
// encoding values.
injectInvalidHeader = make([]injectTest, 0, len(injectInvalidHeaderGenerator)*4)
allHeaders := []string{
b3TraceID,
b3SpanID,
b3Sampled,
b3ParentSpanID,
b3Flags,
b3Context,
}
// Nothing should be set for any header regardless of encoding.
for _, t := range injectInvalidHeaderGenerator {
injectInvalidHeader = append(injectInvalidHeader, injectTest{
name: "none: " + t.name,
sc: t.sc,
doNotWantHeaders: allHeaders,
})
injectInvalidHeader = append(injectInvalidHeader, injectTest{
name: "multiple: " + t.name,
encoding: propagators.B3MultipleHeader,
sc: t.sc,
doNotWantHeaders: allHeaders,
})
injectInvalidHeader = append(injectInvalidHeader, injectTest{
name: "single: " + t.name,
encoding: propagators.B3SingleHeader,
sc: t.sc,
doNotWantHeaders: allHeaders,
})
injectInvalidHeader = append(injectInvalidHeader, injectTest{
name: "single+multiple: " + t.name,
encoding: propagators.B3SingleHeader | propagators.B3MultipleHeader,
sc: t.sc,
doNotWantHeaders: allHeaders,
})
}
}