From faf89d8b00b1a1f3a8cfa06191a406f24f148a5f Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Thu, 26 May 2022 16:20:39 -0400 Subject: [PATCH 1/8] OTLP receiver Signed-off-by: Yuri Shkuro --- cmd/collector/app/collector.go | 24 +++- cmd/collector/app/handler/grpc_handler.go | 2 +- cmd/collector/app/handler/otlp_receiver.go | 108 +++++++++++++++++ .../app/handler/otlp_receover_test.go | 32 +++++ cmd/collector/main.go | 9 +- go.mod | 25 +++- go.sum | 112 ++++++++++++++++-- 7 files changed, 287 insertions(+), 25 deletions(-) create mode 100644 cmd/collector/app/handler/otlp_receiver.go create mode 100644 cmd/collector/app/handler/otlp_receover_test.go diff --git a/cmd/collector/app/collector.go b/cmd/collector/app/collector.go index fa0fd01c888..77cf6ff35c6 100644 --- a/cmd/collector/app/collector.go +++ b/cmd/collector/app/collector.go @@ -22,9 +22,11 @@ import ( "time" "github.com/uber/jaeger-lib/metrics" + "go.opentelemetry.io/collector/component" "go.uber.org/zap" "google.golang.org/grpc" + "github.com/jaegertracing/jaeger/cmd/collector/app/handler" "github.com/jaegertracing/jaeger/cmd/collector/app/processor" "github.com/jaegertracing/jaeger/cmd/collector/app/sampling/strategystore" "github.com/jaegertracing/jaeger/cmd/collector/app/server" @@ -49,6 +51,7 @@ type Collector struct { hServer *http.Server zkServer *http.Server grpcServer *grpc.Server + otlpReceiver component.TracesReceiver tlsGRPCCertWatcherCloser io.Closer tlsHTTPCertWatcherCloser io.Closer tlsZipkinCertWatcherCloser io.Closer @@ -106,7 +109,7 @@ func (c *Collector) Start(options *CollectorOptions) error { MaxConnectionAgeGrace: options.GRPC.MaxConnectionAgeGrace, }) if err != nil { - return fmt.Errorf("could not start gRPC collector %w", err) + return fmt.Errorf("could not start gRPC collector: %w", err) } c.grpcServer = grpcServer @@ -120,7 +123,7 @@ func (c *Collector) Start(options *CollectorOptions) error { Logger: c.logger, }) if err != nil { - return fmt.Errorf("could not start the HTTP server %w", err) + return fmt.Errorf("could not start the HTTP server: %w", err) } c.hServer = httpServer @@ -138,10 +141,16 @@ func (c *Collector) Start(options *CollectorOptions) error { MetricsFactory: c.metricsFactory, }) if err != nil { - return fmt.Errorf("could not start the Zipkin server %w", err) + return fmt.Errorf("could not start the Zipkin server: %w", err) } c.zkServer = zkServer + otlpReceiver, err := handler.StartOtelReceiver(c.logger, c.spanProcessor) + if err != nil { + return err + } + c.otlpReceiver = otlpReceiver + c.publishOpts(options) return nil @@ -178,6 +187,15 @@ func (c *Collector) Close() error { defer cancel() } + // OpenTelemetry OTLP receiver + if c.otlpReceiver != nil { + timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second) + if err := c.otlpReceiver.Shutdown(timeout); err != nil { + c.logger.Fatal("failed to stop the OTLP receiver", zap.Error(err)) + } + defer cancel() + } + if err := c.spanProcessor.Close(); err != nil { c.logger.Error("failed to close span processor.", zap.Error(err)) } diff --git a/cmd/collector/app/handler/grpc_handler.go b/cmd/collector/app/handler/grpc_handler.go index 995fa141ed4..e565178baaf 100644 --- a/cmd/collector/app/handler/grpc_handler.go +++ b/cmd/collector/app/handler/grpc_handler.go @@ -19,7 +19,7 @@ import ( "go.uber.org/zap" "google.golang.org/grpc/codes" - _ "google.golang.org/grpc/encoding/gzip" + _ "google.golang.org/grpc/encoding/gzip" // register zip encoding "google.golang.org/grpc/status" "github.com/jaegertracing/jaeger/cmd/collector/app/processor" diff --git a/cmd/collector/app/handler/otlp_receiver.go b/cmd/collector/app/handler/otlp_receiver.go new file mode 100644 index 00000000000..5499904eeed --- /dev/null +++ b/cmd/collector/app/handler/otlp_receiver.go @@ -0,0 +1,108 @@ +// Copyright (c) 2022 The Jaeger 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 handler + +import ( + "context" + "fmt" + + otlp2jaeger "github.com/open-telemetry/opentelemetry-collector-contrib/pkg/translator/jaeger" + "go.opentelemetry.io/collector/component" + "go.opentelemetry.io/collector/config" + "go.opentelemetry.io/collector/consumer" + "go.opentelemetry.io/collector/pdata/ptrace" + "go.opentelemetry.io/collector/receiver/otlpreceiver" + "go.opentelemetry.io/otel" + "go.uber.org/zap" + + "github.com/jaegertracing/jaeger/cmd/collector/app/processor" + "github.com/jaegertracing/jaeger/model" + "github.com/jaegertracing/jaeger/proto-gen/api_v2" +) + +// A delegation function to assist in tests, because ProtoFromTraces never returns errors despite its API. +var protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) = otlp2jaeger.ProtoFromTraces + +var _ component.Host = (*otelHost)(nil) // API check + +type OtelReceiverOptions struct { + GRPCAddress string + HTTPAddress string +} + +// StartOtelReceiver starts OpenTelemetry OTLP receiver listening on gRPC and HTTP ports. +func StartOtelReceiver(logger *zap.Logger, spanProcessor processor.SpanProcessor) (component.TracesReceiver, error) { + otlpFactory := otlpreceiver.NewFactory() + otlpReceiverConfig := otlpFactory.CreateDefaultConfig() + otlpReceiverSettings := component.ReceiverCreateSettings{ + TelemetrySettings: component.TelemetrySettings{ + Logger: logger, + TracerProvider: otel.GetTracerProvider(), // TODO we may always want no-op here, not the global default + }, + } + // TODO re-implement the logic of NewGRPCHandler, it's fairly trivial + jaegerBatchHandler := NewGRPCHandler(logger, spanProcessor) + nextConsumer, err := consumer.NewTraces(consumer.ConsumeTracesFunc(func(ctx context.Context, ld ptrace.Traces) error { + batches, err := protoFromTraces(ld) + if err != nil { + return err + } + for _, batch := range batches { + // TODO generate metrics + _, err := jaegerBatchHandler.PostSpans(ctx, &api_v2.PostSpansRequest{ + Batch: *batch, + }) + if err != nil { + return err + } + } + return nil + })) + if err != nil { + return nil, fmt.Errorf("could not create the OTLP consumer: %w", err) + } + otlpReceiver, err := otlpFactory.CreateTracesReceiver( + context.Background(), + otlpReceiverSettings, + otlpReceiverConfig, + nextConsumer, + ) + if err != nil { + return nil, fmt.Errorf("could not create the OTLP receiver: %w", err) + } + err = otlpReceiver.Start(context.Background(), &otelHost{logger: logger}) + if err != nil { + return nil, fmt.Errorf("could not start the OTLP receiver: %w", err) + } + return otlpReceiver, nil +} + +// otelHost is a mostly no-op implementation of OTEL component.Host +type otelHost struct { + logger *zap.Logger +} + +func (h *otelHost) ReportFatalError(err error) { + h.logger.Fatal("OTLP receiver error", zap.Error(err)) +} +func (*otelHost) GetFactory(kind component.Kind, componentType config.Type) component.Factory { + return nil +} +func (*otelHost) GetExtensions() map[config.ComponentID]component.Extension { + return nil +} +func (*otelHost) GetExporters() map[config.DataType]map[config.ComponentID]component.Exporter { + return nil +} diff --git a/cmd/collector/app/handler/otlp_receover_test.go b/cmd/collector/app/handler/otlp_receover_test.go new file mode 100644 index 00000000000..5ef55029838 --- /dev/null +++ b/cmd/collector/app/handler/otlp_receover_test.go @@ -0,0 +1,32 @@ +// Copyright (c) 2022 The Jaeger 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 handler + +import ( + "context" + "testing" + + "github.com/jaegertracing/jaeger/pkg/testutils" + "github.com/stretchr/testify/require" +) + +func TestOtlpReceiver(t *testing.T) { + spanProcessor := &mockSpanProcessor{} + logger, _ := testutils.NewLogger() + rec, err := StartOtelReceiver(logger, spanProcessor) + require.NoError(t, err) + err = rec.Shutdown(context.Background()) + require.NoError(t, err) +} diff --git a/cmd/collector/main.go b/cmd/collector/main.go index b7e429b5bf5..ac173033974 100644 --- a/cmd/collector/main.go +++ b/cmd/collector/main.go @@ -97,7 +97,7 @@ func main() { if err != nil { logger.Fatal("Failed to create sampling strategy store", zap.Error(err)) } - c := app.New(&app.CollectorParams{ + collector := app.New(&app.CollectorParams{ ServiceName: serviceName, Logger: logger, MetricsFactory: metricsFactory, @@ -110,12 +110,13 @@ func main() { if err != nil { logger.Fatal("Failed to initialize collector", zap.Error(err)) } - if err := c.Start(collectorOpts); err != nil { + // Start all Collector services + if err := collector.Start(collectorOpts); err != nil { logger.Fatal("Failed to start collector", zap.Error(err)) } - + // Wait for shutfown svc.RunAndThen(func() { - if err := c.Close(); err != nil { + if err := collector.Close(); err != nil { logger.Error("failed to cleanly close the collector", zap.Error(err)) } if closer, ok := spanWriter.(io.Closer); ok { diff --git a/go.mod b/go.mod index 62576afaa4d..762043287c2 100644 --- a/go.mod +++ b/go.mod @@ -29,6 +29,7 @@ require ( github.com/hashicorp/go-plugin v1.4.4 github.com/kr/pretty v0.3.0 github.com/olivere/elastic v6.2.37+incompatible + github.com/open-telemetry/opentelemetry-collector-contrib/pkg/translator/jaeger v0.52.0 github.com/opentracing-contrib/go-grpc v0.0.0-20191001143057-db30781987df github.com/opentracing-contrib/go-stdlib v1.0.0 github.com/opentracing/opentracing-go v1.2.0 @@ -43,8 +44,10 @@ require ( github.com/uber/jaeger-client-go v2.30.0+incompatible github.com/uber/jaeger-lib v2.4.1+incompatible github.com/xdg-go/scram v1.1.1 + go.opentelemetry.io/collector v0.52.0 go.opentelemetry.io/collector/pdata v0.52.0 go.opentelemetry.io/collector/semconv v0.52.0 + go.opentelemetry.io/otel v1.7.0 go.uber.org/atomic v1.9.0 go.uber.org/automaxprocs v1.5.1 go.uber.org/zap v1.21.0 @@ -59,7 +62,7 @@ require ( github.com/HdrHistogram/hdrhistogram-go v1.0.1 // indirect github.com/VividCortex/gohistogram v1.0.0 // indirect github.com/asaskevich/govalidator v0.0.0-20210307081110-f21760c49a8d // indirect - github.com/benbjohnson/clock v1.1.0 // indirect + github.com/benbjohnson/clock v1.3.0 // indirect github.com/beorn7/perks v1.0.1 // indirect github.com/cespare/xxhash v1.1.0 // indirect github.com/cespare/xxhash/v2 v2.1.2 // indirect @@ -73,6 +76,8 @@ require ( github.com/fatih/color v1.13.0 // indirect github.com/felixge/httpsnoop v1.0.2 // indirect github.com/go-kit/kit v0.11.0 // indirect + github.com/go-logr/logr v1.2.3 // indirect + github.com/go-logr/stdr v1.2.2 // indirect github.com/go-openapi/analysis v0.21.2 // indirect github.com/go-openapi/jsonpointer v0.19.5 // indirect github.com/go-openapi/jsonreference v0.20.0 // indirect @@ -81,7 +86,6 @@ require ( github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect github.com/golang/snappy v0.0.4 // indirect github.com/google/flatbuffers v1.12.1 // indirect - github.com/google/uuid v1.3.0 // indirect github.com/hailocab/go-hostpool v0.0.0-20160125115350-e80d13ce29ed // indirect github.com/hashicorp/go-uuid v1.0.2 // indirect github.com/hashicorp/hcl v1.0.0 // indirect @@ -94,21 +98,26 @@ require ( github.com/jcmturner/rpc/v2 v2.0.3 // indirect github.com/josharian/intern v1.0.0 // indirect github.com/json-iterator/go v1.1.12 // indirect - github.com/klauspost/compress v1.14.4 // indirect + github.com/klauspost/compress v1.15.4 // indirect + github.com/knadh/koanf v1.4.1 // indirect github.com/kr/text v0.2.0 // indirect github.com/magiconair/properties v1.8.6 // indirect github.com/mailru/easyjson v0.7.7 // indirect github.com/mattn/go-colorable v0.1.12 // indirect github.com/mattn/go-isatty v0.0.14 // indirect github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect + github.com/mitchellh/copystructure v1.2.0 // indirect github.com/mitchellh/go-testing-interface v1.0.0 // indirect - github.com/mitchellh/mapstructure v1.4.3 // indirect + github.com/mitchellh/mapstructure v1.5.0 // indirect + github.com/mitchellh/reflectwalk v1.0.2 // indirect github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/modern-go/reflect2 v1.0.2 // indirect + github.com/mostynb/go-grpc-compression v1.1.16 // indirect github.com/oklog/run v1.1.0 // indirect github.com/oklog/ulid v1.3.1 // indirect github.com/onsi/ginkgo v1.16.4 // indirect github.com/onsi/gomega v1.13.0 // indirect + github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal v0.52.0 // indirect github.com/pelletier/go-toml v1.9.4 // indirect github.com/pelletier/go-toml/v2 v2.0.0-beta.8 // indirect github.com/pierrec/lz4 v2.6.1+incompatible // indirect @@ -120,7 +129,7 @@ require ( github.com/rogpeppe/go-internal v1.6.2 // indirect github.com/russross/blackfriday/v2 v2.1.0 // indirect github.com/spf13/afero v1.8.2 // indirect - github.com/spf13/cast v1.4.1 // indirect + github.com/spf13/cast v1.5.0 // indirect github.com/spf13/jwalterweatherman v1.1.0 // indirect github.com/stretchr/objx v0.2.0 // indirect github.com/subosito/gotenv v1.2.0 // indirect @@ -128,7 +137,11 @@ require ( github.com/xdg-go/stringprep v1.0.3 // indirect go.mongodb.org/mongo-driver v1.8.3 // indirect go.opencensus.io v0.23.0 // indirect - go.uber.org/multierr v1.7.0 // indirect + go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.32.0 // indirect + go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.32.0 // indirect + go.opentelemetry.io/otel/metric v0.30.0 // indirect + go.opentelemetry.io/otel/trace v1.7.0 // indirect + go.uber.org/multierr v1.8.0 // indirect golang.org/x/crypto v0.0.0-20220411220226-7b82a4e95df4 // indirect golang.org/x/text v0.3.7 // indirect google.golang.org/genproto v0.0.0-20220407144326-9054f6ed7bac // indirect diff --git a/go.sum b/go.sum index 5380fd9c771..691f2bf75e3 100644 --- a/go.sum +++ b/go.sum @@ -17,12 +17,14 @@ cloud.google.com/go v0.65.0/go.mod h1:O5N8zS7uWy9vkA9vayVHs65eM1ubvY4h553ofrNHOb cloud.google.com/go v0.72.0/go.mod h1:M+5Vjvlc2wnp6tjzE102Dw08nGShTscUx2nZMufOKPI= cloud.google.com/go v0.74.0/go.mod h1:VV1xSbzvo+9QJOxLDaJfTjx5e+MePCpCWwvftOeQmWk= cloud.google.com/go v0.75.0/go.mod h1:VGuuCn7PG0dwsd5XPVm2Mm3wlh3EL55/79EKB6hlPTY= +cloud.google.com/go v0.100.2 h1:t9Iw5QH5v4XtlEQaCtUY7x6sCABps8sW0acw7e2WQ6Y= cloud.google.com/go/bigquery v1.0.1/go.mod h1:i/xbL2UlR5RvWAURpBYZTtm/cXjCha9lbfbpx4poX+o= cloud.google.com/go/bigquery v1.3.0/go.mod h1:PjpwJnslEMmckchkHFfq+HTD2DmtT67aNFKH1/VBDHE= cloud.google.com/go/bigquery v1.4.0/go.mod h1:S8dzgnTigyfTmLBfrtrhyYhwRxG72rYxvftPBK2Dvzc= cloud.google.com/go/bigquery v1.5.0/go.mod h1:snEHRnqQbz117VIFhE8bmtwIDY80NLUZUMb4Nv6dBIg= cloud.google.com/go/bigquery v1.7.0/go.mod h1://okPTzCYNXSlb24MZs83e2Do+h+VXtc4gLoIoXIAPc= cloud.google.com/go/bigquery v1.8.0/go.mod h1:J5hqkt3O0uAFnINi6JXValWIb1v0goeZM77hZzJN/fQ= +cloud.google.com/go/compute v1.5.0 h1:b1zWmYuuHz7gO9kDcM/EpHGr06UgsYNRpNJzI2kFiLM= cloud.google.com/go/datastore v1.0.0/go.mod h1:LXYbyblFSglQ5pkeyhO+Qmw7ukd3C+pD7TKLgZqpHYE= cloud.google.com/go/datastore v1.1.0/go.mod h1:umbIZjpQpHh4hmRpGhH4tLFup+FVzqBi1b3c64qFpCk= cloud.google.com/go/pubsub v1.0.1/go.mod h1:R0Gpsv3s54REJCy4fxDixWD93lHJMoZTyQ2kNxGRt3I= @@ -35,6 +37,7 @@ cloud.google.com/go/storage v1.6.0/go.mod h1:N7U0C8pVQ/+NIKOBQyamJIeKQKkZ+mxpohl cloud.google.com/go/storage v1.8.0/go.mod h1:Wv1Oy7z6Yz3DshWRJFhqM/UCfaWIRTdp0RXyy7KQOVs= cloud.google.com/go/storage v1.10.0/go.mod h1:FLPqc6j+Ki4BU591ie1oL6qBQGu2Bl/tZ9ullr3+Kg0= cloud.google.com/go/storage v1.14.0/go.mod h1:GrKmX003DSIwi9o29oFT7YDnHYwZoctc3fOKtUw0Xmo= +code.cloudfoundry.org/bytefmt v0.0.0-20190710193110-1eb035ffe2b6/go.mod h1:wN/zk7mhREp/oviagqUXY3EwuHhWyOvAdsn5Y4CzOrc= dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= @@ -73,10 +76,21 @@ github.com/asaskevich/govalidator v0.0.0-20210307081110-f21760c49a8d h1:Byv0BzEl github.com/asaskevich/govalidator v0.0.0-20210307081110-f21760c49a8d/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw= github.com/aws/aws-sdk-go v1.38.68/go.mod h1:hcU610XS61/+aQV88ixoOzUoG7v3b31pl2zKMmprdro= github.com/aws/aws-sdk-go-v2 v1.7.0/go.mod h1:tb9wi5s61kTDA5qCkcDbt3KRVV74GGslQkl/DRdX/P4= +github.com/aws/aws-sdk-go-v2 v1.9.2/go.mod h1:cK/D0BBs0b/oWPIcX/Z/obahJK1TT7IPVjy53i/mX/4= +github.com/aws/aws-sdk-go-v2/config v1.8.3/go.mod h1:4AEiLtAb8kLs7vgw2ZV3p2VZ1+hBavOc84hqxVNpCyw= +github.com/aws/aws-sdk-go-v2/credentials v1.4.3/go.mod h1:FNNC6nQZQUuyhq5aE5c7ata8o9e4ECGmS4lAXC7o1mQ= +github.com/aws/aws-sdk-go-v2/feature/ec2/imds v1.6.0/go.mod h1:gqlclDEZp4aqJOancXK6TN24aKhT0W0Ae9MHk3wzTMM= +github.com/aws/aws-sdk-go-v2/internal/ini v1.2.4/go.mod h1:ZcBrrI3zBKlhGFNYWvju0I3TR93I7YIgAfy82Fh4lcQ= +github.com/aws/aws-sdk-go-v2/service/appconfig v1.4.2/go.mod h1:FZ3HkCe+b10uFZZkFdvf98LHW21k49W8o8J366lqVKY= github.com/aws/aws-sdk-go-v2/service/cloudwatch v1.5.0/go.mod h1:acH3+MQoiMzozT/ivU+DbRg7Ooo2298RdRaWcOv+4vM= +github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.3.2/go.mod h1:72HRZDLMtmVQiLG2tLfQcaWLCssELvGl+Zf2WVxMmR8= +github.com/aws/aws-sdk-go-v2/service/sso v1.4.2/go.mod h1:NBvT9R1MEF+Ud6ApJKM0G+IkPchKS7p7c2YPKwHmBOk= +github.com/aws/aws-sdk-go-v2/service/sts v1.7.2/go.mod h1:8EzeIqfWt2wWT4rJVu3f21TfrhJ8AEMzVybRNSb/b4g= github.com/aws/smithy-go v1.5.0/go.mod h1:SObp3lf9smib00L/v3U2eAKG8FyQ7iLrJnQiAmR5n+E= -github.com/benbjohnson/clock v1.1.0 h1:Q92kusRqC1XV2MjkWETPvjJVqKetz1OzxZB7mHJLju8= +github.com/aws/smithy-go v1.8.0/go.mod h1:SObp3lf9smib00L/v3U2eAKG8FyQ7iLrJnQiAmR5n+E= github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= +github.com/benbjohnson/clock v1.3.0 h1:ip6w0uFQkncKQ979AypyG0ER7mqUSBdKLOgAle/AT8A= +github.com/benbjohnson/clock v1.3.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= @@ -156,6 +170,7 @@ github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5Kwzbycv github.com/fatih/color v1.9.0/go.mod h1:eQcE1qtQxscV5RaZvpXrrb8Drkc3/DdQ+uUYCNjL+zU= github.com/fatih/color v1.13.0 h1:8LOYc1KYPPmyKMuN8QV2DNRWNbLo6LZ0iLs8+mlH53w= github.com/fatih/color v1.13.0/go.mod h1:kLAiJbzzSOZDVNGyDpeOxJ47H46qBXwg5ILebYFFOfk= +github.com/fatih/structs v1.1.0/go.mod h1:9NiDSp5zOcgEDl+j00MP/WkGVPOlPRLejGD8Ga6PJ7M= github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= github.com/felixge/httpsnoop v1.0.2 h1:+nS9g82KMXccJ/wp0zyRW9ZBHFETmMGtkk+2CTTrW4o= github.com/felixge/httpsnoop v1.0.2/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= @@ -163,8 +178,10 @@ github.com/fortytw2/leaktest v1.3.0 h1:u8491cBMTQ8ft8aeV+adlcytMZylmA5nnwwkRZjI8 github.com/fortytw2/leaktest v1.3.0/go.mod h1:jDsjWgpAGjm2CA7WthBh/CdZYEPF31XHquHwclZch5g= github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4= github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20= -github.com/frankban/quicktest v1.14.2 h1:SPb1KFFmM+ybpEjPUhCCkZOM5xlovT5UbrMvWnXyBns= +github.com/frankban/quicktest v1.4.0/go.mod h1:36zfPVQyHxymz4cH7wlDmVwDrJuljRB60qkgn7rorfQ= +github.com/frankban/quicktest v1.14.0/go.mod h1:NeW+ay9A/U67EYXNFA1nPE8e/tnQv/09mUdL/ijj8og= github.com/frankban/quicktest v1.14.2/go.mod h1:mgiwOwqx65TmIk1wJ6Q7wvnVMocbUorkibMOrVTHZps= +github.com/frankban/quicktest v1.14.3 h1:FJKSZTDHjyhriyC81FLQ0LY93eSai0ZyR/ZIkd3ZUKE= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= github.com/fsnotify/fsnotify v1.5.4 h1:jRbGcIw6P2Meqdwuo0H1p6JVLbL5DHKAKlYndzMwVZI= @@ -179,10 +196,16 @@ github.com/go-kit/kit v0.11.0 h1:IGmIEl7aHTYh6E2HlT+ptILBotjo4xl8PMDl852etiI= github.com/go-kit/kit v0.11.0/go.mod h1:73/6Ixaufkvb5Osvkls8C79vuQ49Ba1rUEUYNSf+FUw= github.com/go-kit/log v0.1.0/go.mod h1:zbhenjAZHb184qTLMA9ZjW7ThYL0H2mk7Q6pNt4vbaY= github.com/go-kit/log v0.2.0/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBjv0= +github.com/go-ldap/ldap v3.0.2+incompatible/go.mod h1:qfd9rJvER9Q0/D/Sqn1DfHRoBp40uXYvFoEVrNEPqRc= github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE= github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs= +github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.2.3 h1:2DntVwHkVopvECVRSlL5PSo9eG+cAkDCuckLubN+rq0= +github.com/go-logr/logr v1.2.3/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= +github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= github.com/go-openapi/analysis v0.21.2 h1:hXFrOYFHUAMQdu6zwAiKKJHJQ8kqZs1ux/ru1P1wLJU= github.com/go-openapi/analysis v0.21.2/go.mod h1:HZwRk4RRisyG8vx2Oe6aqeSQcoxRp47Xkp3+K6q+LdY= github.com/go-openapi/errors v0.19.8/go.mod h1:cM//ZKUKyO06HSwqAelJ5NsEMMcpa6VpXe8DOa1Mi1M= @@ -216,6 +239,7 @@ github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/me github.com/go-stack/stack v1.8.1 h1:ntEHSVwIt7PNXNpgPmVfMrNhLtgjlmnZha2kOpuRiDw= github.com/go-stack/stack v1.8.1/go.mod h1:dcoOX6HbPZSZptuspn9bctJ+N/CnF5gGygcUP3XYfe4= github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE= +github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA= github.com/go-zookeeper/zk v1.0.2/go.mod h1:nOB03cncLtlp4t+UAkGSV+9beXP/akpekBwL+UX1Qcw= github.com/gobuffalo/attrs v0.0.0-20190224210810-a9411de4debd/go.mod h1:4duuawTqi2wkkpB4ePgWMaai6/Kc6WEz83bhFwpHzj0= github.com/gobuffalo/depgen v0.0.0-20190329151759-d478694a28d3/go.mod h1:3STtPUQYuzV0gBVOY3vy6CfMm/ljR4pABfrTeHNLHUY= @@ -303,8 +327,8 @@ github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/ github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.7 h1:81/ik6ipDQS2aGcBfIN5dHDB36BwrStyeAQquSYCV4o= github.com/google/go-cmp v0.5.7/go.mod h1:n+brtR0CgQNWTVd5ZUFpTBC8YFBDLK/h/bpaJ8/DtOE= +github.com/google/go-cmp v0.5.8 h1:e6P7q2lk1O+qJJb4BtCQXlK8vWEO8V1ZeuEdJNOqZyg= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= github.com/google/martian/v3 v3.0.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= @@ -323,7 +347,6 @@ github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm4 github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I= -github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g= @@ -348,7 +371,10 @@ github.com/hailocab/go-hostpool v0.0.0-20160125115350-e80d13ce29ed/go.mod h1:tMW github.com/hashicorp/consul/api v1.8.1/go.mod h1:sDjTOq0yUyv5G4h+BqSea7Fn6BU+XbolEz1952UB+mk= github.com/hashicorp/consul/sdk v0.7.0/go.mod h1:fY08Y9z5SvJqevyZNy6WWPXiG3KwBPAvlcdx16zZ0fM= github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= +github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80= +github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd/go.mod h1:9bjs9uLqI8l75knNv3lV1kA55veR+WUPSiKIWcQHudI= +github.com/hashicorp/go-hclog v0.8.0/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ= github.com/hashicorp/go-hclog v0.12.0/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ= github.com/hashicorp/go-hclog v1.2.0 h1:La19f8d7WIlm4ogzNHB0JGqs5AUDAZ2UfCY4sJXcJdM= github.com/hashicorp/go-hclog v1.2.0/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ= @@ -356,15 +382,20 @@ github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjh github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM= github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk= github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA= +github.com/hashicorp/go-plugin v1.0.1/go.mod h1:++UyYGoz3o5w9ZzAdZxtQKrWWP+iqPBn3cQptSMzBuY= github.com/hashicorp/go-plugin v1.4.4 h1:NVdrSdFRt3SkZtNckJ6tog7gbpRrcbOjQi/rgF7JYWQ= github.com/hashicorp/go-plugin v1.4.4/go.mod h1:viDMjcLJuDui6pXb8U4HVfb8AamCWhHGUjr2IrTF67s= +github.com/hashicorp/go-retryablehttp v0.5.4/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs= +github.com/hashicorp/go-rootcerts v1.0.1/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8= github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8= github.com/hashicorp/go-sockaddr v1.0.0/go.mod h1:7Xibr9yA9JjQq1JpNB2Vw7kxv8xerXegt+ozgdvDeDU= +github.com/hashicorp/go-sockaddr v1.0.2/go.mod h1:rB4wwRAUzs07qva3c5SdrY/NEtAUjGlgmH/UkBUC97A= github.com/hashicorp/go-syslog v1.0.0/go.mod h1:qPfqrKkXGihmCqbJM2mZgkZGvKG1dFdvsLplgctolz4= github.com/hashicorp/go-uuid v1.0.0/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= github.com/hashicorp/go-uuid v1.0.1/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= github.com/hashicorp/go-uuid v1.0.2 h1:cfejS+Tpcp13yd5nYHWDI6qVCny6wyX2Mt5SGur2IGE= github.com/hashicorp/go-uuid v1.0.2/go.mod h1:6SBZvOh/SIDV7/2o3Jml5SYk/TvGqwFJ/bN7x4byOro= +github.com/hashicorp/go-version v1.1.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= @@ -373,6 +404,10 @@ github.com/hashicorp/logutils v1.0.0/go.mod h1:QIAnNjmIWmVIIkWDTG1z5v++HQmx9WQRO github.com/hashicorp/mdns v1.0.1/go.mod h1:4gW7WsVCke5TE7EPeYliwHlRUyBtfCwuFwuMg2DmyNY= github.com/hashicorp/memberlist v0.2.2/go.mod h1:MS2lj3INKhZjWNqd3N0m3J+Jxf3DAOnAH9VT3Sh9MUE= github.com/hashicorp/serf v0.9.5/go.mod h1:UWDWwZeL5cuWDJdl0C6wrvrUwEqtQ4ZKBKKENpqIUyk= +github.com/hashicorp/vault/api v1.0.4/go.mod h1:gDcqh3WGcR1cpF5AJz/B1UFheUEneMoIospckxBxk6Q= +github.com/hashicorp/vault/sdk v0.1.13/go.mod h1:B+hVj7TpuQY1Y/GPbCpffmgd+tSEwvhkWnjtSYCaS2M= +github.com/hashicorp/yamux v0.0.0-20180604194846-3520598351bb/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM= +github.com/hashicorp/yamux v0.0.0-20181012175058-2f1d1f20f75d/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM= github.com/hashicorp/yamux v0.0.0-20190923154419-df201c70410d h1:W+SIwDdl3+jXWeidYySAgzytE3piq6GumXeBjFBG67c= github.com/hashicorp/yamux v0.0.0-20190923154419-df201c70410d/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= @@ -397,6 +432,7 @@ github.com/jcmturner/rpc/v2 v2.0.3/go.mod h1:VUJYCIDm3PVOEHw8sgt091/20OJjskO/YJk github.com/jhump/protoreflect v1.6.0 h1:h5jfMVslIg6l29nsMs0D8Wj17RDVdNYti0vDN/PZZoE= github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo= github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U= +github.com/joho/godotenv v1.3.0 h1:Zjp+RcGpHhGlrMbJzXTrZZPrWj+1vfm90La1wgB6Bhc= github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg= github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y= @@ -419,8 +455,12 @@ github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+o github.com/klauspost/compress v1.11.12/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs= github.com/klauspost/compress v1.12.3/go.mod h1:8dP1Hq4DHOhN9w426knH3Rhby4rFm6D8eO+e+Dq5Gzg= github.com/klauspost/compress v1.13.6/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk= -github.com/klauspost/compress v1.14.4 h1:eijASRJcobkVtSt81Olfh7JX43osYLwy5krOJo6YEu4= +github.com/klauspost/compress v1.14.1/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk= github.com/klauspost/compress v1.14.4/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk= +github.com/klauspost/compress v1.15.4 h1:1kn4/7MepF/CHmYub99/nNX8az0IJjfSOU/jbnTVfqQ= +github.com/klauspost/compress v1.15.4/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU= +github.com/knadh/koanf v1.4.1 h1:Z0VGW/uo8NJmjd+L1Dc3S5frq6c62w5xQ9Yf4Mg3wFQ= +github.com/knadh/koanf v1.4.1/go.mod h1:1cfH5223ZeZUOs8FU2UdTmaNfHpqgtjV0+NHjRO43gs= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= @@ -463,16 +503,27 @@ github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5 github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg= github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKjuso= github.com/minio/highwayhash v1.0.1/go.mod h1:BQskDq+xkJ12lmlUUi7U0M5Swg3EWR+dLTk+kldvVxY= +github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc= github.com/mitchellh/cli v1.1.0/go.mod h1:xcISNoH86gajksDmfB23e/pu+B+GeFRMYmoHXxx3xhI= +github.com/mitchellh/colorstring v0.0.0-20190213212951-d06e56a500db/go.mod h1:l0dey0ia/Uv7NcFFVbCLtqEBQbrT4OCwCSKTEv6enCw= +github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw= +github.com/mitchellh/copystructure v1.2.0 h1:vpKXTN4ewci03Vljg/q9QvCGUDttBOGBIa15WveJJGw= +github.com/mitchellh/copystructure v1.2.0/go.mod h1:qLl+cE2AmVv+CoeAwDPye/v+N2HKCj9FbZEVFJRxO9s= github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0= +github.com/mitchellh/go-testing-interface v0.0.0-20171004221916-a61a99592b77/go.mod h1:kRemZodwjscx+RGhAo8eIhFbs2+BFgRtFPeD/KE+zxI= github.com/mitchellh/go-testing-interface v1.0.0 h1:fzU/JVNcaqHQEcVFAKeR41fkiLdIPrefOvVG1VZ96U0= github.com/mitchellh/go-testing-interface v1.0.0/go.mod h1:kRemZodwjscx+RGhAo8eIhFbs2+BFgRtFPeD/KE+zxI= +github.com/mitchellh/go-wordwrap v1.0.0/go.mod h1:ZXFpozHsX6DPmq2I0TCekCxypsnAUbP2oI0UX1GXzOo= github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/mitchellh/mapstructure v1.3.3/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= github.com/mitchellh/mapstructure v1.4.1/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= -github.com/mitchellh/mapstructure v1.4.3 h1:OVowDSCllw/YjdLkam3/sm7wEtOy59d8ndGgCcyj8cs= github.com/mitchellh/mapstructure v1.4.3/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= +github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY= +github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= +github.com/mitchellh/reflectwalk v1.0.0/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= +github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ= +github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -481,6 +532,8 @@ github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3Rllmb github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M= github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe/go.mod h1:wL8QJuTMNUDYhXwkmfOly8iTdp5TEcJFWZD2D7SIkUc= +github.com/mostynb/go-grpc-compression v1.1.16 h1:D9tGUINmcII049pxOj9dl32Fzhp26TrDVQXECoKJqQg= +github.com/mostynb/go-grpc-compression v1.1.16/go.mod h1:xxa6UoYynYS2h+5HB/Hglu81iYAp87ARaNmhhwi0s1s= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f h1:KUppIJq7/+SVif2QVs3tOP0zanoHgBEVAwHxUSIzRqU= github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= @@ -492,9 +545,11 @@ github.com/nats-io/nkeys v0.2.0/go.mod h1:XdZpAbhgyyODYqjTawOnIOI7VlbKSarI9Gfy1t github.com/nats-io/nkeys v0.3.0/go.mod h1:gvUNGjVcM2IPr5rCsRsC6Wb3Hr2CQAm08dsxtV6A5y4= github.com/nats-io/nuid v1.0.1/go.mod h1:19wcPz3Ph3q0Jbyiqsd0kePYG7A95tJPxeL+1OSON2c= github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= +github.com/npillmayer/nestext v0.1.3/go.mod h1:h2lrijH8jpicr25dFY+oAJLyzlya6jhnuG+zWp9L0Uk= github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI8A= github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE= github.com/nxadm/tail v1.4.8/go.mod h1:+ncqLTQzXmGhMZNUePPaPqPvBxHAIsmXswZKocGu+AU= +github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQA= github.com/oklog/run v1.1.0 h1:GEenZ1cK0+q0+wsJew9qUg/DyD8k3JzYsZAi5gYi2mA= github.com/oklog/run v1.1.0/go.mod h1:sVPdnTZT1zYwAJeCMu2Th4T21pA3FPOQRfWjQlk7DVU= github.com/oklog/ulid v1.3.1 h1:EGfNDEx6MqHz8B3uNV6QAib1UR2Lm97sHi3ocA6ESJ4= @@ -503,16 +558,22 @@ github.com/olivere/elastic v6.2.37+incompatible h1:UfSGJem5czY+x/LqxgeCBgjDn6St+ github.com/olivere/elastic v6.2.37+incompatible/go.mod h1:J+q1zQJTgAz9woqsbVRqGeB5G1iqDKVBWLNSYW8yfJ8= github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= +github.com/onsi/ginkgo v1.8.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= github.com/onsi/ginkgo v1.16.2/go.mod h1:CObGmKUOKaSC0RjmoAK7tKyn4Azo5P2IWuoMnvwxz1E= github.com/onsi/ginkgo v1.16.4 h1:29JGrr5oVBm5ulCWet69zQkzWipVXIol6ygQUe/EzNc= github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0= github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= +github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= github.com/onsi/gomega v1.13.0 h1:7lLHu94wT9Ij0o6EWWclhu0aOh32VxhkwEJvzuWPeak= github.com/onsi/gomega v1.13.0/go.mod h1:lRk9szgn8TxENtWd0Tp4c3wjlRfMTMH27I+3Je41yGY= github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWErDVzsI23lYNej1Htcns9BCg93Dk0bBINWk= +github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal v0.52.0 h1:xP8y+aDlqm7iTyf8zp2bFo+9prbmufy9JzVrTjtzFL8= +github.com/open-telemetry/opentelemetry-collector-contrib/internal/coreinternal v0.52.0/go.mod h1:CIX1MWy+2JYdeYhqjK89vrRpCGbz6LTLinp+SM8kZyo= +github.com/open-telemetry/opentelemetry-collector-contrib/pkg/translator/jaeger v0.52.0 h1:7nXosK3WgHKIRXbCn2AjUTC7T7ELgeFI3FoP/br0OVw= +github.com/open-telemetry/opentelemetry-collector-contrib/pkg/translator/jaeger v0.52.0/go.mod h1:tU7s/ki/QePSIZ7ExYGWLMb9erCAt66brQHBEHxr8HU= github.com/opentracing-contrib/go-grpc v0.0.0-20191001143057-db30781987df h1:vdYtBU6zvL7v+Tr+0xFM/qhahw/EvY8DMMunZHKH6eE= github.com/opentracing-contrib/go-grpc v0.0.0-20191001143057-db30781987df/go.mod h1:DYR5Eij8rJl8h7gblRrOZ8g0kW1umSpKqYIBTgeDtLo= github.com/opentracing-contrib/go-stdlib v1.0.0 h1:TBS7YuVotp8myLon4Pv7BtCBzOTo1DeZCld0Z63mW2w= @@ -522,6 +583,7 @@ github.com/opentracing/opentracing-go v1.2.0 h1:uEJPy/1a5RIPAJ0Ov+OIO8OxWu77jEv+ github.com/opentracing/opentracing-go v1.2.0/go.mod h1:GxEUsuufX4nBwe+T+Wl9TAgYrxe9dPLANfrWvHYVTgc= github.com/openzipkin/zipkin-go v0.2.5/go.mod h1:KpXfKdgRDnnhsxw4pNIH9Md5lyFqKUa4YDFlwRYAMyE= github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= +github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= github.com/pelletier/go-toml v1.7.0/go.mod h1:vwGMzjaWMwyfHwgIBhI2YUM4fB6nL6lVAvS1LBMMhTE= github.com/pelletier/go-toml v1.9.4 h1:tjENF6MfZAg8e4ZmZTeWaWiT2vXtsoO6+iuOjFhECwM= @@ -529,9 +591,12 @@ github.com/pelletier/go-toml v1.9.4/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCko github.com/pelletier/go-toml/v2 v2.0.0-beta.8 h1:dy81yyLYJDwMTifq24Oi/IslOslRrDSb3jwDggjz3Z0= github.com/pelletier/go-toml/v2 v2.0.0-beta.8/go.mod h1:r9LEWfGN8R5k0VXJ+0BkIe7MYkRdwZOjgMj2KwnJFUo= github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac= +github.com/pierrec/cmdflag v0.0.2/go.mod h1:a3zKGZ3cdQUfxjd0RGMLZr8xI3nvpJOB+m6o/1X5BmU= github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc= +github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= github.com/pierrec/lz4 v2.6.1+incompatible h1:9UY3+iC23yxF0UfGaYrGplQ+79Rg+h/q9FV9ix19jjM= github.com/pierrec/lz4 v2.6.1+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY= +github.com/pierrec/lz4/v3 v3.3.4/go.mod h1:280XNCGS8jAcG++AHdd6SeWnzyJ1w9oow2vbORyey8Q= github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= @@ -570,6 +635,7 @@ github.com/prometheus/procfs v0.7.3/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1 github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= +github.com/rhnvrm/simples3 v0.6.1/go.mod h1:Y+3vYm2V7Y4VijFoJHHTrja6OgPrJ2cBti8dPGkC3sA= github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= github.com/rogpeppe/go-internal v1.1.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= github.com/rogpeppe/go-internal v1.2.2/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= @@ -584,6 +650,9 @@ github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQD github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts= +github.com/ryanuber/columnize v2.1.0+incompatible/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts= +github.com/ryanuber/go-glob v1.0.0/go.mod h1:807d1WSdnB0XRJzKNil9Om6lcp/3a0v4qIHxIXzX/Yc= +github.com/schollz/progressbar/v2 v2.13.2/go.mod h1:6YZjqdthH6SCZKv2rqGryrxPtfmRB/DWZxSMfCXPyD8= github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc= github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= @@ -604,8 +673,8 @@ github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B github.com/spf13/afero v1.8.2 h1:xehSyVa0YnHWsJ49JFljMpg1HX19V6NDZ1fkm1Xznbo= github.com/spf13/afero v1.8.2/go.mod h1:CtAatgMJh6bJEIs48Ay/FOnkljP3WeGUG0MC1RfAqwo= github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= -github.com/spf13/cast v1.4.1 h1:s0hze+J0196ZfEMTs80N7UlFt0BDuQ7Q+JDnHiMWKdA= -github.com/spf13/cast v1.4.1/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= +github.com/spf13/cast v1.5.0 h1:rj3WzYc11XZaIZMPKmwP96zkFEnnAmV8s6XbB2aY32w= +github.com/spf13/cast v1.5.0/go.mod h1:SpXXQ5YoyJw6s3/6cMTQuxvgRl3PCJiyaX9p6b155UU= github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ= github.com/spf13/cobra v0.0.5/go.mod h1:3K3wKZymM7VvHMDS9+Akkh4K60UwM26emMESw8tLCHU= github.com/spf13/cobra v1.4.0 h1:y+wJpx64xcgO1V+RcnwW0LEHxTKRi2ZDPSBjWnrg88Q= @@ -676,10 +745,23 @@ go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= go.opencensus.io v0.23.0 h1:gqCw0LfLxScz8irSi8exQc7fyQ0fKQU/qnC/X8+V/1M= go.opencensus.io v0.23.0/go.mod h1:XItmlyltB5F7CS4xOC1DcqMoFqwtC6OG2xF7mCv7P7E= +go.opentelemetry.io/collector v0.52.0 h1:f8860C+jAGtfBIKmF5UFCmKHA3P3ni/KZuVbz3qgvQk= +go.opentelemetry.io/collector v0.52.0/go.mod h1:a9GvaOhyc0nVOUzqvdv5mxyWghCSso/WRO2GgRl4I1g= go.opentelemetry.io/collector/pdata v0.52.0 h1:B0L9fkqKq5xRKFjICK9i11PRyTR52CCYSpTWaynf1Qc= go.opentelemetry.io/collector/pdata v0.52.0/go.mod h1:GJUTfTv8mlYpHRjcmHXVbvJr48EW/q/P/HuBvpXAE58= go.opentelemetry.io/collector/semconv v0.52.0 h1:ogYkQ6WL01xQ4GGSwWQejNTQwy/Pwcd6jCKFLSd7svA= go.opentelemetry.io/collector/semconv v0.52.0/go.mod h1:SxK0rUnUP7YeDakexzbE/vhimTOHwE6m/4aKKd9e27Q= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.32.0 h1:WenoaOMNP71oq3KkMZ/jnxI9xU/JSCLw8yZILSI2lfU= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.32.0/go.mod h1:J0dBVrt7dPS/lKJyQoW0xzQiUr4r2Ik1VwPjAUWnofI= +go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.32.0 h1:mac9BKRqwaX6zxHPDe3pvmWpwuuIM0vuXv2juCnQevE= +go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.32.0/go.mod h1:5eCOqeGphOyz6TsY3ZDNjE33SM/TFAK3RGuCL2naTgY= +go.opentelemetry.io/otel v1.7.0 h1:Z2lA3Tdch0iDcrhJXDIlC94XE+bxok1F9B+4Lz/lGsM= +go.opentelemetry.io/otel v1.7.0/go.mod h1:5BdUoMIz5WEs0vt0CUEMtSSaTSHBBVwrhnz7+nrD5xk= +go.opentelemetry.io/otel/metric v0.30.0 h1:Hs8eQZ8aQgs0U49diZoaS6Uaxw3+bBE3lcMUKBFIk3c= +go.opentelemetry.io/otel/metric v0.30.0/go.mod h1:/ShZ7+TS4dHzDFmfi1kSXMhMVubNoP0oIaBp70J6UXU= +go.opentelemetry.io/otel/sdk v1.7.0 h1:4OmStpcKVOfvDOgCt7UriAPtKolwIhxpnSNI/yK+1B0= +go.opentelemetry.io/otel/trace v1.7.0 h1:O37Iogk1lEkMRXewVtZ1BBTVn5JEp8GrJvP92bJqC6o= +go.opentelemetry.io/otel/trace v1.7.0/go.mod h1:fzLSB9nqR2eXzxPXb2JW9IKE+ScyXA48yyE4TNvoHqU= go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= @@ -691,8 +773,8 @@ go.uber.org/goleak v1.1.11 h1:wy28qYRKZgnJTxGxvye5/wgWr1EKjmUDGYox5mGlRlI= go.uber.org/goleak v1.1.11/go.mod h1:cwTWslyiVhfpKIDGSZEM2HlOvcqm+tG4zioyIeLoqMQ= go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU= -go.uber.org/multierr v1.7.0 h1:zaiO/rmgFjbmCXdSYJWQcdvOCsthmdaHfr3Gm2Kx4Ec= -go.uber.org/multierr v1.7.0/go.mod h1:7EAYxJLBy9rStEaz58O2t4Uvip6FSURkq8/ppBp95ak= +go.uber.org/multierr v1.8.0 h1:dg6GjLku4EH+249NNmoIciG9N/jURbDG+pFlTkhzIC8= +go.uber.org/multierr v1.8.0/go.mod h1:7EAYxJLBy9rStEaz58O2t4Uvip6FSURkq8/ppBp95ak= go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo= go.uber.org/zap v1.21.0 h1:WefMeulhovoZ2sYXz7st6K0sLj7bBhpiFaud4r4zST8= @@ -832,6 +914,7 @@ golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5h golang.org/x/sys v0.0.0-20181026203630-95b1ffbd15a5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20181205085412-a5c9d58dba9a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sys v0.0.0-20190129075346-302c3dd5f1cc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190130150945-aca44879d564/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -903,6 +986,7 @@ golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuX golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +golang.org/x/text v0.3.1-0.20181227161524-e6919f6577db/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= @@ -976,7 +1060,6 @@ golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8T golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -golang.org/x/xerrors v0.0.0-20220411194840-2f41105eb62f h1:GGU+dLjvlC3qDwqYgL6UgRmHXhOOgns0bZu2Ty5mm6U= google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE= google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M= google.golang.org/api v0.8.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= @@ -1006,6 +1089,7 @@ google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6 google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= google.golang.org/genproto v0.0.0-20190307195333-5fe7a883aa19/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= +google.golang.org/genproto v0.0.0-20190404172233-64821d5d2107/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190425155659-357c62f0e4bb/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= @@ -1045,9 +1129,11 @@ google.golang.org/genproto v0.0.0-20210226172003-ab064af71705/go.mod h1:FWY/as6D google.golang.org/genproto v0.0.0-20210602131652-f16073e35f0c/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0= google.golang.org/genproto v0.0.0-20220407144326-9054f6ed7bac h1:qSNTkEN+L2mvWcLgJOR+8bdHX9rN/IdU3A1Ghpfb1Rg= google.golang.org/genproto v0.0.0-20220407144326-9054f6ed7bac/go.mod h1:8w6bsBMX6yCPbAVTeqQHvzxW0EIFigd5lZyahWgyfDo= +google.golang.org/grpc v1.14.0/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw= google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= google.golang.org/grpc v1.20.1/go.mod h1:10oTOabMzJvdu6/UiuZezV6QK5dSlG84ov/aaiqXj38= google.golang.org/grpc v1.21.1/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= +google.golang.org/grpc v1.22.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= google.golang.org/grpc v1.23.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= @@ -1065,7 +1151,9 @@ google.golang.org/grpc v1.34.0/go.mod h1:WotjhfgOW/POjDeRt8vscBtXq+2VjORFy659qA5 google.golang.org/grpc v1.35.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= google.golang.org/grpc v1.36.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= google.golang.org/grpc v1.38.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= +google.golang.org/grpc v1.42.0/go.mod h1:k+4IHHFw41K8+bbowsex27ge2rCb65oeWqe4jJ590SU= google.golang.org/grpc v1.45.0/go.mod h1:lN7owxKUQEqMfSyQikvvk5tf/6zMPsrK+ONuO11+0rQ= +google.golang.org/grpc v1.46.0/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACuMGWk= google.golang.org/grpc v1.46.2 h1:u+MLGgVf7vRdjEYZ8wDFhAVNmhkbJ5hmrA1LMWK1CAQ= google.golang.org/grpc v1.46.2/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACuMGWk= google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= @@ -1084,6 +1172,7 @@ google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQ google.golang.org/protobuf v1.28.0 h1:w43yiav+6bVFTBQFZX0r7ipe9JQ1QsbMgHwbBziscLw= google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw= +gopkg.in/asn1-ber.v1 v1.0.0-20181015200546-f715ec2f112d/go.mod h1:cuepJuh7vyXfUyUwEgHQXw849cJrilpS5NeIjOWESAw= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= @@ -1097,6 +1186,7 @@ gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc= gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= gopkg.in/ini.v1 v1.66.4 h1:SsAcf+mM7mRZo2nJNGt8mZCjG8ZRaNGMURJw7BsIST4= gopkg.in/ini.v1 v1.66.4/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= +gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI= gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ= gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= gopkg.in/warnings.v0 v0.1.2/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI= From df7c0abaa9072dc0b43fb4ae645ab9df32161b85 Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Thu, 26 May 2022 18:35:06 -0400 Subject: [PATCH 2/8] lint Signed-off-by: Yuri Shkuro --- cmd/collector/app/handler/otlp_receover_test.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/cmd/collector/app/handler/otlp_receover_test.go b/cmd/collector/app/handler/otlp_receover_test.go index 5ef55029838..b55a0997214 100644 --- a/cmd/collector/app/handler/otlp_receover_test.go +++ b/cmd/collector/app/handler/otlp_receover_test.go @@ -18,8 +18,9 @@ import ( "context" "testing" - "github.com/jaegertracing/jaeger/pkg/testutils" "github.com/stretchr/testify/require" + + "github.com/jaegertracing/jaeger/pkg/testutils" ) func TestOtlpReceiver(t *testing.T) { From 0967334f9a57a27784a0d0b1a105b44bfc024fa0 Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Thu, 26 May 2022 20:24:03 -0400 Subject: [PATCH 3/8] tests Signed-off-by: Yuri Shkuro --- cmd/collector/app/collector.go | 9 +- cmd/collector/app/flags.go | 5 + cmd/collector/app/handler/grpc_handler.go | 44 ++++-- .../app/handler/grpc_handler_test.go | 70 ++++++---- cmd/collector/app/handler/otlp_receiver.go | 88 +++++++----- .../app/handler/otlp_receiver_test.go | 126 ++++++++++++++++++ .../app/handler/otlp_receover_test.go | 33 ----- cmd/collector/app/processor/interface.go | 2 + 8 files changed, 275 insertions(+), 102 deletions(-) create mode 100644 cmd/collector/app/handler/otlp_receiver_test.go delete mode 100644 cmd/collector/app/handler/otlp_receover_test.go diff --git a/cmd/collector/app/collector.go b/cmd/collector/app/collector.go index 77cf6ff35c6..ee2fee33cc8 100644 --- a/cmd/collector/app/collector.go +++ b/cmd/collector/app/collector.go @@ -145,7 +145,14 @@ func (c *Collector) Start(options *CollectorOptions) error { } c.zkServer = zkServer - otlpReceiver, err := handler.StartOtelReceiver(c.logger, c.spanProcessor) + otlpReceiver, err := handler.StartOtelReceiver( + handler.OtelReceiverOptions{ + GRPCHostPort: options.OTLP.GRPCHostPort, + HTTPHostPort: options.OTLP.HTTPHostPort, + }, + c.logger, + c.spanProcessor, + ) if err != nil { return err } diff --git a/cmd/collector/app/flags.go b/cmd/collector/app/flags.go index 390247013b7..2a9bf85392b 100644 --- a/cmd/collector/app/flags.go +++ b/cmd/collector/app/flags.go @@ -84,6 +84,11 @@ type CollectorOptions struct { // See gRPC's keepalive.ServerParameters#MaxConnectionAgeGrace. MaxConnectionAgeGrace time.Duration } + // OTLP section defines options for servers accepting OpenTelemetry OTLP format + OTLP struct { + GRPCHostPort string + HTTPHostPort string + } // Zipkin section defines options for Zipkin HTTP server Zipkin struct { // HTTPHostPort is the host:port address that the Zipkin collector service listens in on for http requests diff --git a/cmd/collector/app/handler/grpc_handler.go b/cmd/collector/app/handler/grpc_handler.go index e565178baaf..a98c5ce29d2 100644 --- a/cmd/collector/app/handler/grpc_handler.go +++ b/cmd/collector/app/handler/grpc_handler.go @@ -23,40 +23,62 @@ import ( "google.golang.org/grpc/status" "github.com/jaegertracing/jaeger/cmd/collector/app/processor" + "github.com/jaegertracing/jaeger/model" "github.com/jaegertracing/jaeger/proto-gen/api_v2" ) // GRPCHandler implements gRPC CollectorService. type GRPCHandler struct { - logger *zap.Logger - spanProcessor processor.SpanProcessor + logger *zap.Logger + // spanProcessor processor.SpanProcessor + batchConsumer batchConsumer } // NewGRPCHandler registers routes for this handler on the given router. func NewGRPCHandler(logger *zap.Logger, spanProcessor processor.SpanProcessor) *GRPCHandler { return &GRPCHandler{ - logger: logger, - spanProcessor: spanProcessor, + logger: logger, + // spanProcessor: spanProcessor, + batchConsumer: batchConsumer{ + logger: logger, + spanProcessor: spanProcessor, + spanOptions: processor.SpansOptions{ + InboundTransport: processor.GRPCTransport, + SpanFormat: processor.ProtoSpanFormat, + }, + }, } } // PostSpans implements gRPC CollectorService. func (g *GRPCHandler) PostSpans(ctx context.Context, r *api_v2.PostSpansRequest) (*api_v2.PostSpansResponse, error) { - for _, span := range r.GetBatch().Spans { + batch := &r.Batch + err := g.batchConsumer.consume(batch) + return &api_v2.PostSpansResponse{}, err +} + +type batchConsumer struct { + logger *zap.Logger + spanProcessor processor.SpanProcessor + spanOptions processor.SpansOptions +} + +func (c *batchConsumer) consume(batch *model.Batch) error { + for _, span := range batch.Spans { if span.GetProcess() == nil { - span.Process = r.Batch.Process + span.Process = batch.Process } } - _, err := g.spanProcessor.ProcessSpans(r.GetBatch().Spans, processor.SpansOptions{ + _, err := c.spanProcessor.ProcessSpans(batch.Spans, processor.SpansOptions{ InboundTransport: processor.GRPCTransport, SpanFormat: processor.ProtoSpanFormat, }) if err != nil { if err == processor.ErrBusy { - return nil, status.Errorf(codes.ResourceExhausted, err.Error()) + return status.Errorf(codes.ResourceExhausted, err.Error()) } - g.logger.Error("cannot process spans", zap.Error(err)) - return nil, err + c.logger.Error("cannot process spans", zap.Error(err)) + return err } - return &api_v2.PostSpansResponse{}, nil + return nil } diff --git a/cmd/collector/app/handler/grpc_handler_test.go b/cmd/collector/app/handler/grpc_handler_test.go index 3b109af70f9..a38b7bc41bf 100644 --- a/cmd/collector/app/handler/grpc_handler_test.go +++ b/cmd/collector/app/handler/grpc_handler_test.go @@ -29,6 +29,7 @@ import ( "github.com/jaegertracing/jaeger/cmd/collector/app/processor" "github.com/jaegertracing/jaeger/model" + "github.com/jaegertracing/jaeger/pkg/testutils" "github.com/jaegertracing/jaeger/proto-gen/api_v2" ) @@ -123,32 +124,55 @@ func TestGRPCCompressionEnabled(t *testing.T) { defer conn.Close() // Do not use string constant imported from grpc, since we are actually testing that package is imported by the handler. - _, err := client.PostSpans(context.Background(), &api_v2.PostSpansRequest{}, - grpc.UseCompressor("gzip")) + _, err := client.PostSpans( + context.Background(), + &api_v2.PostSpansRequest{}, + grpc.UseCompressor("gzip"), + ) require.NoError(t, err) } func TestPostSpansWithError(t *testing.T) { - expectedError := errors.New("test-error") - processor := &mockSpanProcessor{expectedError: expectedError} - server, addr := initializeGRPCTestServer(t, func(s *grpc.Server) { - handler := NewGRPCHandler(zap.NewNop(), processor) - api_v2.RegisterCollectorServiceServer(s, handler) - }) - defer server.Stop() - client, conn := newClient(t, addr) - defer conn.Close() - r, err := client.PostSpans(context.Background(), &api_v2.PostSpansRequest{ - Batch: model.Batch{ - Spans: []*model.Span{ - { - OperationName: "fake-operation", - }, - }, + testCases := []struct { + processorError error + expectedError string + expectedLog string + }{ + { + processorError: errors.New("test-error"), + expectedError: "test-error", + expectedLog: "test-error", }, - }) - require.Error(t, err) - require.Nil(t, r) - require.Contains(t, err.Error(), expectedError.Error()) - require.Len(t, processor.getSpans(), 1) + { + processorError: processor.ErrBusy, + expectedError: "server busy", + }, + } + for _, test := range testCases { + t.Run(test.expectedError, func(t *testing.T) { + processor := &mockSpanProcessor{expectedError: test.processorError} + logger, logBuf := testutils.NewLogger() + server, addr := initializeGRPCTestServer(t, func(s *grpc.Server) { + handler := NewGRPCHandler(logger, processor) + api_v2.RegisterCollectorServiceServer(s, handler) + }) + defer server.Stop() + client, conn := newClient(t, addr) + defer conn.Close() + r, err := client.PostSpans(context.Background(), &api_v2.PostSpansRequest{ + Batch: model.Batch{ + Spans: []*model.Span{ + { + OperationName: "fake-operation", + }, + }, + }, + }) + require.Error(t, err) + require.Nil(t, r) + assert.Contains(t, err.Error(), test.expectedError) + assert.Contains(t, logBuf.String(), test.expectedLog) + assert.Len(t, processor.getSpans(), 1) + }) + } } diff --git a/cmd/collector/app/handler/otlp_receiver.go b/cmd/collector/app/handler/otlp_receiver.go index 5499904eeed..3e156b94b33 100644 --- a/cmd/collector/app/handler/otlp_receiver.go +++ b/cmd/collector/app/handler/otlp_receiver.go @@ -29,66 +29,86 @@ import ( "github.com/jaegertracing/jaeger/cmd/collector/app/processor" "github.com/jaegertracing/jaeger/model" - "github.com/jaegertracing/jaeger/proto-gen/api_v2" ) -// A delegation function to assist in tests, because ProtoFromTraces never returns errors despite its API. -var protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) = otlp2jaeger.ProtoFromTraces +// // A delegation function to assist in tests, because ProtoFromTraces never returns errors despite its API. +// var protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) = otlp2jaeger.ProtoFromTraces var _ component.Host = (*otelHost)(nil) // API check +// OtelReceiverOptions allows configuration of the receiver. type OtelReceiverOptions struct { - GRPCAddress string - HTTPAddress string + GRPCHostPort string + HTTPHostPort string } // StartOtelReceiver starts OpenTelemetry OTLP receiver listening on gRPC and HTTP ports. -func StartOtelReceiver(logger *zap.Logger, spanProcessor processor.SpanProcessor) (component.TracesReceiver, error) { +func StartOtelReceiver(options OtelReceiverOptions, logger *zap.Logger, spanProcessor processor.SpanProcessor) (component.TracesReceiver, error) { otlpFactory := otlpreceiver.NewFactory() - otlpReceiverConfig := otlpFactory.CreateDefaultConfig() + otlpReceiverConfig := otlpFactory.CreateDefaultConfig().(*otlpreceiver.Config) + if options.GRPCHostPort != "" { + otlpReceiverConfig.GRPC.NetAddr.Endpoint = options.GRPCHostPort + } + if options.HTTPHostPort != "" { + otlpReceiverConfig.HTTP.Endpoint = options.HTTPHostPort + } otlpReceiverSettings := component.ReceiverCreateSettings{ TelemetrySettings: component.TelemetrySettings{ Logger: logger, TracerProvider: otel.GetTracerProvider(), // TODO we may always want no-op here, not the global default }, } - // TODO re-implement the logic of NewGRPCHandler, it's fairly trivial - jaegerBatchHandler := NewGRPCHandler(logger, spanProcessor) - nextConsumer, err := consumer.NewTraces(consumer.ConsumeTracesFunc(func(ctx context.Context, ld ptrace.Traces) error { - batches, err := protoFromTraces(ld) - if err != nil { - return err - } - for _, batch := range batches { - // TODO generate metrics - _, err := jaegerBatchHandler.PostSpans(ctx, &api_v2.PostSpansRequest{ - Batch: *batch, - }) - if err != nil { - return err - } - } - return nil - })) - if err != nil { - return nil, fmt.Errorf("could not create the OTLP consumer: %w", err) - } - otlpReceiver, err := otlpFactory.CreateTracesReceiver( + + otlpConsumer := newConsumerDelegate(logger, spanProcessor) + // the following two constructors never return errors given non-nil arguments, so we ignore errors + nextConsumer, _ := consumer.NewTraces(consumer.ConsumeTracesFunc(otlpConsumer.consume)) + otlpReceiver, _ := otlpFactory.CreateTracesReceiver( context.Background(), otlpReceiverSettings, otlpReceiverConfig, nextConsumer, ) - if err != nil { - return nil, fmt.Errorf("could not create the OTLP receiver: %w", err) - } - err = otlpReceiver.Start(context.Background(), &otelHost{logger: logger}) - if err != nil { + if err := otlpReceiver.Start(context.Background(), &otelHost{logger: logger}); err != nil { return nil, fmt.Errorf("could not start the OTLP receiver: %w", err) } return otlpReceiver, nil } +func newConsumerDelegate(logger *zap.Logger, spanProcessor processor.SpanProcessor) *consumerDelegate { + return &consumerDelegate{ + logger: logger, + batchConsumer: batchConsumer{ + logger: logger, + spanProcessor: spanProcessor, + spanOptions: processor.SpansOptions{ + SpanFormat: processor.OTLPSpanFormat, + InboundTransport: processor.UnknownTransport, // could be gRPC or HTTP + }, + }, + protoFromTraces: otlp2jaeger.ProtoFromTraces, + } +} + +type consumerDelegate struct { + logger *zap.Logger + batchConsumer batchConsumer + protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) +} + +func (c *consumerDelegate) consume(ctx context.Context, ld ptrace.Traces) error { + batches, err := c.protoFromTraces(ld) + if err != nil { + return err + } + for _, batch := range batches { + err := c.batchConsumer.consume(batch) + if err != nil { + return err + } + } + return nil +} + // otelHost is a mostly no-op implementation of OTEL component.Host type otelHost struct { logger *zap.Logger diff --git a/cmd/collector/app/handler/otlp_receiver_test.go b/cmd/collector/app/handler/otlp_receiver_test.go new file mode 100644 index 00000000000..5d03a46b388 --- /dev/null +++ b/cmd/collector/app/handler/otlp_receiver_test.go @@ -0,0 +1,126 @@ +// Copyright (c) 2022 The Jaeger 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 handler + +import ( + "context" + "errors" + "testing" + + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" + "go.opentelemetry.io/collector/component" + "go.opentelemetry.io/collector/config" + "go.opentelemetry.io/collector/pdata/ptrace" + + "github.com/jaegertracing/jaeger/model" + "github.com/jaegertracing/jaeger/pkg/testutils" +) + +func TestStartOtlpReceiver(t *testing.T) { + spanProcessor := &mockSpanProcessor{} + logger, _ := testutils.NewLogger() + rec, err := StartOtelReceiver( + OtelReceiverOptions{ + GRPCHostPort: ":0", + HTTPHostPort: ":0", + }, + logger, + spanProcessor, + ) + require.NoError(t, err) + defer func() { + assert.NoError(t, rec.Shutdown(context.Background())) + }() + + // Ideally, we want to test with a real gRPC client, but OTEL repos only have those as internal packages. + // So we will rely on otlpreceiver being tested in the OTEL repos, and we only test the consumer function. +} + +func makeTracesOneSpan() ptrace.Traces { + traces := ptrace.NewTraces() + rSpans := traces.ResourceSpans().AppendEmpty() + sSpans := rSpans.ScopeSpans().AppendEmpty() + span := sSpans.Spans().AppendEmpty() + span.SetName("test") + return traces +} + +func TestConsumerDelegate(t *testing.T) { + logger, _ := testutils.NewLogger() + spanProcessor := &mockSpanProcessor{} + consumer := newConsumerDelegate(logger, spanProcessor) + + err := consumer.consume(context.Background(), makeTracesOneSpan()) + require.NoError(t, err) + assert.Len(t, spanProcessor.getSpans(), 1) +} + +func TestConsumerDelegate_Error(t *testing.T) { + logger, logBuf := testutils.NewLogger() + expectedErr := errors.New("test-error") + spanProcessor := &mockSpanProcessor{ + expectedError: expectedErr, + } + consumer := newConsumerDelegate(logger, spanProcessor) + + err := consumer.consume(context.Background(), makeTracesOneSpan()) + require.Error(t, err) + assert.Equal(t, expectedErr, err) + assert.Contains(t, logBuf.String(), "test-error") +} + +func TestStartOtlpReceiver_Error(t *testing.T) { + spanProcessor := &mockSpanProcessor{} + logger, _ := testutils.NewLogger() + _, err := StartOtelReceiver( + OtelReceiverOptions{ + GRPCHostPort: ":-1", + HTTPHostPort: ":-1", + }, + logger, + spanProcessor, + ) + assert.Error(t, err) +} +func TestProtoFromTracesError(t *testing.T) { + mockErr := errors.New("mock error") + c := &consumerDelegate{ + protoFromTraces: func(td ptrace.Traces) ([]*model.Batch, error) { + return nil, mockErr + }, + } + err := c.consume(context.Background(), ptrace.Traces{}) + assert.Equal(t, mockErr, err) +} + +func TestOtelHost_ReportFatalError(t *testing.T) { + logger, buf := testutils.NewLogger() + host := &otelHost{logger: logger} + + defer func() { + _ = recover() + assert.Contains(t, buf.String(), "mock error") + }() + host.ReportFatalError(errors.New("mock error")) + t.Errorf("ReportFatalError did not panic") +} + +func TestOtelHost(t *testing.T) { + host := &otelHost{} + assert.Nil(t, host.GetFactory(component.KindReceiver, config.TracesDataType)) + assert.Nil(t, host.GetExtensions()) + assert.Nil(t, host.GetExporters()) +} diff --git a/cmd/collector/app/handler/otlp_receover_test.go b/cmd/collector/app/handler/otlp_receover_test.go deleted file mode 100644 index b55a0997214..00000000000 --- a/cmd/collector/app/handler/otlp_receover_test.go +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (c) 2022 The Jaeger 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 handler - -import ( - "context" - "testing" - - "github.com/stretchr/testify/require" - - "github.com/jaegertracing/jaeger/pkg/testutils" -) - -func TestOtlpReceiver(t *testing.T) { - spanProcessor := &mockSpanProcessor{} - logger, _ := testutils.NewLogger() - rec, err := StartOtelReceiver(logger, spanProcessor) - require.NoError(t, err) - err = rec.Shutdown(context.Background()) - require.NoError(t, err) -} diff --git a/cmd/collector/app/processor/interface.go b/cmd/collector/app/processor/interface.go index de6f81012d2..f22a92051cd 100644 --- a/cmd/collector/app/processor/interface.go +++ b/cmd/collector/app/processor/interface.go @@ -60,6 +60,8 @@ const ( ZipkinSpanFormat SpanFormat = "zipkin" // ProtoSpanFormat is for Jaeger protobuf Spans. ProtoSpanFormat SpanFormat = "proto" + // OTLPSpanFormat is for OpenTelemetry OTLP format. + OTLPSpanFormat SpanFormat = "otlp" // UnknownSpanFormat is the fallback/catch-all category. UnknownSpanFormat SpanFormat = "unknown" ) From 8cec8a9ad364ae2e1f93485a24d0c59590c44448 Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Thu, 26 May 2022 20:36:11 -0400 Subject: [PATCH 4/8] cleanup Signed-off-by: Yuri Shkuro --- cmd/collector/app/handler/grpc_handler.go | 4 +- cmd/collector/app/handler/otlp_receiver.go | 5 --- .../app/handler/otlp_receiver_test.go | 39 ++++++++++--------- 3 files changed, 22 insertions(+), 26 deletions(-) diff --git a/cmd/collector/app/handler/grpc_handler.go b/cmd/collector/app/handler/grpc_handler.go index a98c5ce29d2..51d35920b19 100644 --- a/cmd/collector/app/handler/grpc_handler.go +++ b/cmd/collector/app/handler/grpc_handler.go @@ -29,8 +29,7 @@ import ( // GRPCHandler implements gRPC CollectorService. type GRPCHandler struct { - logger *zap.Logger - // spanProcessor processor.SpanProcessor + logger *zap.Logger batchConsumer batchConsumer } @@ -38,7 +37,6 @@ type GRPCHandler struct { func NewGRPCHandler(logger *zap.Logger, spanProcessor processor.SpanProcessor) *GRPCHandler { return &GRPCHandler{ logger: logger, - // spanProcessor: spanProcessor, batchConsumer: batchConsumer{ logger: logger, spanProcessor: spanProcessor, diff --git a/cmd/collector/app/handler/otlp_receiver.go b/cmd/collector/app/handler/otlp_receiver.go index 3e156b94b33..3bdf41a9d8e 100644 --- a/cmd/collector/app/handler/otlp_receiver.go +++ b/cmd/collector/app/handler/otlp_receiver.go @@ -31,9 +31,6 @@ import ( "github.com/jaegertracing/jaeger/model" ) -// // A delegation function to assist in tests, because ProtoFromTraces never returns errors despite its API. -// var protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) = otlp2jaeger.ProtoFromTraces - var _ component.Host = (*otelHost)(nil) // API check // OtelReceiverOptions allows configuration of the receiver. @@ -76,7 +73,6 @@ func StartOtelReceiver(options OtelReceiverOptions, logger *zap.Logger, spanProc func newConsumerDelegate(logger *zap.Logger, spanProcessor processor.SpanProcessor) *consumerDelegate { return &consumerDelegate{ - logger: logger, batchConsumer: batchConsumer{ logger: logger, spanProcessor: spanProcessor, @@ -90,7 +86,6 @@ func newConsumerDelegate(logger *zap.Logger, spanProcessor processor.SpanProcess } type consumerDelegate struct { - logger *zap.Logger batchConsumer batchConsumer protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) } diff --git a/cmd/collector/app/handler/otlp_receiver_test.go b/cmd/collector/app/handler/otlp_receiver_test.go index 5d03a46b388..a9eeb8c7dd8 100644 --- a/cmd/collector/app/handler/otlp_receiver_test.go +++ b/cmd/collector/app/handler/otlp_receiver_test.go @@ -59,27 +59,30 @@ func makeTracesOneSpan() ptrace.Traces { } func TestConsumerDelegate(t *testing.T) { - logger, _ := testutils.NewLogger() - spanProcessor := &mockSpanProcessor{} - consumer := newConsumerDelegate(logger, spanProcessor) + testCases := []struct { + expectErr error + expectLog string + }{ + {}, // no errors + {expectErr: errors.New("test-error"), expectLog: "test-error"}, + } + for _, test := range testCases { + t.Run(test.expectLog, func(t *testing.T) { + logger, logBuf := testutils.NewLogger() + spanProcessor := &mockSpanProcessor{expectedError: test.expectErr} + consumer := newConsumerDelegate(logger, spanProcessor) - err := consumer.consume(context.Background(), makeTracesOneSpan()) - require.NoError(t, err) - assert.Len(t, spanProcessor.getSpans(), 1) -} + err := consumer.consume(context.Background(), makeTracesOneSpan()) -func TestConsumerDelegate_Error(t *testing.T) { - logger, logBuf := testutils.NewLogger() - expectedErr := errors.New("test-error") - spanProcessor := &mockSpanProcessor{ - expectedError: expectedErr, + if test.expectErr != nil { + require.Equal(t, test.expectErr, err) + assert.Contains(t, logBuf.String(), test.expectLog) + } else { + require.NoError(t, err) + assert.Len(t, spanProcessor.getSpans(), 1) + } + }) } - consumer := newConsumerDelegate(logger, spanProcessor) - - err := consumer.consume(context.Background(), makeTracesOneSpan()) - require.Error(t, err) - assert.Equal(t, expectedErr, err) - assert.Contains(t, logBuf.String(), "test-error") } func TestStartOtlpReceiver_Error(t *testing.T) { From ff415e5130d486edb50207b2d8404a3ce31c195b Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Thu, 26 May 2022 21:52:41 -0400 Subject: [PATCH 5/8] coverage Signed-off-by: Yuri Shkuro --- cmd/collector/app/collector.go | 16 ++-- cmd/collector/app/collector_test.go | 99 +++++++++++++++------ cmd/collector/app/root_span_handler_test.go | 17 ++-- 3 files changed, 90 insertions(+), 42 deletions(-) diff --git a/cmd/collector/app/collector.go b/cmd/collector/app/collector.go index ee2fee33cc8..c3c3c68d49c 100644 --- a/cmd/collector/app/collector.go +++ b/cmd/collector/app/collector.go @@ -109,7 +109,7 @@ func (c *Collector) Start(options *CollectorOptions) error { MaxConnectionAgeGrace: options.GRPC.MaxConnectionAgeGrace, }) if err != nil { - return fmt.Errorf("could not start gRPC collector: %w", err) + return fmt.Errorf("could not start gRPC server: %w", err) } c.grpcServer = grpcServer @@ -123,7 +123,7 @@ func (c *Collector) Start(options *CollectorOptions) error { Logger: c.logger, }) if err != nil { - return fmt.Errorf("could not start the HTTP server: %w", err) + return fmt.Errorf("could not start HTTP server: %w", err) } c.hServer = httpServer @@ -141,7 +141,7 @@ func (c *Collector) Start(options *CollectorOptions) error { MetricsFactory: c.metricsFactory, }) if err != nil { - return fmt.Errorf("could not start the Zipkin server: %w", err) + return fmt.Errorf("could not start Zipkin server: %w", err) } c.zkServer = zkServer @@ -154,7 +154,7 @@ func (c *Collector) Start(options *CollectorOptions) error { c.spanProcessor, ) if err != nil { - return err + return fmt.Errorf("could not start OTLP server: %w", err) } c.otlpReceiver = otlpReceiver @@ -171,12 +171,12 @@ func (c *Collector) publishOpts(cOpts *CollectorOptions) { // Close the component and all its underlying dependencies func (c *Collector) Close() error { - // gRPC server + // Stop gRPC server if c.grpcServer != nil { c.grpcServer.GracefulStop() } - // HTTP server + // Stop HTTP server if c.hServer != nil { timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second) if err := c.hServer.Shutdown(timeout); err != nil { @@ -185,7 +185,7 @@ func (c *Collector) Close() error { defer cancel() } - // Zipkin server + // Stop Zipkin server if c.zkServer != nil { timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second) if err := c.zkServer.Shutdown(timeout); err != nil { @@ -194,7 +194,7 @@ func (c *Collector) Close() error { defer cancel() } - // OpenTelemetry OTLP receiver + // Stop OpenTelemetry OTLP receiver if c.otlpReceiver != nil { timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second) if err := c.otlpReceiver.Shutdown(timeout); err != nil { diff --git a/cmd/collector/app/collector_test.go b/cmd/collector/app/collector_test.go index d5e369e172b..897912d617b 100644 --- a/cmd/collector/app/collector_test.go +++ b/cmd/collector/app/collector_test.go @@ -21,6 +21,7 @@ import ( "time" "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" "github.com/uber/jaeger-lib/metrics/fork" "github.com/uber/jaeger-lib/metrics/metricstest" "go.uber.org/zap" @@ -33,6 +34,15 @@ import ( var _ (io.Closer) = (*Collector)(nil) +func optionsForEphemeralPorts() *CollectorOptions { + collectorOpts := &CollectorOptions{} + collectorOpts.GRPC.HostPort = ":0" + collectorOpts.HTTP.HostPort = ":0" + collectorOpts.OTLP.GRPCHostPort = ":0" + collectorOpts.OTLP.HTTPHostPort = ":0" + return collectorOpts +} + func TestNewCollector(t *testing.T) { // prepare hc := healthcheck.New() @@ -49,13 +59,51 @@ func TestNewCollector(t *testing.T) { StrategyStore: strategyStore, HealthCheck: hc, }) - collectorOpts := &CollectorOptions{} + collectorOpts := optionsForEphemeralPorts() + require.NoError(t, c.Start(collectorOpts)) + assert.NoError(t, c.Close()) +} - // test - c.Start(collectorOpts) +func TestCollector_StartErrors(t *testing.T) { + run := func(name string, options *CollectorOptions, expErr string) { + t.Run(name, func(t *testing.T) { + hc := healthcheck.New() + logger := zap.NewNop() + baseMetrics := metricstest.NewFactory(time.Hour) + spanWriter := &fakeSpanWriter{} + strategyStore := &mockStrategyStore{} + + c := New(&CollectorParams{ + ServiceName: "collector", + Logger: logger, + MetricsFactory: baseMetrics, + SpanWriter: spanWriter, + StrategyStore: strategyStore, + HealthCheck: hc, + }) + err := c.Start(options) + require.Error(t, err) + assert.Contains(t, err.Error(), expErr) + }) + } - // verify - assert.NoError(t, c.Close()) + var options *CollectorOptions + + options = optionsForEphemeralPorts() + options.GRPC.HostPort = ":-1" + run("gRPC", options, "could not start gRPC server") + + options = optionsForEphemeralPorts() + options.HTTP.HostPort = ":-1" + run("HTTP", options, "could not start HTTP server") + + options = optionsForEphemeralPorts() + options.Zipkin.HTTPHostPort = ":-1" + run("Zipkin", options, "could not start Zipkin server") + + options = optionsForEphemeralPorts() + options.OTLP.HTTPHostPort = ":-1" + run("OTLP", options, "could not start OTLP server") } type mockStrategyStore struct { @@ -83,12 +131,11 @@ func TestCollector_PublishOpts(t *testing.T) { StrategyStore: strategyStore, HealthCheck: hc, }) - collectorOpts := &CollectorOptions{ - NumWorkers: 24, - QueueSize: 42, - } + collectorOpts := optionsForEphemeralPorts() + collectorOpts.NumWorkers = 24 + collectorOpts.QueueSize = 42 - c.Start(collectorOpts) + require.NoError(t, c.Start(collectorOpts)) defer c.Close() forkFactory.AssertGaugeMetrics(t, metricstest.ExpectedMetric{ @@ -119,16 +166,13 @@ func TestAggregator(t *testing.T) { HealthCheck: hc, Aggregator: agg, }) - collectorOpts := &CollectorOptions{ - QueueSize: 10, - NumWorkers: 10, - } - - // test - c.Start(collectorOpts) + collectorOpts := optionsForEphemeralPorts() + collectorOpts.NumWorkers = 10 + collectorOpts.QueueSize = 10 + require.NoError(t, c.Start(collectorOpts)) // assert that aggregator was added to the collector - _, err := c.spanProcessor.ProcessSpans([]*model.Span{ + spans := []*model.Span{ { OperationName: "y", Process: &model.Process{ @@ -145,15 +189,18 @@ func TestAggregator(t *testing.T) { }, }, }, - }, processor.SpansOptions{SpanFormat: processor.JaegerSpanFormat}) + } + _, err := c.spanProcessor.ProcessSpans(spans, processor.SpansOptions{SpanFormat: processor.JaegerSpanFormat}) assert.NoError(t, err) - - // verify assert.NoError(t, c.Close()) - // assert that aggregator was used - assert.Equal(t, 1, agg.callCount) - - // assert that aggregator close was called - assert.Equal(t, 1, agg.closeCount) + // spans are processed by background workers, so we may need to wait + for i := 0; i < 1000; i++ { + if agg.callCount.Load() == 1 && agg.closeCount.Load() == 1 { + break + } + time.Sleep(10 * time.Millisecond) + } + assert.EqualValues(t, 1, agg.callCount.Load(), "aggregator was used") + assert.EqualValues(t, 1, agg.closeCount.Load(), "aggregator close was called") } diff --git a/cmd/collector/app/root_span_handler_test.go b/cmd/collector/app/root_span_handler_test.go index 9f469d5580a..c73cfce9a4c 100644 --- a/cmd/collector/app/root_span_handler_test.go +++ b/cmd/collector/app/root_span_handler_test.go @@ -18,22 +18,23 @@ import ( "testing" "github.com/stretchr/testify/assert" + "go.uber.org/atomic" "go.uber.org/zap" "github.com/jaegertracing/jaeger/model" ) type mockAggregator struct { - callCount int - closeCount int + callCount atomic.Int32 + closeCount atomic.Int32 } func (t *mockAggregator) RecordThroughput(service, operation, samplerType string, probability float64) { - t.callCount++ + t.callCount.Inc() } func (t *mockAggregator) Start() {} func (t *mockAggregator) Close() error { - t.closeCount++ + t.closeCount.Inc() return nil } @@ -44,7 +45,7 @@ func TestHandleRootSpan(t *testing.T) { // Testing non-root span span := &model.Span{References: []model.SpanRef{{SpanID: model.NewSpanID(1), RefType: model.ChildOf}}} processor(span, "") - assert.Equal(t, 0, aggregator.callCount) + assert.EqualValues(t, 0, aggregator.callCount.Load()) // Testing span with service name but no operation span.References = []model.SpanRef{} @@ -52,12 +53,12 @@ func TestHandleRootSpan(t *testing.T) { ServiceName: "service", } processor(span, "") - assert.Equal(t, 0, aggregator.callCount) + assert.EqualValues(t, 0, aggregator.callCount.Load()) // Testing span with service name and operation but no probabilistic sampling tags span.OperationName = "GET" processor(span, "") - assert.Equal(t, 0, aggregator.callCount) + assert.EqualValues(t, 0, aggregator.callCount.Load()) // Testing span with service name, operation, and probabilistic sampling tags span.Tags = model.KeyValues{ @@ -65,5 +66,5 @@ func TestHandleRootSpan(t *testing.T) { model.String("sampler.param", "0.001"), } processor(span, "") - assert.Equal(t, 1, aggregator.callCount) + assert.EqualValues(t, 1, aggregator.callCount.Load()) } From cbef0132c8a9455ce93df90d6bd6e5041c4e48b8 Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Sun, 29 May 2022 15:59:23 -0400 Subject: [PATCH 6/8] Apply suggestions from code review Signed-off-by: Yuri Shkuro Co-authored-by: Albert <26584478+albertteoh@users.noreply.github.com> --- cmd/collector/app/handler/otlp_receiver.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/cmd/collector/app/handler/otlp_receiver.go b/cmd/collector/app/handler/otlp_receiver.go index 3bdf41a9d8e..97b4faf954d 100644 --- a/cmd/collector/app/handler/otlp_receiver.go +++ b/cmd/collector/app/handler/otlp_receiver.go @@ -58,7 +58,7 @@ func StartOtelReceiver(options OtelReceiverOptions, logger *zap.Logger, spanProc otlpConsumer := newConsumerDelegate(logger, spanProcessor) // the following two constructors never return errors given non-nil arguments, so we ignore errors - nextConsumer, _ := consumer.NewTraces(consumer.ConsumeTracesFunc(otlpConsumer.consume)) + nextConsumer, _ := consumer.NewTraces(otlpConsumer.consume) otlpReceiver, _ := otlpFactory.CreateTracesReceiver( context.Background(), otlpReceiverSettings, @@ -90,7 +90,7 @@ type consumerDelegate struct { protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) } -func (c *consumerDelegate) consume(ctx context.Context, ld ptrace.Traces) error { +func (c *consumerDelegate) consume(_ context.Context, ld ptrace.Traces) error { batches, err := c.protoFromTraces(ld) if err != nil { return err From 266ea8706c0ea8c4d2a25069e89b151ed18fd37f Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Sun, 29 May 2022 16:03:37 -0400 Subject: [PATCH 7/8] OTLP server -> receiver Signed-off-by: Yuri Shkuro --- cmd/collector/app/collector.go | 2 +- cmd/collector/app/collector_test.go | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/cmd/collector/app/collector.go b/cmd/collector/app/collector.go index c3c3c68d49c..4f475ff25ad 100644 --- a/cmd/collector/app/collector.go +++ b/cmd/collector/app/collector.go @@ -154,7 +154,7 @@ func (c *Collector) Start(options *CollectorOptions) error { c.spanProcessor, ) if err != nil { - return fmt.Errorf("could not start OTLP server: %w", err) + return fmt.Errorf("could not start OTLP receiver: %w", err) } c.otlpReceiver = otlpReceiver diff --git a/cmd/collector/app/collector_test.go b/cmd/collector/app/collector_test.go index 897912d617b..deeb1f6f1c6 100644 --- a/cmd/collector/app/collector_test.go +++ b/cmd/collector/app/collector_test.go @@ -103,7 +103,7 @@ func TestCollector_StartErrors(t *testing.T) { options = optionsForEphemeralPorts() options.OTLP.HTTPHostPort = ":-1" - run("OTLP", options, "could not start OTLP server") + run("OTLP", options, "could not start OTLP receiver") } type mockStrategyStore struct { From 4bfca3cd9fd259aa06ce0648531ae9426448b2fd Mon Sep 17 00:00:00 2001 From: Yuri Shkuro Date: Sun, 29 May 2022 16:08:55 -0400 Subject: [PATCH 8/8] fixes Signed-off-by: Yuri Shkuro --- cmd/collector/app/handler/otlp_receiver.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cmd/collector/app/handler/otlp_receiver.go b/cmd/collector/app/handler/otlp_receiver.go index 97b4faf954d..91fcfc0208f 100644 --- a/cmd/collector/app/handler/otlp_receiver.go +++ b/cmd/collector/app/handler/otlp_receiver.go @@ -90,8 +90,8 @@ type consumerDelegate struct { protoFromTraces func(td ptrace.Traces) ([]*model.Batch, error) } -func (c *consumerDelegate) consume(_ context.Context, ld ptrace.Traces) error { - batches, err := c.protoFromTraces(ld) +func (c *consumerDelegate) consume(_ context.Context, td ptrace.Traces) error { + batches, err := c.protoFromTraces(td) if err != nil { return err } @@ -112,7 +112,7 @@ type otelHost struct { func (h *otelHost) ReportFatalError(err error) { h.logger.Fatal("OTLP receiver error", zap.Error(err)) } -func (*otelHost) GetFactory(kind component.Kind, componentType config.Type) component.Factory { +func (*otelHost) GetFactory(_ component.Kind, _ config.Type) component.Factory { return nil } func (*otelHost) GetExtensions() map[config.ComponentID]component.Extension {