mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-18 03:22:12 +02:00
115 lines
2.9 KiB
Go
115 lines
2.9 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package metric // import "go.opentelemetry.io/otel/sdk/metric"
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
"go.opentelemetry.io/otel/metric"
|
|
"go.opentelemetry.io/otel/sdk/metric/metricdata"
|
|
)
|
|
|
|
func TestManualReader(t *testing.T) {
|
|
suite.Run(t, &readerTestSuite{Factory: func(opts ...ReaderOption) Reader {
|
|
var mopts []ManualReaderOption
|
|
for _, o := range opts {
|
|
mopts = append(mopts, o)
|
|
}
|
|
return NewManualReader(mopts...)
|
|
}})
|
|
}
|
|
|
|
func BenchmarkManualReader(b *testing.B) {
|
|
b.Run("Collect", benchReaderCollectFunc(NewManualReader()))
|
|
}
|
|
|
|
var (
|
|
deltaTemporalitySelector = func(InstrumentKind) metricdata.Temporality { return metricdata.DeltaTemporality }
|
|
cumulativeTemporalitySelector = func(InstrumentKind) metricdata.Temporality { return metricdata.CumulativeTemporality }
|
|
)
|
|
|
|
func TestManualReaderTemporality(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
options []ManualReaderOption
|
|
// Currently only testing constant temporality. This should be expanded
|
|
// if we put more advanced selection in the SDK
|
|
wantTemporality metricdata.Temporality
|
|
}{
|
|
{
|
|
name: "default",
|
|
wantTemporality: metricdata.CumulativeTemporality,
|
|
},
|
|
{
|
|
name: "delta",
|
|
options: []ManualReaderOption{
|
|
WithTemporalitySelector(deltaTemporalitySelector),
|
|
},
|
|
wantTemporality: metricdata.DeltaTemporality,
|
|
},
|
|
{
|
|
name: "repeats overwrite",
|
|
options: []ManualReaderOption{
|
|
WithTemporalitySelector(deltaTemporalitySelector),
|
|
WithTemporalitySelector(cumulativeTemporalitySelector),
|
|
},
|
|
wantTemporality: metricdata.CumulativeTemporality,
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
var undefinedInstrument InstrumentKind
|
|
rdr := NewManualReader(tt.options...)
|
|
assert.Equal(t, tt.wantTemporality, rdr.temporality(undefinedInstrument))
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestManualReaderCollect(t *testing.T) {
|
|
expiredCtx, cancel := context.WithDeadline(context.Background(), time.Now().Add(-1))
|
|
defer cancel()
|
|
|
|
tests := []struct {
|
|
name string
|
|
ctx context.Context
|
|
expectedErr error
|
|
}{
|
|
{
|
|
name: "with a valid context",
|
|
ctx: context.Background(),
|
|
expectedErr: nil,
|
|
},
|
|
{
|
|
name: "with an expired context",
|
|
ctx: expiredCtx,
|
|
expectedErr: context.DeadlineExceeded,
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
rdr := NewManualReader()
|
|
mp := NewMeterProvider(WithReader(rdr))
|
|
meter := mp.Meter("test")
|
|
|
|
// Ensure the pipeline has a callback setup
|
|
testM, err := meter.Int64ObservableCounter("test")
|
|
assert.NoError(t, err)
|
|
_, err = meter.RegisterCallback(func(_ context.Context, o metric.Observer) error {
|
|
return nil
|
|
}, testM)
|
|
assert.NoError(t, err)
|
|
|
|
rm := &metricdata.ResourceMetrics{}
|
|
assert.Equal(t, tt.expectedErr, rdr.Collect(tt.ctx, rm))
|
|
})
|
|
}
|
|
}
|