mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-18 03:22:12 +02:00
dafe137bbe
Resolve #5225 The specification has [added a synchronous gauge instrument](https://github.com/open-telemetry/opentelemetry-specification/pull/3540). That instrument has now been [stabilized](https://github.com/open-telemetry/opentelemetry-specification/pull/4019), and that stabilization is included in the [next release](https://github.com/open-telemetry/opentelemetry-specification/pull/4034). This adds the new synchronous gauge instrument to the metric API and all implementation we publish. This change will be a breaking change for any SDK developer. The `embedded` package is updated to ensure our compatibility guarantees are meet. --------- Co-authored-by: David Ashpole <dashpole@google.com>
53 lines
1.3 KiB
Go
53 lines
1.3 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package metric // import "go.opentelemetry.io/otel/metric"
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestFloat64Configuration(t *testing.T) {
|
|
const (
|
|
token float64 = 43
|
|
desc = "Instrument description."
|
|
uBytes = "By"
|
|
)
|
|
|
|
run := func(got float64Config) func(*testing.T) {
|
|
return func(t *testing.T) {
|
|
assert.Equal(t, desc, got.Description(), "description")
|
|
assert.Equal(t, uBytes, got.Unit(), "unit")
|
|
}
|
|
}
|
|
|
|
t.Run("Float64Counter", run(
|
|
NewFloat64CounterConfig(WithDescription(desc), WithUnit(uBytes)),
|
|
))
|
|
|
|
t.Run("Float64UpDownCounter", run(
|
|
NewFloat64UpDownCounterConfig(WithDescription(desc), WithUnit(uBytes)),
|
|
))
|
|
|
|
t.Run("Float64Histogram", run(
|
|
NewFloat64HistogramConfig(WithDescription(desc), WithUnit(uBytes)),
|
|
))
|
|
|
|
t.Run("Float64Gauge", run(
|
|
NewFloat64GaugeConfig(WithDescription(desc), WithUnit(uBytes)),
|
|
))
|
|
}
|
|
|
|
type float64Config interface {
|
|
Description() string
|
|
Unit() string
|
|
}
|
|
|
|
func TestFloat64ExplicitBucketHistogramConfiguration(t *testing.T) {
|
|
bounds := []float64{0.1, 0.5, 1.0}
|
|
got := NewFloat64HistogramConfig(WithExplicitBucketBoundaries(bounds...))
|
|
assert.Equal(t, bounds, got.ExplicitBucketBoundaries(), "boundaries")
|
|
}
|