2020-07-28 10:47:08 -07:00
|
|
|
// 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.
|
|
|
|
|
2020-11-04 18:10:58 +01:00
|
|
|
package oteltest // import "go.opentelemetry.io/otel/oteltest"
|
2020-07-28 10:47:08 -07:00
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
|
2020-11-06 23:13:31 +01:00
|
|
|
"go.opentelemetry.io/otel/trace"
|
2020-07-28 10:47:08 -07:00
|
|
|
)
|
|
|
|
|
2020-10-13 12:27:53 -07:00
|
|
|
// TracerProvider is a testing TracerProvider. It is an functioning
|
|
|
|
// implementation of an OpenTelemetry TracerProvider and can be configured
|
|
|
|
// with a SpanRecorder that it configure all Tracers it creates to record
|
|
|
|
// their Spans with.
|
2020-09-23 15:16:13 -07:00
|
|
|
type TracerProvider struct {
|
2020-07-28 10:47:08 -07:00
|
|
|
config config
|
|
|
|
|
|
|
|
tracersMu sync.Mutex
|
|
|
|
tracers map[instrumentation]*Tracer
|
|
|
|
}
|
|
|
|
|
2020-11-06 23:13:31 +01:00
|
|
|
var _ trace.TracerProvider = (*TracerProvider)(nil)
|
2020-07-28 10:47:08 -07:00
|
|
|
|
2020-10-13 12:27:53 -07:00
|
|
|
// NewTracerProvider returns a *TracerProvider configured with options.
|
|
|
|
func NewTracerProvider(options ...Option) *TracerProvider {
|
2020-09-23 15:16:13 -07:00
|
|
|
return &TracerProvider{
|
2020-10-13 12:27:53 -07:00
|
|
|
config: newConfig(options...),
|
2020-07-28 10:47:08 -07:00
|
|
|
tracers: make(map[instrumentation]*Tracer),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type instrumentation struct {
|
|
|
|
Name, Version string
|
|
|
|
}
|
|
|
|
|
2020-10-13 12:27:53 -07:00
|
|
|
// Tracer returns an OpenTelemetry Tracer used for testing.
|
2020-11-06 23:13:31 +01:00
|
|
|
func (p *TracerProvider) Tracer(instName string, opts ...trace.TracerOption) trace.Tracer {
|
|
|
|
conf := trace.NewTracerConfig(opts...)
|
2020-09-10 12:15:17 -07:00
|
|
|
|
2020-07-28 10:47:08 -07:00
|
|
|
inst := instrumentation{
|
|
|
|
Name: instName,
|
|
|
|
Version: conf.InstrumentationVersion,
|
|
|
|
}
|
|
|
|
p.tracersMu.Lock()
|
|
|
|
defer p.tracersMu.Unlock()
|
|
|
|
t, ok := p.tracers[inst]
|
|
|
|
if !ok {
|
|
|
|
t = &Tracer{
|
|
|
|
Name: instName,
|
|
|
|
Version: conf.InstrumentationVersion,
|
|
|
|
config: &p.config,
|
|
|
|
}
|
|
|
|
p.tracers[inst] = t
|
|
|
|
}
|
|
|
|
return t
|
|
|
|
}
|
2020-11-05 17:13:19 +01:00
|
|
|
|
2021-04-27 22:27:12 +08:00
|
|
|
// DefaultTracer returns a default tracer for testing purposes.
|
2020-11-06 23:13:31 +01:00
|
|
|
func DefaultTracer() trace.Tracer {
|
2020-11-05 17:13:19 +01:00
|
|
|
return NewTracerProvider().Tracer("")
|
|
|
|
}
|