1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2025-01-22 03:38:42 +02:00
opentelemetry-go/handler_test.go

144 lines
3.3 KiB
Go
Raw Normal View History

2020-05-29 15:34:53 -07: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 otel
2020-05-29 15:34:53 -07:00
import (
"bytes"
2020-05-29 15:34:53 -07:00
"errors"
"fmt"
"log"
2020-05-29 15:34:53 -07:00
"testing"
"time"
"github.com/stretchr/testify/suite"
)
type errLogger []string
func (l *errLogger) Write(p []byte) (int, error) {
msg := bytes.TrimRight(p, "\n")
(*l) = append(*l, string(msg))
return len(msg), nil
}
func (l *errLogger) Reset() {
*l = errLogger([]string{})
}
2020-05-29 15:34:53 -07:00
func (l *errLogger) Got() []string {
return []string(*l)
2020-05-29 15:34:53 -07:00
}
type HandlerTestSuite struct {
suite.Suite
origHandler *loggingErrorHandler
errLogger *errLogger
2020-05-29 15:34:53 -07:00
}
func (s *HandlerTestSuite) SetupSuite() {
s.errLogger = new(errLogger)
s.origHandler = globalErrorHandler
globalErrorHandler = &loggingErrorHandler{
l: log.New(s.errLogger, "", 0),
}
2020-05-29 15:34:53 -07:00
}
func (s *HandlerTestSuite) TearDownSuite() {
globalErrorHandler = s.origHandler
2020-05-29 15:34:53 -07:00
}
func (s *HandlerTestSuite) SetupTest() {
s.errLogger.Reset()
2020-05-29 15:34:53 -07:00
}
2020-06-01 09:28:27 -07:00
func (s *HandlerTestSuite) TestGlobalHandler() {
errs := []string{"one", "two"}
GetErrorHandler().Handle(errors.New(errs[0]))
Handle(errors.New(errs[1]))
s.Assert().Equal(errs, s.errLogger.Got())
2020-05-29 15:34:53 -07:00
}
func (s *HandlerTestSuite) TestNoDropsOnDelegate() {
// max time to wait for goroutine to Handle an error.
pause := 10 * time.Millisecond
2020-05-29 15:34:53 -07:00
var sent int
err := errors.New("")
stop := make(chan struct{})
beat := make(chan struct{})
done := make(chan struct{})
// Wait for a error to be submitted from the following goroutine.
wait := func(d time.Duration) error {
timer := time.NewTimer(d)
select {
case <-timer.C:
// We are about to fail, stop the spawned goroutine.
stop <- struct{}{}
return fmt.Errorf("no errors sent in %v", d)
case <-beat:
2020-06-09 17:21:01 -07:00
// Allow the timer to be reclaimed by GC.
timer.Stop()
return nil
}
}
2020-05-29 15:34:53 -07:00
go func() {
2020-06-09 17:21:01 -07:00
// Slow down to speed up: do not overload the processor.
ticker := time.NewTicker(100 * time.Microsecond)
2020-05-29 15:34:53 -07:00
for {
select {
case <-stop:
2020-06-09 17:21:01 -07:00
ticker.Stop()
2020-05-29 15:34:53 -07:00
done <- struct{}{}
return
2020-06-09 17:21:01 -07:00
case <-ticker.C:
2020-05-29 15:34:53 -07:00
sent++
Handle(err)
}
select {
case beat <- struct{}{}:
default:
}
}
}()
// Wait for the spice to flow
s.Require().NoError(wait(pause), "starting error stream")
2020-05-29 15:34:53 -07:00
// Change to another Handler. We are testing this is loss-less.
newErrLogger := new(errLogger)
secondary := &loggingErrorHandler{
l: log.New(newErrLogger, "", 0),
}
SetErrorHandler(secondary)
2020-06-09 17:21:01 -07:00
s.Require().NoError(wait(pause), "switched to new Handler")
2020-05-29 15:34:53 -07:00
// Testing done, stop sending errors.
2020-05-29 15:34:53 -07:00
stop <- struct{}{}
// Ensure we do not lose any straglers.
<-done
got := append(s.errLogger.Got(), newErrLogger.Got()...)
s.Assert().Greater(len(got), 1, "at least 2 errors should have been sent")
s.Assert().Len(got, sent)
2020-05-29 15:34:53 -07:00
}
func TestHandlerTestSuite(t *testing.T) {
suite.Run(t, new(HandlerTestSuite))
}