232 lines
6.6 KiB
Go
232 lines
6.6 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package otlpexporter
|
|
|
|
import (
|
|
"context"
|
|
"path/filepath"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"go.opentelemetry.io/collector/component"
|
|
"go.opentelemetry.io/collector/component/componenttest"
|
|
"go.opentelemetry.io/collector/config"
|
|
"go.opentelemetry.io/collector/config/configcompression"
|
|
"go.opentelemetry.io/collector/config/configgrpc"
|
|
"go.opentelemetry.io/collector/config/configtls"
|
|
"go.opentelemetry.io/collector/exporter/exporterhelper"
|
|
"go.opentelemetry.io/collector/internal/testutil"
|
|
)
|
|
|
|
func TestCreateDefaultConfig(t *testing.T) {
|
|
factory := NewFactory()
|
|
cfg := factory.CreateDefaultConfig()
|
|
assert.NotNil(t, cfg, "failed to create default config")
|
|
assert.NoError(t, componenttest.CheckConfigStruct(cfg))
|
|
ocfg, ok := factory.CreateDefaultConfig().(*Config)
|
|
assert.True(t, ok)
|
|
assert.Equal(t, ocfg.RetrySettings, exporterhelper.NewDefaultRetrySettings())
|
|
assert.Equal(t, ocfg.QueueSettings, exporterhelper.NewDefaultQueueSettings())
|
|
assert.Equal(t, ocfg.TimeoutSettings, exporterhelper.NewDefaultTimeoutSettings())
|
|
assert.Equal(t, ocfg.Compression, configcompression.Gzip)
|
|
}
|
|
|
|
func TestCreateMetricsExporter(t *testing.T) {
|
|
factory := NewFactory()
|
|
cfg := factory.CreateDefaultConfig().(*Config)
|
|
cfg.GRPCClientSettings.Endpoint = testutil.GetAvailableLocalAddress(t)
|
|
|
|
set := componenttest.NewNopExporterCreateSettings()
|
|
oexp, err := factory.CreateMetricsExporter(context.Background(), set, cfg)
|
|
require.Nil(t, err)
|
|
require.NotNil(t, oexp)
|
|
}
|
|
|
|
func TestCreateTracesExporter(t *testing.T) {
|
|
endpoint := testutil.GetAvailableLocalAddress(t)
|
|
tests := []struct {
|
|
name string
|
|
config Config
|
|
mustFailOnCreate bool
|
|
mustFailOnStart bool
|
|
}{
|
|
{
|
|
name: "NoEndpoint",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: "",
|
|
},
|
|
},
|
|
mustFailOnCreate: true,
|
|
},
|
|
{
|
|
name: "UseSecure",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
TLSSetting: configtls.TLSClientSetting{
|
|
Insecure: false,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Keepalive",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
Keepalive: &configgrpc.KeepaliveClientConfig{
|
|
Time: 30 * time.Second,
|
|
Timeout: 25 * time.Second,
|
|
PermitWithoutStream: true,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "NoneCompression",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
Compression: "none",
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "GzipCompression",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
Compression: configcompression.Gzip,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "SnappyCompression",
|
|
config: Config{
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
Compression: configcompression.Snappy,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "ZstdCompression",
|
|
config: Config{
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
Compression: configcompression.Zstd,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "Headers",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
Headers: map[string]string{
|
|
"hdr1": "val1",
|
|
"hdr2": "val2",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "NumConsumers",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "CaCert",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
TLSSetting: configtls.TLSClientSetting{
|
|
TLSSetting: configtls.TLSSetting{
|
|
CAFile: filepath.Join("testdata", "test_cert.pem"),
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
{
|
|
name: "CertPemFileError",
|
|
config: Config{
|
|
ExporterSettings: config.NewExporterSettings(component.NewID(typeStr)),
|
|
GRPCClientSettings: configgrpc.GRPCClientSettings{
|
|
Endpoint: endpoint,
|
|
TLSSetting: configtls.TLSClientSetting{
|
|
TLSSetting: configtls.TLSSetting{
|
|
CAFile: "nosuchfile",
|
|
},
|
|
},
|
|
},
|
|
},
|
|
mustFailOnStart: true,
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
factory := NewFactory()
|
|
set := componenttest.NewNopExporterCreateSettings()
|
|
consumer, err := factory.CreateTracesExporter(context.Background(), set, &tt.config)
|
|
if tt.mustFailOnCreate {
|
|
assert.NotNil(t, err)
|
|
return
|
|
}
|
|
assert.NoError(t, err)
|
|
assert.NotNil(t, consumer)
|
|
err = consumer.Start(context.Background(), componenttest.NewNopHost())
|
|
if tt.mustFailOnStart {
|
|
assert.Error(t, err)
|
|
return
|
|
}
|
|
assert.NoError(t, err)
|
|
err = consumer.Shutdown(context.Background())
|
|
if err != nil {
|
|
// Since the endpoint of OTLP exporter doesn't actually exist,
|
|
// exporter may already stop because it cannot connect.
|
|
assert.Equal(t, err.Error(), "rpc error: code = Canceled desc = grpc: the client connection is closing")
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestCreateLogsExporter(t *testing.T) {
|
|
factory := NewFactory()
|
|
cfg := factory.CreateDefaultConfig().(*Config)
|
|
cfg.GRPCClientSettings.Endpoint = testutil.GetAvailableLocalAddress(t)
|
|
|
|
set := componenttest.NewNopExporterCreateSettings()
|
|
oexp, err := factory.CreateLogsExporter(context.Background(), set, cfg)
|
|
require.Nil(t, err)
|
|
require.NotNil(t, oexp)
|
|
}
|