2020-06-05 10:08:12 +02:00
|
|
|
// Copyright The OpenTelemetry Authors
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2020-06-05 09:19:30 +02:00
|
|
|
package jaeger
|
|
|
|
|
|
|
|
import (
|
2020-06-10 11:03:26 +02:00
|
|
|
"math"
|
2020-06-05 09:19:30 +02:00
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
|
|
|
"go.opentelemetry.io/otel/api/kv"
|
|
|
|
"go.opentelemetry.io/otel/api/kv/value"
|
2020-06-08 10:52:50 +02:00
|
|
|
ottest "go.opentelemetry.io/otel/internal/testing"
|
2020-06-05 09:19:30 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func Test_parseTags(t *testing.T) {
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore, err := ottest.SetEnvVariables(map[string]string{
|
|
|
|
"existing": "not-default",
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
defer func() {
|
|
|
|
require.NoError(t, envStore.Restore())
|
|
|
|
}()
|
2020-06-05 09:19:30 +02:00
|
|
|
|
2020-06-10 11:03:26 +02:00
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
tagStr string
|
|
|
|
expectedTags []kv.KeyValue
|
|
|
|
expectedError error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "string",
|
|
|
|
tagStr: "key=value",
|
|
|
|
expectedTags: []kv.KeyValue{
|
|
|
|
{
|
|
|
|
Key: "key",
|
|
|
|
Value: value.String("value"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "int64",
|
|
|
|
tagStr: "k=9223372036854775807,k2=-9223372036854775808",
|
|
|
|
expectedTags: []kv.KeyValue{
|
|
|
|
{
|
|
|
|
Key: "k",
|
|
|
|
Value: value.Int64(math.MaxInt64),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k2",
|
|
|
|
Value: value.Int64(math.MinInt64),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "float64",
|
|
|
|
tagStr: "k=1.797693134862315708145274237317043567981e+308,k2=4.940656458412465441765687928682213723651e-324,k3=-1.2",
|
|
|
|
expectedTags: []kv.KeyValue{
|
|
|
|
{
|
|
|
|
Key: "k",
|
|
|
|
Value: value.Float64(math.MaxFloat64),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k2",
|
|
|
|
Value: value.Float64(math.SmallestNonzeroFloat64),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k3",
|
|
|
|
Value: value.Float64(-1.2),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "multiple type values",
|
|
|
|
tagStr: "k=v,k2=123, k3=v3 ,k4=-1.2, k5=${existing:default},k6=${nonExisting:default}",
|
|
|
|
expectedTags: []kv.KeyValue{
|
|
|
|
{
|
|
|
|
Key: "k",
|
|
|
|
Value: value.String("v"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k2",
|
|
|
|
Value: value.Int64(123),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k3",
|
|
|
|
Value: value.String("v3"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k4",
|
|
|
|
Value: value.Float64(-1.2),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k5",
|
|
|
|
Value: value.String("not-default"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Key: "k6",
|
|
|
|
Value: value.String("default"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "malformed: only have key",
|
|
|
|
tagStr: "key",
|
|
|
|
expectedError: errTagValueNotFound,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "malformed: environment key has no default value",
|
|
|
|
tagStr: "key=${foo}",
|
|
|
|
expectedError: errTagEnvironmentDefaultValueNotFound,
|
|
|
|
},
|
|
|
|
}
|
2020-06-05 09:19:30 +02:00
|
|
|
|
2020-06-10 11:03:26 +02:00
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
tags, err := parseTags(tc.tagStr)
|
|
|
|
if tc.expectedError == nil {
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, tc.expectedTags, tags)
|
|
|
|
} else {
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.Equal(t, tc.expectedError, err)
|
|
|
|
assert.Equal(t, tc.expectedTags, tags)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2020-06-05 09:19:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func Test_parseValue(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
str string
|
|
|
|
expected value.Value
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "bool: true",
|
|
|
|
str: "true",
|
|
|
|
expected: value.Bool(true),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "bool: false",
|
|
|
|
str: "false",
|
|
|
|
expected: value.Bool(false),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "int64: 012340",
|
|
|
|
str: "012340",
|
|
|
|
expected: value.Int64(12340),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "int64: -012340",
|
|
|
|
str: "-012340",
|
|
|
|
expected: value.Int64(-12340),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "int64: 0",
|
|
|
|
str: "0",
|
|
|
|
expected: value.Int64(0),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "float64: -0.1",
|
|
|
|
str: "-0.1",
|
|
|
|
expected: value.Float64(-0.1),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "float64: 00.001",
|
|
|
|
str: "00.001",
|
|
|
|
expected: value.Float64(0.001),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "float64: 1E23",
|
|
|
|
str: "1E23",
|
|
|
|
expected: value.Float64(1e23),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "string: foo",
|
|
|
|
str: "foo",
|
|
|
|
expected: value.String("foo"),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
v := parseValue(tc.str)
|
|
|
|
assert.Equal(t, tc.expected, v)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewRawExporterWithEnv(t *testing.T) {
|
|
|
|
const (
|
|
|
|
collectorEndpoint = "http://localhost"
|
|
|
|
username = "user"
|
|
|
|
password = "password"
|
|
|
|
serviceName = "test-service"
|
2020-06-06 10:42:24 +02:00
|
|
|
disabled = "false"
|
2020-06-05 09:19:30 +02:00
|
|
|
tags = "key=value"
|
|
|
|
)
|
|
|
|
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore, err := ottest.SetEnvVariables(map[string]string{
|
|
|
|
envEndpoint: collectorEndpoint,
|
|
|
|
envUser: username,
|
|
|
|
envPassword: password,
|
|
|
|
envDisabled: disabled,
|
|
|
|
envServiceName: serviceName,
|
|
|
|
envTags: tags,
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
2020-06-05 09:19:30 +02:00
|
|
|
defer func() {
|
2020-06-08 10:52:50 +02:00
|
|
|
require.NoError(t, envStore.Restore())
|
2020-06-05 09:19:30 +02:00
|
|
|
}()
|
|
|
|
|
|
|
|
// Create Jaeger Exporter with environment variables
|
|
|
|
exp, err := NewRawExporter(
|
|
|
|
WithCollectorEndpoint(CollectorEndpointFromEnv(), WithCollectorEndpointOptionFromEnv()),
|
2020-06-06 10:42:24 +02:00
|
|
|
WithDisabled(true),
|
2020-06-05 09:19:30 +02:00
|
|
|
WithDisabledFromEnv(),
|
|
|
|
WithProcessFromEnv(),
|
|
|
|
)
|
|
|
|
|
|
|
|
assert.NoError(t, err)
|
2020-06-06 10:42:24 +02:00
|
|
|
assert.Equal(t, false, exp.o.Disabled)
|
2020-06-05 09:19:30 +02:00
|
|
|
assert.EqualValues(t, serviceName, exp.process.ServiceName)
|
|
|
|
assert.Len(t, exp.process.Tags, 1)
|
2020-06-06 10:42:24 +02:00
|
|
|
|
|
|
|
require.IsType(t, &collectorUploader{}, exp.uploader)
|
|
|
|
uploader := exp.uploader.(*collectorUploader)
|
|
|
|
assert.Equal(t, collectorEndpoint, uploader.endpoint)
|
|
|
|
assert.Equal(t, username, uploader.username)
|
|
|
|
assert.Equal(t, password, uploader.password)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewRawExporterWithEnvImplicitly(t *testing.T) {
|
|
|
|
const (
|
|
|
|
collectorEndpoint = "http://localhost"
|
|
|
|
username = "user"
|
|
|
|
password = "password"
|
|
|
|
serviceName = "test-service"
|
|
|
|
disabled = "false"
|
|
|
|
tags = "key=value"
|
|
|
|
)
|
|
|
|
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore, err := ottest.SetEnvVariables(map[string]string{
|
|
|
|
envEndpoint: collectorEndpoint,
|
|
|
|
envUser: username,
|
|
|
|
envPassword: password,
|
|
|
|
envDisabled: disabled,
|
|
|
|
envServiceName: serviceName,
|
|
|
|
envTags: tags,
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
2020-06-06 10:42:24 +02:00
|
|
|
defer func() {
|
2020-06-08 10:52:50 +02:00
|
|
|
require.NoError(t, envStore.Restore())
|
2020-06-06 10:42:24 +02:00
|
|
|
}()
|
|
|
|
|
|
|
|
// Create Jaeger Exporter with environment variables
|
|
|
|
exp, err := NewRawExporter(
|
2020-06-08 10:52:50 +02:00
|
|
|
WithCollectorEndpoint("should be overwritten"),
|
2020-06-06 10:42:24 +02:00
|
|
|
WithDisabled(true),
|
|
|
|
)
|
|
|
|
|
|
|
|
assert.NoError(t, err)
|
2020-06-10 05:36:25 +02:00
|
|
|
// NewRawExporter will ignore Disabled env
|
|
|
|
assert.Equal(t, true, exp.o.Disabled)
|
2020-06-06 10:42:24 +02:00
|
|
|
assert.EqualValues(t, serviceName, exp.process.ServiceName)
|
|
|
|
assert.Len(t, exp.process.Tags, 1)
|
|
|
|
|
|
|
|
require.IsType(t, &collectorUploader{}, exp.uploader)
|
|
|
|
uploader := exp.uploader.(*collectorUploader)
|
|
|
|
assert.Equal(t, collectorEndpoint, uploader.endpoint)
|
|
|
|
assert.Equal(t, username, uploader.username)
|
|
|
|
assert.Equal(t, password, uploader.password)
|
2020-06-05 09:19:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestCollectorEndpointFromEnv(t *testing.T) {
|
|
|
|
const (
|
|
|
|
collectorEndpoint = "http://localhost"
|
|
|
|
)
|
|
|
|
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore, err := ottest.SetEnvVariables(map[string]string{
|
|
|
|
envEndpoint: collectorEndpoint,
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
2020-06-05 09:19:30 +02:00
|
|
|
defer func() {
|
2020-06-08 10:52:50 +02:00
|
|
|
require.NoError(t, envStore.Restore())
|
2020-06-05 09:19:30 +02:00
|
|
|
}()
|
|
|
|
|
|
|
|
assert.Equal(t, collectorEndpoint, CollectorEndpointFromEnv())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestWithCollectorEndpointOptionFromEnv(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
envUsername string
|
|
|
|
envPassword string
|
|
|
|
collectorEndpointOptions CollectorEndpointOptions
|
|
|
|
expectedCollectorEndpointOptions CollectorEndpointOptions
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "overrides value via environment variables",
|
|
|
|
envUsername: "username",
|
|
|
|
envPassword: "password",
|
|
|
|
collectorEndpointOptions: CollectorEndpointOptions{
|
|
|
|
username: "foo",
|
|
|
|
password: "bar",
|
|
|
|
},
|
|
|
|
expectedCollectorEndpointOptions: CollectorEndpointOptions{
|
|
|
|
username: "username",
|
|
|
|
password: "password",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "environment variables is empty, will not overwrite value",
|
|
|
|
envUsername: "",
|
|
|
|
envPassword: "",
|
|
|
|
collectorEndpointOptions: CollectorEndpointOptions{
|
|
|
|
username: "foo",
|
|
|
|
password: "bar",
|
|
|
|
},
|
|
|
|
expectedCollectorEndpointOptions: CollectorEndpointOptions{
|
|
|
|
username: "foo",
|
|
|
|
password: "bar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore := ottest.NewEnvStore()
|
|
|
|
envStore.Record(envUser)
|
|
|
|
envStore.Record(envPassword)
|
|
|
|
defer func() {
|
|
|
|
require.NoError(t, envStore.Restore())
|
|
|
|
}()
|
2020-06-05 09:19:30 +02:00
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
require.NoError(t, os.Setenv(envUser, tc.envUsername))
|
|
|
|
require.NoError(t, os.Setenv(envPassword, tc.envPassword))
|
|
|
|
|
|
|
|
f := WithCollectorEndpointOptionFromEnv()
|
|
|
|
f(&tc.collectorEndpointOptions)
|
|
|
|
|
|
|
|
assert.Equal(t, tc.expectedCollectorEndpointOptions, tc.collectorEndpointOptions)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestWithDisabledFromEnv(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
env string
|
|
|
|
options options
|
|
|
|
expectedOptions options
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "overwriting",
|
|
|
|
env: "true",
|
|
|
|
options: options{},
|
|
|
|
expectedOptions: options{Disabled: true},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "no overwriting",
|
|
|
|
env: "",
|
|
|
|
options: options{Disabled: true},
|
|
|
|
expectedOptions: options{Disabled: true},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore := ottest.NewEnvStore()
|
|
|
|
envStore.Record(envDisabled)
|
|
|
|
defer func() {
|
|
|
|
require.NoError(t, envStore.Restore())
|
|
|
|
}()
|
2020-06-05 09:19:30 +02:00
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
require.NoError(t, os.Setenv(envDisabled, tc.env))
|
|
|
|
|
|
|
|
f := WithDisabledFromEnv()
|
|
|
|
f(&tc.options)
|
|
|
|
|
|
|
|
assert.Equal(t, tc.expectedOptions, tc.options)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestProcessFromEnv(t *testing.T) {
|
2020-06-10 11:03:26 +02:00
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
serviceName string
|
|
|
|
tags string
|
|
|
|
expectedProcess Process
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "set process",
|
|
|
|
serviceName: "test-service",
|
|
|
|
tags: "key=value,key2=123",
|
|
|
|
expectedProcess: Process{
|
|
|
|
ServiceName: "test-service",
|
|
|
|
Tags: []kv.KeyValue{
|
|
|
|
kv.String("key", "value"),
|
|
|
|
kv.Int64("key2", 123),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "malformed tags",
|
|
|
|
serviceName: "test-service",
|
|
|
|
tags: "key",
|
|
|
|
expectedProcess: Process{
|
|
|
|
ServiceName: "test-service",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2020-06-05 09:19:30 +02:00
|
|
|
|
2020-06-10 11:03:26 +02:00
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
envStore, err := ottest.SetEnvVariables(map[string]string{
|
|
|
|
envServiceName: tc.serviceName,
|
|
|
|
envTags: tc.tags,
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
2020-06-05 09:19:30 +02:00
|
|
|
|
2020-06-10 11:03:26 +02:00
|
|
|
p := ProcessFromEnv()
|
|
|
|
assert.Equal(t, tc.expectedProcess, p)
|
2020-06-05 09:19:30 +02:00
|
|
|
|
2020-06-10 11:03:26 +02:00
|
|
|
require.NoError(t, envStore.Restore())
|
|
|
|
})
|
|
|
|
}
|
2020-06-05 09:19:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestWithProcessFromEnv(t *testing.T) {
|
|
|
|
testCases := []struct {
|
|
|
|
name string
|
|
|
|
envServiceName string
|
|
|
|
envTags string
|
|
|
|
options options
|
|
|
|
expectedOptions options
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "overwriting",
|
|
|
|
envServiceName: "service-name",
|
|
|
|
envTags: "key=value",
|
|
|
|
options: options{
|
|
|
|
Process: Process{
|
|
|
|
ServiceName: "old-name",
|
|
|
|
Tags: []kv.KeyValue{
|
|
|
|
kv.String("old-key", "old-value"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedOptions: options{
|
|
|
|
Process: Process{
|
|
|
|
ServiceName: "service-name",
|
|
|
|
Tags: []kv.KeyValue{
|
|
|
|
kv.String("key", "value"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "no overwriting",
|
|
|
|
envServiceName: "",
|
|
|
|
envTags: "",
|
|
|
|
options: options{
|
|
|
|
Process: Process{
|
|
|
|
ServiceName: "old-name",
|
|
|
|
Tags: []kv.KeyValue{
|
|
|
|
kv.String("old-key", "old-value"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedOptions: options{
|
|
|
|
Process: Process{
|
|
|
|
ServiceName: "old-name",
|
|
|
|
Tags: []kv.KeyValue{
|
|
|
|
kv.String("old-key", "old-value"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-06-08 10:52:50 +02:00
|
|
|
envStore := ottest.NewEnvStore()
|
|
|
|
envStore.Record(envServiceName)
|
|
|
|
envStore.Record(envTags)
|
|
|
|
defer func() {
|
|
|
|
require.NoError(t, envStore.Restore())
|
|
|
|
}()
|
2020-06-05 09:19:30 +02:00
|
|
|
for _, tc := range testCases {
|
|
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
|
|
require.NoError(t, os.Setenv(envServiceName, tc.envServiceName))
|
|
|
|
require.NoError(t, os.Setenv(envTags, tc.envTags))
|
|
|
|
|
|
|
|
f := WithProcessFromEnv()
|
|
|
|
f(&tc.options)
|
|
|
|
|
|
|
|
assert.Equal(t, tc.expectedOptions, tc.options)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|