opentelemetry-collector/pdata/internal/generated_wrapper_exponenti...

157 lines
6.2 KiB
Go

// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
// Code generated by "internal/cmd/pdatagen/main.go". DO NOT EDIT.
// To regenerate this file run "make genpdata".
package internal
import (
"strconv"
"testing"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
gootlpmetrics "go.opentelemetry.io/proto/slim/otlp/metrics/v1"
"google.golang.org/protobuf/proto"
"go.opentelemetry.io/collector/featuregate"
otlpmetrics "go.opentelemetry.io/collector/pdata/internal/data/protogen/metrics/v1"
"go.opentelemetry.io/collector/pdata/internal/json"
)
func TestCopyOrigExponentialHistogramDataPoint_Buckets(t *testing.T) {
for name, src := range genTestEncodingValuesExponentialHistogramDataPoint_Buckets() {
for _, pooling := range []bool{true, false} {
t.Run(name+"/Pooling="+strconv.FormatBool(pooling), func(t *testing.T) {
prevPooling := UseProtoPooling.IsEnabled()
require.NoError(t, featuregate.GlobalRegistry().Set(UseProtoPooling.ID(), pooling))
defer func() {
require.NoError(t, featuregate.GlobalRegistry().Set(UseProtoPooling.ID(), prevPooling))
}()
dest := NewOrigExponentialHistogramDataPoint_Buckets()
CopyOrigExponentialHistogramDataPoint_Buckets(dest, src)
assert.Equal(t, src, dest)
CopyOrigExponentialHistogramDataPoint_Buckets(dest, dest)
assert.Equal(t, src, dest)
})
}
}
}
func TestMarshalAndUnmarshalJSONOrigExponentialHistogramDataPoint_BucketsUnknown(t *testing.T) {
iter := json.BorrowIterator([]byte(`{"unknown": "string"}`))
defer json.ReturnIterator(iter)
dest := NewOrigExponentialHistogramDataPoint_Buckets()
UnmarshalJSONOrigExponentialHistogramDataPoint_Buckets(dest, iter)
require.NoError(t, iter.Error())
assert.Equal(t, NewOrigExponentialHistogramDataPoint_Buckets(), dest)
}
func TestMarshalAndUnmarshalJSONOrigExponentialHistogramDataPoint_Buckets(t *testing.T) {
for name, src := range genTestEncodingValuesExponentialHistogramDataPoint_Buckets() {
for _, pooling := range []bool{true, false} {
t.Run(name+"/Pooling="+strconv.FormatBool(pooling), func(t *testing.T) {
prevPooling := UseProtoPooling.IsEnabled()
require.NoError(t, featuregate.GlobalRegistry().Set(UseProtoPooling.ID(), pooling))
defer func() {
require.NoError(t, featuregate.GlobalRegistry().Set(UseProtoPooling.ID(), prevPooling))
}()
stream := json.BorrowStream(nil)
defer json.ReturnStream(stream)
MarshalJSONOrigExponentialHistogramDataPoint_Buckets(src, stream)
require.NoError(t, stream.Error())
iter := json.BorrowIterator(stream.Buffer())
defer json.ReturnIterator(iter)
dest := NewOrigExponentialHistogramDataPoint_Buckets()
UnmarshalJSONOrigExponentialHistogramDataPoint_Buckets(dest, iter)
require.NoError(t, iter.Error())
assert.Equal(t, src, dest)
DeleteOrigExponentialHistogramDataPoint_Buckets(dest, true)
})
}
}
}
func TestMarshalAndUnmarshalProtoOrigExponentialHistogramDataPoint_BucketsFailing(t *testing.T) {
for name, buf := range genTestFailingUnmarshalProtoValuesExponentialHistogramDataPoint_Buckets() {
t.Run(name, func(t *testing.T) {
dest := NewOrigExponentialHistogramDataPoint_Buckets()
require.Error(t, UnmarshalProtoOrigExponentialHistogramDataPoint_Buckets(dest, buf))
})
}
}
func TestMarshalAndUnmarshalProtoOrigExponentialHistogramDataPoint_BucketsUnknown(t *testing.T) {
dest := NewOrigExponentialHistogramDataPoint_Buckets()
// message Test { required int64 field = 1313; } encoding { "field": "1234" }
require.NoError(t, UnmarshalProtoOrigExponentialHistogramDataPoint_Buckets(dest, []byte{0x88, 0x52, 0xD2, 0x09}))
assert.Equal(t, NewOrigExponentialHistogramDataPoint_Buckets(), dest)
}
func TestMarshalAndUnmarshalProtoOrigExponentialHistogramDataPoint_Buckets(t *testing.T) {
for name, src := range genTestEncodingValuesExponentialHistogramDataPoint_Buckets() {
for _, pooling := range []bool{true, false} {
t.Run(name+"/Pooling="+strconv.FormatBool(pooling), func(t *testing.T) {
prevPooling := UseProtoPooling.IsEnabled()
require.NoError(t, featuregate.GlobalRegistry().Set(UseProtoPooling.ID(), pooling))
defer func() {
require.NoError(t, featuregate.GlobalRegistry().Set(UseProtoPooling.ID(), prevPooling))
}()
buf := make([]byte, SizeProtoOrigExponentialHistogramDataPoint_Buckets(src))
gotSize := MarshalProtoOrigExponentialHistogramDataPoint_Buckets(src, buf)
assert.Equal(t, len(buf), gotSize)
dest := NewOrigExponentialHistogramDataPoint_Buckets()
require.NoError(t, UnmarshalProtoOrigExponentialHistogramDataPoint_Buckets(dest, buf))
assert.Equal(t, src, dest)
DeleteOrigExponentialHistogramDataPoint_Buckets(dest, true)
})
}
}
}
func TestMarshalAndUnmarshalProtoViaProtobufExponentialHistogramDataPoint_Buckets(t *testing.T) {
for name, src := range genTestEncodingValuesExponentialHistogramDataPoint_Buckets() {
t.Run(name, func(t *testing.T) {
buf := make([]byte, SizeProtoOrigExponentialHistogramDataPoint_Buckets(src))
gotSize := MarshalProtoOrigExponentialHistogramDataPoint_Buckets(src, buf)
assert.Equal(t, len(buf), gotSize)
goDest := &gootlpmetrics.ExponentialHistogramDataPoint_Buckets{}
require.NoError(t, proto.Unmarshal(buf, goDest))
goBuf, err := proto.Marshal(goDest)
require.NoError(t, err)
dest := NewOrigExponentialHistogramDataPoint_Buckets()
require.NoError(t, UnmarshalProtoOrigExponentialHistogramDataPoint_Buckets(dest, goBuf))
assert.Equal(t, src, dest)
})
}
}
func genTestFailingUnmarshalProtoValuesExponentialHistogramDataPoint_Buckets() map[string][]byte {
return map[string][]byte{
"invalid_field": {0x02},
"Offset/wrong_wire_type": {0xc},
"Offset/missing_value": {0x8},
"BucketCounts/wrong_wire_type": {0x14},
"BucketCounts/missing_value": {0x12},
}
}
func genTestEncodingValuesExponentialHistogramDataPoint_Buckets() map[string]*otlpmetrics.ExponentialHistogramDataPoint_Buckets {
return map[string]*otlpmetrics.ExponentialHistogramDataPoint_Buckets{
"empty": NewOrigExponentialHistogramDataPoint_Buckets(),
"Offset/test": {Offset: int32(13)},
"BucketCounts/default_and_test": {BucketCounts: []uint64{uint64(0), uint64(13)}},
}
}