2022-03-22 10:33:13 -05:00
|
|
|
// Copyright The OpenTelemetry 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 global
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"go.opentelemetry.io/otel/metric"
|
2023-04-03 07:33:19 -07:00
|
|
|
"go.opentelemetry.io/otel/metric/embedded"
|
2023-03-29 08:05:07 -07:00
|
|
|
"go.opentelemetry.io/otel/metric/noop"
|
2022-03-22 10:33:13 -05:00
|
|
|
)
|
|
|
|
|
2023-04-18 07:16:06 -07:00
|
|
|
func testFloat64Race(interact func(float64), setDelegate func(metric.Meter)) {
|
2022-03-22 10:33:13 -05:00
|
|
|
finish := make(chan struct{})
|
|
|
|
go func() {
|
|
|
|
for {
|
2023-04-18 07:16:06 -07:00
|
|
|
interact(1)
|
2022-03-22 10:33:13 -05:00
|
|
|
select {
|
|
|
|
case <-finish:
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
2023-03-29 08:05:07 -07:00
|
|
|
setDelegate(noop.NewMeterProvider().Meter(""))
|
2022-03-22 10:33:13 -05:00
|
|
|
close(finish)
|
|
|
|
}
|
|
|
|
|
2023-04-18 07:16:06 -07:00
|
|
|
func testInt64Race(interact func(int64), setDelegate func(metric.Meter)) {
|
2022-03-22 10:33:13 -05:00
|
|
|
finish := make(chan struct{})
|
|
|
|
go func() {
|
|
|
|
for {
|
2023-04-18 07:16:06 -07:00
|
|
|
interact(1)
|
2022-03-22 10:33:13 -05:00
|
|
|
select {
|
|
|
|
case <-finish:
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
|
2023-03-29 08:05:07 -07:00
|
|
|
setDelegate(noop.NewMeterProvider().Meter(""))
|
2022-03-22 10:33:13 -05:00
|
|
|
close(finish)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestAsyncInstrumentSetDelegateRace(t *testing.T) {
|
|
|
|
// Float64 Instruments
|
|
|
|
t.Run("Float64", func(t *testing.T) {
|
|
|
|
t.Run("Counter", func(t *testing.T) {
|
|
|
|
delegate := &afCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(float64) { _ = delegate.Unwrap() }
|
2023-01-25 12:58:09 -08:00
|
|
|
testFloat64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("UpDownCounter", func(t *testing.T) {
|
|
|
|
delegate := &afUpDownCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(float64) { _ = delegate.Unwrap() }
|
2023-01-25 12:58:09 -08:00
|
|
|
testFloat64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Gauge", func(t *testing.T) {
|
|
|
|
delegate := &afGauge{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(float64) { _ = delegate.Unwrap() }
|
2023-01-25 12:58:09 -08:00
|
|
|
testFloat64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
// Int64 Instruments
|
|
|
|
|
|
|
|
t.Run("Int64", func(t *testing.T) {
|
|
|
|
t.Run("Counter", func(t *testing.T) {
|
|
|
|
delegate := &aiCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(int64) { _ = delegate.Unwrap() }
|
2023-01-25 12:58:09 -08:00
|
|
|
testInt64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("UpDownCounter", func(t *testing.T) {
|
|
|
|
delegate := &aiUpDownCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(int64) { _ = delegate.Unwrap() }
|
2023-01-25 12:58:09 -08:00
|
|
|
testInt64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Gauge", func(t *testing.T) {
|
|
|
|
delegate := &aiGauge{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(int64) { _ = delegate.Unwrap() }
|
2023-01-25 12:58:09 -08:00
|
|
|
testInt64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSyncInstrumentSetDelegateRace(t *testing.T) {
|
|
|
|
// Float64 Instruments
|
|
|
|
t.Run("Float64", func(t *testing.T) {
|
|
|
|
t.Run("Counter", func(t *testing.T) {
|
|
|
|
delegate := &sfCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(v float64) { delegate.Add(context.Background(), v) }
|
|
|
|
testFloat64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("UpDownCounter", func(t *testing.T) {
|
|
|
|
delegate := &sfUpDownCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(v float64) { delegate.Add(context.Background(), v) }
|
|
|
|
testFloat64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Histogram", func(t *testing.T) {
|
|
|
|
delegate := &sfHistogram{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(v float64) { delegate.Record(context.Background(), v) }
|
|
|
|
testFloat64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
// Int64 Instruments
|
|
|
|
|
|
|
|
t.Run("Int64", func(t *testing.T) {
|
|
|
|
t.Run("Counter", func(t *testing.T) {
|
|
|
|
delegate := &siCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(v int64) { delegate.Add(context.Background(), v) }
|
|
|
|
testInt64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("UpDownCounter", func(t *testing.T) {
|
|
|
|
delegate := &siUpDownCounter{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(v int64) { delegate.Add(context.Background(), v) }
|
|
|
|
testInt64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("Histogram", func(t *testing.T) {
|
|
|
|
delegate := &siHistogram{}
|
2023-04-18 07:16:06 -07:00
|
|
|
f := func(v int64) { delegate.Record(context.Background(), v) }
|
|
|
|
testInt64Race(f, delegate.setDelegate)
|
2022-03-22 10:33:13 -05:00
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
type testCountingFloatInstrument struct {
|
|
|
|
count int
|
|
|
|
|
2023-04-27 11:25:48 -07:00
|
|
|
metric.Float64Observable
|
2023-04-03 07:33:19 -07:00
|
|
|
embedded.Float64Counter
|
|
|
|
embedded.Float64UpDownCounter
|
|
|
|
embedded.Float64Histogram
|
|
|
|
embedded.Float64ObservableCounter
|
|
|
|
embedded.Float64ObservableUpDownCounter
|
|
|
|
embedded.Float64ObservableGauge
|
2022-03-22 10:33:13 -05:00
|
|
|
}
|
|
|
|
|
2023-01-25 12:58:09 -08:00
|
|
|
func (i *testCountingFloatInstrument) observe() {
|
2022-03-22 10:33:13 -05:00
|
|
|
i.count++
|
|
|
|
}
|
2023-04-27 11:25:48 -07:00
|
|
|
func (i *testCountingFloatInstrument) Add(context.Context, float64, ...metric.AddOption) {
|
2022-03-22 10:33:13 -05:00
|
|
|
i.count++
|
|
|
|
}
|
2023-04-27 11:25:48 -07:00
|
|
|
func (i *testCountingFloatInstrument) Record(context.Context, float64, ...metric.RecordOption) {
|
2022-03-22 10:33:13 -05:00
|
|
|
i.count++
|
|
|
|
}
|
|
|
|
|
|
|
|
type testCountingIntInstrument struct {
|
|
|
|
count int
|
|
|
|
|
2023-04-27 11:25:48 -07:00
|
|
|
metric.Int64Observable
|
2023-04-03 07:33:19 -07:00
|
|
|
embedded.Int64Counter
|
|
|
|
embedded.Int64UpDownCounter
|
|
|
|
embedded.Int64Histogram
|
|
|
|
embedded.Int64ObservableCounter
|
|
|
|
embedded.Int64ObservableUpDownCounter
|
|
|
|
embedded.Int64ObservableGauge
|
2022-03-22 10:33:13 -05:00
|
|
|
}
|
|
|
|
|
2023-01-25 12:58:09 -08:00
|
|
|
func (i *testCountingIntInstrument) observe() {
|
2022-03-22 10:33:13 -05:00
|
|
|
i.count++
|
|
|
|
}
|
2023-04-27 11:25:48 -07:00
|
|
|
func (i *testCountingIntInstrument) Add(context.Context, int64, ...metric.AddOption) {
|
2022-03-22 10:33:13 -05:00
|
|
|
i.count++
|
|
|
|
}
|
2023-04-27 11:25:48 -07:00
|
|
|
func (i *testCountingIntInstrument) Record(context.Context, int64, ...metric.RecordOption) {
|
2022-03-22 10:33:13 -05:00
|
|
|
i.count++
|
|
|
|
}
|