Files
fn-serverless/vendor/go.opencensus.io/exporter/jaeger/jaeger_test.go
jan grant 91e58afa55 The opencensus API changes between 0.6.0 and 0.9.0 (#980)
We get some useful features in later versions; update so as to not
pin downstream consumers (extensions) to an older version.
2018-05-09 14:55:00 +01:00

136 lines
3.4 KiB
Go

// Copyright 2018, OpenCensus 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 jaeger
import (
"fmt"
"reflect"
"testing"
"time"
gen "go.opencensus.io/exporter/jaeger/internal/gen-go/jaeger"
"go.opencensus.io/trace"
)
// TODO(jbd): Test export.
func Test_bytesToInt64(t *testing.T) {
type args struct {
}
tests := []struct {
buf []byte
want int64
}{
{
buf: []byte{255, 0, 0, 0, 0, 0, 0, 0},
want: -72057594037927936,
},
{
buf: []byte{0, 0, 0, 0, 0, 0, 0, 1},
want: 1,
},
{
buf: []byte{0, 0, 0, 0, 0, 0, 0, 0},
want: 0,
},
}
for _, tt := range tests {
t.Run(fmt.Sprintf("%d", tt.want), func(t *testing.T) {
if got := bytesToInt64(tt.buf); got != tt.want {
t.Errorf("bytesToInt64() = %v, want %v", got, tt.want)
}
})
}
}
func Test_spanDataToThrift(t *testing.T) {
now := time.Now()
answerValue := int64(42)
keyValue := "value"
resultValue := true
statusCodeValue := int64(2)
statusMessage := "error"
tests := []struct {
name string
data *trace.SpanData
want *gen.Span
}{
{
name: "no parent",
data: &trace.SpanData{
SpanContext: trace.SpanContext{
TraceID: trace.TraceID{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16},
SpanID: trace.SpanID{1, 2, 3, 4, 5, 6, 7, 8},
},
Name: "/foo",
StartTime: now,
EndTime: now,
Attributes: map[string]interface{}{
"key": keyValue,
},
Annotations: []trace.Annotation{
{
Time: now,
Message: statusMessage,
Attributes: map[string]interface{}{
"answer": answerValue,
},
},
{
Time: now,
Message: statusMessage,
Attributes: map[string]interface{}{
"result": resultValue,
},
},
},
Status: trace.Status{Code: trace.StatusCodeUnknown, Message: "error"},
},
want: &gen.Span{
TraceIdLow: 651345242494996240,
TraceIdHigh: 72623859790382856,
SpanId: 72623859790382856,
OperationName: "/foo",
StartTime: now.UnixNano() / 1000,
Duration: 0,
Tags: []*gen.Tag{
{Key: "key", VType: gen.TagType_STRING, VStr: &keyValue},
{Key: "status.code", VType: gen.TagType_LONG, VLong: &statusCodeValue},
{Key: "status.message", VType: gen.TagType_STRING, VStr: &statusMessage},
},
Logs: []*gen.Log{
{Timestamp: now.UnixNano() / 1000, Fields: []*gen.Tag{
{Key: "answer", VType: gen.TagType_LONG, VLong: &answerValue},
{Key: "message", VType: gen.TagType_STRING, VStr: &statusMessage},
}},
{Timestamp: now.UnixNano() / 1000, Fields: []*gen.Tag{
{Key: "result", VType: gen.TagType_BOOL, VBool: &resultValue},
{Key: "message", VType: gen.TagType_STRING, VStr: &statusMessage},
}},
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := spanDataToThrift(tt.data); !reflect.DeepEqual(got, tt.want) {
t.Errorf("spanDataToThrift() = %v, want %v", got, tt.want)
}
})
}
}