mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-12 02:28:07 +02:00
Add disabled field for jaeger exporter
This commit is contained in:
parent
c367f256a2
commit
a234027fde
@ -18,13 +18,12 @@ import (
|
||||
"context"
|
||||
"encoding/binary"
|
||||
|
||||
"go.opentelemetry.io/otel/api/kv/value"
|
||||
|
||||
"google.golang.org/api/support/bundler"
|
||||
"google.golang.org/grpc/codes"
|
||||
|
||||
"go.opentelemetry.io/otel/api/global"
|
||||
"go.opentelemetry.io/otel/api/kv"
|
||||
"go.opentelemetry.io/otel/api/kv/value"
|
||||
gen "go.opentelemetry.io/otel/exporters/trace/jaeger/internal/gen-go/jaeger"
|
||||
export "go.opentelemetry.io/otel/sdk/export/trace"
|
||||
sdktrace "go.opentelemetry.io/otel/sdk/trace"
|
||||
@ -47,6 +46,8 @@ type options struct {
|
||||
// RegisterGlobal is set to true if the trace provider of the new pipeline should be
|
||||
// registered as Global Trace Provider
|
||||
RegisterGlobal bool
|
||||
|
||||
Disabled bool
|
||||
}
|
||||
|
||||
// WithProcess sets the process with the information about the exporting process.
|
||||
@ -78,18 +79,29 @@ func RegisterAsGlobal() Option {
|
||||
}
|
||||
}
|
||||
|
||||
func WithDisabled(disabled bool) Option {
|
||||
return func(o *options) {
|
||||
o.Disabled = disabled
|
||||
}
|
||||
}
|
||||
|
||||
// NewRawExporter returns a trace.Exporter implementation that exports
|
||||
// the collected spans to Jaeger.
|
||||
func NewRawExporter(endpointOption EndpointOption, opts ...Option) (*Exporter, error) {
|
||||
uploader, err := endpointOption()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
o := options{}
|
||||
for _, opt := range opts {
|
||||
opt(&o)
|
||||
}
|
||||
if o.Disabled {
|
||||
return &Exporter{
|
||||
o: o,
|
||||
}, nil
|
||||
}
|
||||
|
||||
uploader, err := endpointOption()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
service := o.Process.ServiceName
|
||||
if service == "" {
|
||||
@ -171,6 +183,9 @@ var _ export.SpanSyncer = (*Exporter)(nil)
|
||||
|
||||
// ExportSpan exports a SpanData to Jaeger.
|
||||
func (e *Exporter) ExportSpan(ctx context.Context, d *export.SpanData) {
|
||||
if e.o.Disabled {
|
||||
return
|
||||
}
|
||||
_ = e.bundler.Add(spanDataToThrift(d), 1)
|
||||
// TODO(jbd): Handle oversized bundlers.
|
||||
}
|
||||
@ -328,10 +343,16 @@ func getBoolTag(k string, b bool) *gen.Tag {
|
||||
//
|
||||
// This is useful if your program is ending and you do not want to lose recent spans.
|
||||
func (e *Exporter) Flush() {
|
||||
if e.o.Disabled {
|
||||
return
|
||||
}
|
||||
e.bundler.Flush()
|
||||
}
|
||||
|
||||
func (e *Exporter) upload(spans []*gen.Span) error {
|
||||
if e.o.Disabled {
|
||||
return nil
|
||||
}
|
||||
batch := &gen.Batch{
|
||||
Spans: spans,
|
||||
Process: e.process,
|
||||
|
@ -303,3 +303,22 @@ func Test_spanDataToThrift(t *testing.T) {
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func TestNewRawExporterWithDisabled(t *testing.T) {
|
||||
const (
|
||||
collectorEndpoint = "http://localhost"
|
||||
)
|
||||
// Create Jaeger Exporter
|
||||
exp, err := NewRawExporter(
|
||||
WithCollectorEndpoint(collectorEndpoint),
|
||||
WithDisabled(true),
|
||||
)
|
||||
|
||||
assert.NoError(t, err)
|
||||
assert.EqualValues(t, true, exp.o.Disabled)
|
||||
|
||||
// Ensure we can still normally invoke function
|
||||
assert.NoError(t, exp.upload([]*gen.Span{}))
|
||||
exp.ExportSpan(context.Background(), &export.SpanData{})
|
||||
exp.Flush()
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user