$31 GRAYBYTE WORDPRESS FILE MANAGER $96

SERVER : in-mum-web1330.main-hosting.eu #1 SMP Mon Feb 10 22:45:17 UTC 2025
SERVER IP : 88.222.222.221 | ADMIN IP 216.73.216.215
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/go/pkg/mod/go.opentelemetry.io/otel@v1.14.0/

HOME
Current File : /opt/go/pkg/mod/go.opentelemetry.io/otel@v1.14.0//handler_test.go
// 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 otel

import (
	"bytes"
	"errors"
	"io"
	"log"
	"os"
	"testing"

	"github.com/stretchr/testify/suite"
)

type testErrCatcher []string

func (l *testErrCatcher) Write(p []byte) (int, error) {
	msg := bytes.TrimRight(p, "\n")
	(*l) = append(*l, string(msg))
	return len(msg), nil
}

func (l *testErrCatcher) Reset() {
	*l = testErrCatcher([]string{})
}

func (l *testErrCatcher) Got() []string {
	return []string(*l)
}

func causeErr(text string) {
	Handle(errors.New(text))
}

type HandlerTestSuite struct {
	suite.Suite

	origHandler ErrorHandler
	errCatcher  *testErrCatcher
}

func (s *HandlerTestSuite) SetupSuite() {
	s.errCatcher = new(testErrCatcher)
	s.origHandler = globalErrorHandler.getDelegate()

	globalErrorHandler.setDelegate(&errLogger{l: log.New(s.errCatcher, "", 0)})
}

func (s *HandlerTestSuite) TearDownSuite() {
	globalErrorHandler.setDelegate(s.origHandler)
}

func (s *HandlerTestSuite) SetupTest() {
	s.errCatcher.Reset()
}

func (s *HandlerTestSuite) TearDownTest() {
	globalErrorHandler.setDelegate(&errLogger{l: log.New(s.errCatcher, "", 0)})
}

func (s *HandlerTestSuite) TestGlobalHandler() {
	errs := []string{"one", "two"}
	GetErrorHandler().Handle(errors.New(errs[0]))
	Handle(errors.New(errs[1]))
	s.Assert().Equal(errs, s.errCatcher.Got())
}

func (s *HandlerTestSuite) TestDelegatedHandler() {
	eh := GetErrorHandler()

	newErrLogger := new(testErrCatcher)
	SetErrorHandler(&errLogger{l: log.New(newErrLogger, "", 0)})

	errs := []string{"TestDelegatedHandler"}
	eh.Handle(errors.New(errs[0]))
	s.Assert().Equal(errs, newErrLogger.Got())
}

func (s *HandlerTestSuite) TestNoDropsOnDelegate() {
	causeErr("")
	s.Require().Len(s.errCatcher.Got(), 1)

	// Change to another Handler. We are testing this is loss-less.
	newErrLogger := new(testErrCatcher)
	secondary := &errLogger{
		l: log.New(newErrLogger, "", 0),
	}
	SetErrorHandler(secondary)

	causeErr("")
	s.Assert().Len(s.errCatcher.Got(), 1, "original Handler used after delegation")
	s.Assert().Len(newErrLogger.Got(), 1, "new Handler not used after delegation")
}

func (s *HandlerTestSuite) TestAllowMultipleSets() {
	notUsed := new(testErrCatcher)

	secondary := &errLogger{l: log.New(notUsed, "", 0)}
	SetErrorHandler(secondary)
	s.Require().Same(GetErrorHandler(), globalErrorHandler, "set changed globalErrorHandler")
	s.Require().Same(globalErrorHandler.getDelegate(), secondary, "new Handler not set")

	tertiary := &errLogger{l: log.New(notUsed, "", 0)}
	SetErrorHandler(tertiary)
	s.Require().Same(GetErrorHandler(), globalErrorHandler, "set changed globalErrorHandler")
	s.Assert().Same(globalErrorHandler.getDelegate(), tertiary, "user Handler not overridden")
}

func TestHandlerTestSuite(t *testing.T) {
	suite.Run(t, new(HandlerTestSuite))
}

func TestHandlerRace(t *testing.T) {
	go SetErrorHandler(&errLogger{log.New(os.Stderr, "", 0)})
	go Handle(errors.New("error"))
}

func BenchmarkErrorHandler(b *testing.B) {
	primary := &errLogger{l: log.New(io.Discard, "", 0)}
	secondary := &errLogger{l: log.New(io.Discard, "", 0)}
	tertiary := &errLogger{l: log.New(io.Discard, "", 0)}

	globalErrorHandler.setDelegate(primary)

	err := errors.New("benchmark error handler")

	b.ReportAllocs()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		GetErrorHandler().Handle(err)
		Handle(err)

		SetErrorHandler(secondary)
		GetErrorHandler().Handle(err)
		Handle(err)

		SetErrorHandler(tertiary)
		GetErrorHandler().Handle(err)
		Handle(err)

		globalErrorHandler.setDelegate(primary)
	}

	reset()
}

