2020-03-25 14:47:17 -07:00
|
|
|
// Copyright The OpenTelemetry Authors
|
2020-03-09 09:30:42 -07:00
|
|
|
//
|
|
|
|
|
// 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 resource_test
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
|
|
"github.com/google/go-cmp/cmp"
|
|
|
|
|
|
|
|
|
|
"go.opentelemetry.io/otel/api/core"
|
|
|
|
|
"go.opentelemetry.io/otel/sdk/resource"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var (
|
|
|
|
|
kv11 = core.Key("k1").String("v11")
|
|
|
|
|
kv12 = core.Key("k1").String("v12")
|
|
|
|
|
kv21 = core.Key("k2").String("v21")
|
|
|
|
|
kv31 = core.Key("k3").String("v31")
|
|
|
|
|
kv41 = core.Key("k4").String("v41")
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestNew(t *testing.T) {
|
|
|
|
|
cases := []struct {
|
|
|
|
|
name string
|
|
|
|
|
in []core.KeyValue
|
|
|
|
|
want []core.KeyValue
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "New with common key order1",
|
|
|
|
|
in: []core.KeyValue{kv11, kv12, kv21},
|
|
|
|
|
want: []core.KeyValue{kv11, kv21},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "New with common key order2",
|
|
|
|
|
in: []core.KeyValue{kv12, kv11, kv21},
|
|
|
|
|
want: []core.KeyValue{kv12, kv21},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "New with nil",
|
|
|
|
|
in: nil,
|
2020-04-07 12:15:36 -07:00
|
|
|
want: nil,
|
2020-03-09 09:30:42 -07:00
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, c := range cases {
|
|
|
|
|
t.Run(fmt.Sprintf("case-%s", c.name), func(t *testing.T) {
|
|
|
|
|
res := resource.New(c.in...)
|
|
|
|
|
if diff := cmp.Diff(
|
2020-04-07 12:15:36 -07:00
|
|
|
res.Attributes(),
|
|
|
|
|
c.want,
|
2020-03-09 09:30:42 -07:00
|
|
|
cmp.AllowUnexported(core.Value{})); diff != "" {
|
|
|
|
|
t.Fatalf("unwanted result: diff %+v,", diff)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestMerge(t *testing.T) {
|
|
|
|
|
cases := []struct {
|
|
|
|
|
name string
|
|
|
|
|
a, b *resource.Resource
|
|
|
|
|
want []core.KeyValue
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
name: "Merge with no overlap, no nil",
|
|
|
|
|
a: resource.New(kv11, kv31),
|
|
|
|
|
b: resource.New(kv21, kv41),
|
|
|
|
|
want: []core.KeyValue{kv11, kv21, kv31, kv41},
|
|
|
|
|
},
|
2020-04-07 12:15:36 -07:00
|
|
|
{
|
|
|
|
|
name: "Merge with no overlap, no nil, not interleaved",
|
|
|
|
|
a: resource.New(kv11, kv21),
|
|
|
|
|
b: resource.New(kv31, kv41),
|
|
|
|
|
want: []core.KeyValue{kv11, kv21, kv31, kv41},
|
|
|
|
|
},
|
2020-03-09 09:30:42 -07:00
|
|
|
{
|
|
|
|
|
name: "Merge with common key order1",
|
|
|
|
|
a: resource.New(kv11),
|
|
|
|
|
b: resource.New(kv12, kv21),
|
2020-04-07 12:15:36 -07:00
|
|
|
want: []core.KeyValue{kv11, kv21},
|
2020-03-09 09:30:42 -07:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Merge with common key order2",
|
|
|
|
|
a: resource.New(kv12, kv21),
|
|
|
|
|
b: resource.New(kv11),
|
|
|
|
|
want: []core.KeyValue{kv12, kv21},
|
|
|
|
|
},
|
2020-04-07 12:15:36 -07:00
|
|
|
{
|
|
|
|
|
name: "Merge with common key order4",
|
|
|
|
|
a: resource.New(kv11, kv21, kv41),
|
|
|
|
|
b: resource.New(kv31, kv41),
|
|
|
|
|
want: []core.KeyValue{kv11, kv21, kv31, kv41},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Merge with no keys",
|
|
|
|
|
a: resource.New(),
|
|
|
|
|
b: resource.New(),
|
|
|
|
|
want: nil,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Merge with first resource no keys",
|
|
|
|
|
a: resource.New(),
|
|
|
|
|
b: resource.New(kv21),
|
|
|
|
|
want: []core.KeyValue{kv21},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Merge with second resource no keys",
|
|
|
|
|
a: resource.New(kv11),
|
|
|
|
|
b: resource.New(),
|
|
|
|
|
want: []core.KeyValue{kv11},
|
|
|
|
|
},
|
2020-03-09 09:30:42 -07:00
|
|
|
{
|
|
|
|
|
name: "Merge with first resource nil",
|
|
|
|
|
a: nil,
|
|
|
|
|
b: resource.New(kv21),
|
|
|
|
|
want: []core.KeyValue{kv21},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
name: "Merge with second resource nil",
|
|
|
|
|
a: resource.New(kv11),
|
|
|
|
|
b: nil,
|
|
|
|
|
want: []core.KeyValue{kv11},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for _, c := range cases {
|
|
|
|
|
t.Run(fmt.Sprintf("case-%s", c.name), func(t *testing.T) {
|
|
|
|
|
res := resource.Merge(c.a, c.b)
|
|
|
|
|
if diff := cmp.Diff(
|
2020-04-07 12:15:36 -07:00
|
|
|
res.Attributes(),
|
|
|
|
|
c.want,
|
2020-03-09 09:30:42 -07:00
|
|
|
cmp.AllowUnexported(core.Value{})); diff != "" {
|
|
|
|
|
t.Fatalf("unwanted result: diff %+v,", diff)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-07 12:15:36 -07:00
|
|
|
func TestString(t *testing.T) {
|
|
|
|
|
for _, test := range []struct {
|
|
|
|
|
kvs []core.KeyValue
|
|
|
|
|
want string
|
|
|
|
|
}{
|
|
|
|
|
{
|
|
|
|
|
kvs: nil,
|
|
|
|
|
want: "Resource()",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{},
|
|
|
|
|
want: "Resource()",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{kv11},
|
|
|
|
|
want: "Resource(k1=v11)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{kv11, kv12},
|
|
|
|
|
want: "Resource(k1=v11)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{kv11, kv21},
|
|
|
|
|
want: "Resource(k1=v11,k2=v21)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{kv21, kv11},
|
|
|
|
|
want: "Resource(k1=v11,k2=v21)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{kv11, kv21, kv31},
|
|
|
|
|
want: "Resource(k1=v11,k2=v21,k3=v31)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{kv31, kv11, kv21},
|
|
|
|
|
want: "Resource(k1=v11,k2=v21,k3=v31)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{core.Key("A").String("a"), core.Key("B").String("b")},
|
|
|
|
|
want: "Resource(A=a,B=b)",
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{core.Key("A").String("a,B=b")},
|
|
|
|
|
want: `Resource(A=a\,B\=b)`,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{core.Key("A").String(`a,B\=b`)},
|
|
|
|
|
want: `Resource(A=a\,B\\\=b)`,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{core.Key("A=a,B").String(`b`)},
|
|
|
|
|
want: `Resource(A\=a\,B=b)`,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
kvs: []core.KeyValue{core.Key(`A=a\,B`).String(`b`)},
|
|
|
|
|
want: `Resource(A\=a\\\,B=b)`,
|
|
|
|
|
},
|
|
|
|
|
} {
|
|
|
|
|
if got := resource.New(test.kvs...).String(); got != test.want {
|
|
|
|
|
t.Errorf("Resource(%v).String() = %q, want %q", test.kvs, got, test.want)
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-03-09 09:30:42 -07:00
|
|
|
}
|