1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2025-11-25 22:41:46 +02:00

Remove the oterror package (#1026)

* Break up the oterror package

* Update use of ErrorHandler in project

* Update handler naming and comments
This commit is contained in:
Tyler Yahn
2020-08-05 10:31:42 -07:00
committed by GitHub
parent 67408889d4
commit 3780b80214
10 changed files with 50 additions and 97 deletions

View File

@@ -20,35 +20,35 @@ import (
"sync" "sync"
"sync/atomic" "sync/atomic"
"go.opentelemetry.io/otel/api/oterror" "go.opentelemetry.io/otel"
) )
var ( var (
// globalHandler provides an oterror.Handler that can be used throughout // globalErrorHandler provides an ErrorHandler that can be used
// an OpenTelemetry instrumented project. When a user specified Handler // throughout an OpenTelemetry instrumented project. When a user
// is registered (`SetHandler`) all calls to `Handle` will be delegated // specified ErrorHandler is registered (`SetErrorHandler`) all calls to
// to the registered Handler. // `Handle` and will be delegated to the registered ErrorHandler.
globalHandler = &handler{ globalErrorHandler = &loggingErrorHandler{
l: log.New(os.Stderr, "", log.LstdFlags), l: log.New(os.Stderr, "", log.LstdFlags),
} }
// delegateHanderOnce ensures that a user provided Handler is only ever // delegateErrorHandlerOnce ensures that a user provided ErrorHandler is
// registered once. // only ever registered once.
delegateHanderOnce sync.Once delegateErrorHandlerOnce sync.Once
// Ensure the handler implements oterror.Handle at build time. // Comiple time check that loggingErrorHandler implements ErrorHandler.
_ oterror.Handler = (*handler)(nil) _ otel.ErrorHandler = (*loggingErrorHandler)(nil)
) )
// handler logs all errors to STDERR. // loggingErrorHandler logs all errors to STDERR.
type handler struct { type loggingErrorHandler struct {
delegate atomic.Value delegate atomic.Value
l *log.Logger l *log.Logger
} }
// setDelegate sets the handler delegate if one is not already set. // setDelegate sets the ErrorHandler delegate if one is not already set.
func (h *handler) setDelegate(d oterror.Handler) { func (h *loggingErrorHandler) setDelegate(d otel.ErrorHandler) {
if h.delegate.Load() != nil { if h.delegate.Load() != nil {
// Delegate already registered // Delegate already registered
return return
@@ -56,37 +56,36 @@ func (h *handler) setDelegate(d oterror.Handler) {
h.delegate.Store(d) h.delegate.Store(d)
} }
// Handle implements oterror.Handler. // Handle implements otel.ErrorHandler.
func (h *handler) Handle(err error) { func (h *loggingErrorHandler) Handle(err error) {
if d := h.delegate.Load(); d != nil { if d := h.delegate.Load(); d != nil {
d.(oterror.Handler).Handle(err) d.(otel.ErrorHandler).Handle(err)
return return
} }
h.l.Print(err) h.l.Print(err)
} }
// Handler returns the global Handler instance. If no Handler instance has // ErrorHandler returns the global ErrorHandler instance. If no ErrorHandler
// be explicitly set yet, a default Handler is returned that logs to STDERR // instance has been set (`SetErrorHandler`), the default ErrorHandler which
// until an Handler is set (all functionality is delegated to the set // logs errors to STDERR is returned.
// Handler once it is set). func ErrorHandler() otel.ErrorHandler {
func Handler() oterror.Handler { return globalErrorHandler
return globalHandler
} }
// SetHandler sets the global Handler to be h. // SetErrorHandler sets the global ErrorHandler to be h.
func SetHandler(h oterror.Handler) { func SetErrorHandler(h otel.ErrorHandler) {
delegateHanderOnce.Do(func() { delegateErrorHandlerOnce.Do(func() {
current := Handler() current := ErrorHandler()
if current == h { if current == h {
return return
} }
if internalHandler, ok := current.(*handler); ok { if internalHandler, ok := current.(*loggingErrorHandler); ok {
internalHandler.setDelegate(h) internalHandler.setDelegate(h)
} }
}) })
} }
// Handle is a convience function for Handler().Handle(err) // Handle is a convience function for ErrorHandler().Handle(err)
func Handle(err error) { func Handle(err error) {
globalHandler.Handle(err) ErrorHandler().Handle(err)
} }

View File

@@ -44,20 +44,20 @@ func (l *errLogger) Got() []string {
type HandlerTestSuite struct { type HandlerTestSuite struct {
suite.Suite suite.Suite
origHandler *handler origHandler *loggingErrorHandler
errLogger *errLogger errLogger *errLogger
} }
func (s *HandlerTestSuite) SetupSuite() { func (s *HandlerTestSuite) SetupSuite() {
s.errLogger = new(errLogger) s.errLogger = new(errLogger)
s.origHandler = globalHandler s.origHandler = globalErrorHandler
globalHandler = &handler{ globalErrorHandler = &loggingErrorHandler{
l: log.New(s.errLogger, "", 0), l: log.New(s.errLogger, "", 0),
} }
} }
func (s *HandlerTestSuite) TearDownSuite() { func (s *HandlerTestSuite) TearDownSuite() {
globalHandler = s.origHandler globalErrorHandler = s.origHandler
} }
func (s *HandlerTestSuite) SetupTest() { func (s *HandlerTestSuite) SetupTest() {
@@ -66,7 +66,7 @@ func (s *HandlerTestSuite) SetupTest() {
func (s *HandlerTestSuite) TestGlobalHandler() { func (s *HandlerTestSuite) TestGlobalHandler() {
errs := []string{"one", "two"} errs := []string{"one", "two"}
Handler().Handle(errors.New(errs[0])) ErrorHandler().Handle(errors.New(errs[0]))
Handle(errors.New(errs[1])) Handle(errors.New(errs[1]))
s.Assert().Equal(errs, s.errLogger.Got()) s.Assert().Equal(errs, s.errLogger.Got())
} }
@@ -122,10 +122,10 @@ func (s *HandlerTestSuite) TestNoDropsOnDelegate() {
// Change to another Handler. We are testing this is loss-less. // Change to another Handler. We are testing this is loss-less.
newErrLogger := new(errLogger) newErrLogger := new(errLogger)
secondary := &handler{ secondary := &loggingErrorHandler{
l: log.New(newErrLogger, "", 0), l: log.New(newErrLogger, "", 0),
} }
SetHandler(secondary) SetErrorHandler(secondary)
s.Require().NoError(wait(pause), "switched to new Handler") s.Require().NoError(wait(pause), "switched to new Handler")
// Testing done, stop sending errors. // Testing done, stop sending errors.

View File

@@ -22,7 +22,6 @@ import (
"go.opentelemetry.io/otel/api/kv" "go.opentelemetry.io/otel/api/kv"
"go.opentelemetry.io/otel/api/metric" "go.opentelemetry.io/otel/api/metric"
"go.opentelemetry.io/otel/api/oterror"
"go.opentelemetry.io/otel/api/unit" "go.opentelemetry.io/otel/api/unit"
mockTest "go.opentelemetry.io/otel/internal/metric" mockTest "go.opentelemetry.io/otel/internal/metric"
@@ -392,7 +391,7 @@ func TestWrappedInstrumentError(t *testing.T) {
valuerecorder, err := meter.NewInt64ValueRecorder("test.valuerecorder") valuerecorder, err := meter.NewInt64ValueRecorder("test.valuerecorder")
require.Equal(t, err, oterror.ErrSDKReturnedNilImpl) require.Equal(t, err, metric.ErrSDKReturnedNilImpl)
require.NotNil(t, valuerecorder.SyncImpl()) require.NotNil(t, valuerecorder.SyncImpl())
observer, err := meter.NewInt64ValueObserver("test.observer", func(_ context.Context, result metric.Int64ObserverResult) {}) observer, err := meter.NewInt64ValueObserver("test.observer", func(_ context.Context, result metric.Int64ObserverResult) {})

View File

@@ -16,11 +16,14 @@ package metric
import ( import (
"context" "context"
"errors"
"go.opentelemetry.io/otel/api/kv" "go.opentelemetry.io/otel/api/kv"
"go.opentelemetry.io/otel/api/oterror"
) )
// ErrSDKReturnedNilImpl is returned when a new `MeterImpl` returns nil.
var ErrSDKReturnedNilImpl = errors.New("SDK returned a nil implementation")
// Measurement is used for reporting a synchronous batch of metric // Measurement is used for reporting a synchronous batch of metric
// values. Instances of this type should be created by synchronous // values. Instances of this type should be created by synchronous
// instruments (e.g., Int64Counter.Measurement()). // instruments (e.g., Int64Counter.Measurement()).
@@ -110,7 +113,7 @@ func (h syncBoundInstrument) Unbind() {
func checkNewAsync(instrument AsyncImpl, err error) (asyncInstrument, error) { func checkNewAsync(instrument AsyncImpl, err error) (asyncInstrument, error) {
if instrument == nil { if instrument == nil {
if err == nil { if err == nil {
err = oterror.ErrSDKReturnedNilImpl err = ErrSDKReturnedNilImpl
} }
instrument = NoopAsync{} instrument = NoopAsync{}
} }
@@ -125,7 +128,7 @@ func checkNewAsync(instrument AsyncImpl, err error) (asyncInstrument, error) {
func checkNewSync(instrument SyncImpl, err error) (syncInstrument, error) { func checkNewSync(instrument SyncImpl, err error) (syncInstrument, error) {
if instrument == nil { if instrument == nil {
if err == nil { if err == nil {
err = oterror.ErrSDKReturnedNilImpl err = ErrSDKReturnedNilImpl
} }
// Note: an alternate behavior would be to synthesize a new name // Note: an alternate behavior would be to synthesize a new name
// or group all duplicately-named instruments of a certain type // or group all duplicately-named instruments of a certain type

View File

@@ -1,26 +0,0 @@
// 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.
/*
* The oterror package provides unified error interactions in OpenTelemetry.
* This includes providing standardized errors common to OpenTelemetry (APIs,
* SDKs, and exporters). Additionally it provides an API for unified error
* handling in OpenTelemetry.
*
* The unified error handling interface is used for any error that
* OpenTelemetry component are not able to remediate on their own, instead
* handling them in a uniform and user-defined way.
*/
package oterror

View File

@@ -1,22 +0,0 @@
// 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 oterror
import "errors"
var (
// ErrSDKReturnedNilImpl is returned when a new `MeterImpl` returns nil.
ErrSDKReturnedNilImpl = errors.New("SDK returned a nil implementation")
)

View File

@@ -12,10 +12,10 @@
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
package oterror package otel
// Handler handles irremediable events. // ErrorHandler handles irremediable events.
type Handler interface { type ErrorHandler interface {
// Handle handles any error deemed irremediable by an OpenTelemetry // Handle handles any error deemed irremediable by an OpenTelemetry
// component. // component.
Handle(error) Handle(error)

View File

@@ -63,7 +63,7 @@ var testHandler *handler
func init() { func init() {
testHandler = new(handler) testHandler = new(handler)
global.SetHandler(testHandler) global.SetErrorHandler(testHandler)
} }
type testExporter struct { type testExporter struct {

View File

@@ -67,7 +67,7 @@ var testHandler *handler
func init() { func init() {
testHandler = new(handler) testHandler = new(handler)
global.SetHandler(testHandler) global.SetErrorHandler(testHandler)
} }
type correctnessProcessor struct { type correctnessProcessor struct {

View File

@@ -52,7 +52,7 @@ func init() {
tid, _ = apitrace.IDFromHex("01020304050607080102040810203040") tid, _ = apitrace.IDFromHex("01020304050607080102040810203040")
sid, _ = apitrace.SpanIDFromHex("0102040810203040") sid, _ = apitrace.SpanIDFromHex("0102040810203040")
global.SetHandler(new(discardHandler)) global.SetErrorHandler(new(discardHandler))
} }
func TestTracerFollowsExpectedAPIBehaviour(t *testing.T) { func TestTracerFollowsExpectedAPIBehaviour(t *testing.T) {