var eh ErrorHandler

func BenchmarkGetDefaultErrorHandler(b *testing.B) {
	b.ReportAllocs()
	for i := 0; i < b.N; i++ {
		eh = GetErrorHandler()
	}
}

func BenchmarkGetDelegatedErrorHandler(b *testing.B) {
	SetErrorHandler(&errLogger{l: log.New(io.Discard, "", 0)})

	b.ReportAllocs()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		eh = GetErrorHandler()
	}

	reset()
}

func BenchmarkDefaultErrorHandlerHandle(b *testing.B) {
	globalErrorHandler.setDelegate(
		&errLogger{l: log.New(io.Discard, "", 0)},
	)

	eh := GetErrorHandler()
	err := errors.New("benchmark default error handler handle")

	b.ReportAllocs()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		eh.Handle(err)
	}

	reset()
}

func BenchmarkDelegatedErrorHandlerHandle(b *testing.B) {
	eh := GetErrorHandler()
	SetErrorHandler(&errLogger{l: log.New(io.Discard, "", 0)})
	err := errors.New("benchmark delegated error handler handle")

	b.ReportAllocs()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		eh.Handle(err)
	}

	reset()
}

func BenchmarkSetErrorHandlerDelegation(b *testing.B) {
	alt := &errLogger{l: log.New(io.Discard, "", 0)}

	b.ReportAllocs()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		SetErrorHandler(alt)

		reset()
	}
}

func reset() {
	globalErrorHandler = defaultErrorHandler()
}

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
25 Jan 2024 4.43 PM
root / root
0755
.github
--
25 Jan 2024 4.43 PM
root / root
0555
attribute
--
25 Jan 2024 4.43 PM
root / root
0555
baggage
--
25 Jan 2024 4.43 PM
root / root
0555
codes
--
25 Jan 2024 4.43 PM
root / root
0555
exporters
--
25 Jan 2024 4.43 PM
root / root
0555
internal
--
25 Jan 2024 4.43 PM
root / root
0555
propagation
--
25 Jan 2024 4.43 PM
root / root
0555
semconv
--
25 Jan 2024 4.43 PM
root / root
0555
website_docs
--
25 Jan 2024 4.43 PM
root / root
0555
.gitattributes
0.087 KB
25 Jan 2024 4.43 PM
root / root
0444
.gitignore
0.32 KB
25 Jan 2024 4.43 PM
root / root
0444
.gitmodules
0.144 KB
25 Jan 2024 4.43 PM
root / root
0444
.golangci.yml
9.197 KB
25 Jan 2024 4.43 PM
root / root
0444
.lycheeignore
0.291 KB
25 Jan 2024 4.43 PM
root / root
0444
.markdownlint.yaml
0.302 KB
25 Jan 2024 4.43 PM
root / root
0444
CHANGELOG.md
159.072 KB
25 Jan 2024 4.43 PM
root / root
0444
CODEOWNERS
0.529 KB
25 Jan 2024 4.43 PM
root / root
0444
CONTRIBUTING.md
15.818 KB
25 Jan 2024 4.43 PM
root / root
0444
LICENSE
11.091 KB
25 Jan 2024 4.43 PM
root / root
0444
Makefile
7.625 KB
25 Jan 2024 4.43 PM
root / root
0444
README.md
5.29 KB
25 Jan 2024 4.43 PM
root / root
0444
RELEASING.md
4.998 KB
25 Jan 2024 4.43 PM
root / root
0444
VERSIONING.md
10.73 KB
25 Jan 2024 4.43 PM
root / root
0444
doc.go
1.465 KB
25 Jan 2024 4.43 PM
root / root
0444
error_handler.go
1.365 KB
25 Jan 2024 4.43 PM
root / root
0444
get_main_pkgs.sh
1.217 KB
25 Jan 2024 4.43 PM
root / root
0444
go.mod
0.415 KB
25 Jan 2024 4.43 PM
root / root
0444
go.sum
2.052 KB
25 Jan 2024 4.43 PM
root / root
0444
handler.go
2.969 KB
25 Jan 2024 4.43 PM
root / root
0444
handler_test.go
5.238 KB
25 Jan 2024 4.43 PM
root / root
0444
internal_logging.go
0.847 KB
25 Jan 2024 4.43 PM
root / root
0444
internal_logging_test.go
0.806 KB
25 Jan 2024 4.43 PM
root / root
0444
propagation.go
1.128 KB
25 Jan 2024 4.43 PM
root / root
0444
trace.go
1.58 KB
25 Jan 2024 4.43 PM
root / root
0444
trace_test.go
1.127 KB
25 Jan 2024 4.43 PM
root / root
0444
verify_examples.sh
2.325 KB
25 Jan 2024 4.43 PM
root / root
0444
version.go
0.741 KB
25 Jan 2024 4.43 PM
root / root
0444
version_test.go
1.078 KB
25 Jan 2024 4.43 PM
root / root
0444
versions.yaml
2.416 KB
25 Jan 2024 4.43 PM
root / root
0444

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF