forked from open-telemetry/opentelemetry-collector-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
legacy_factory_test.go
121 lines (111 loc) · 3.76 KB
/
legacy_factory_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// 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
//
// https://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 lokiexporter
import (
"context"
"fmt"
"net/http"
"testing"
"time"
"github.com/stretchr/testify/assert"
"go.opentelemetry.io/collector/component/componenttest"
"go.opentelemetry.io/collector/config/confighttp"
"go.opentelemetry.io/collector/exporter/exportertest"
"github.com/open-telemetry/opentelemetry-collector-contrib/internal/common/testutil"
)
func TestFactory_CreateDefaultConfig(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.HTTPClientSettings.Endpoint)
assert.Equal(t, 30*time.Second, ocfg.HTTPClientSettings.Timeout, "default timeout is 30 seconds")
assert.Equal(t, true, ocfg.RetrySettings.Enabled, "default retry is enabled")
assert.Equal(t, 300*time.Second, ocfg.RetrySettings.MaxElapsedTime, "default retry MaxElapsedTime")
assert.Equal(t, 5*time.Second, ocfg.RetrySettings.InitialInterval, "default retry InitialInterval")
assert.Equal(t, 30*time.Second, ocfg.RetrySettings.MaxInterval, "default retry MaxInterval")
assert.Equal(t, true, ocfg.QueueSettings.Enabled, "default sending queue is enabled")
assert.Nil(t, ocfg.TenantID)
assert.Nil(t, ocfg.Labels)
}
func TestFactory_CreateLogsExporter(t *testing.T) {
skip(t, "Flaky Test - See https://github.com/open-telemetry/opentelemetry-collector-contrib/issues/15365")
tests := []struct {
name string
config Config
shouldError bool
errorMessage string
}{
{
name: "with valid config",
config: Config{
HTTPClientSettings: confighttp.HTTPClientSettings{
Endpoint: "https://" + testutil.GetAvailableLocalAddress(t),
},
Labels: &LabelsConfig{
Attributes: testValidAttributesWithMapping,
ResourceAttributes: testValidResourceWithMapping,
},
},
shouldError: false,
},
{
name: "with invalid config",
config: Config{
HTTPClientSettings: confighttp.HTTPClientSettings{
Endpoint: "",
},
},
shouldError: true,
},
{
name: "with forced bad configuration (for coverage)",
config: Config{
HTTPClientSettings: confighttp.HTTPClientSettings{
Endpoint: "",
CustomRoundTripper: func(next http.RoundTripper) (http.RoundTripper, error) {
return nil, fmt.Errorf("this causes newExporter(...) to error")
},
},
},
shouldError: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
factory := NewFactory()
creationParams := exportertest.NewNopCreateSettings()
exp, err := factory.CreateLogsExporter(context.Background(), creationParams, &tt.config)
if (err != nil) != tt.shouldError {
t.Errorf("CreateLogsExporter() error = %v, shouldError %v", err, tt.shouldError)
return
}
if tt.shouldError {
assert.Error(t, err)
if len(tt.errorMessage) != 0 {
assert.Equal(t, tt.errorMessage, err.Error())
}
return
}
assert.NoError(t, err)
assert.NotNil(t, exp)
})
}
}
// This abstraction prevents skipped function from causing "unused" lint errors
var skip = func(t *testing.T, why string) {
t.Skip(why)
}