mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-11 12:10:05 +00:00
d17996f8b0
* Update V3 from V4 * Fix build v3 -> v4 * Update ssz * Update beacon_chain.pb.go * Fix formatter import * Update update-mockgen.sh comment to v4 * Fix conflicts. Pass build and tests * Fix test
86 lines
2.2 KiB
Go
86 lines
2.2 KiB
Go
package prefixed_test
|
|
|
|
import (
|
|
"fmt"
|
|
"regexp"
|
|
"testing"
|
|
|
|
"github.com/pkg/errors"
|
|
prefixed "github.com/prysmaticlabs/prysm/v4/runtime/logging/logrus-prefixed-formatter"
|
|
"github.com/prysmaticlabs/prysm/v4/testing/require"
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
var _ = Describe("Formatter", func() {
|
|
var formatter *prefixed.TextFormatter
|
|
var log *logrus.Logger
|
|
var output *LogOutput
|
|
|
|
BeforeEach(func() {
|
|
output = new(LogOutput)
|
|
formatter = new(prefixed.TextFormatter)
|
|
log = logrus.New()
|
|
log.Out = output
|
|
log.Formatter = formatter
|
|
log.Level = logrus.DebugLevel
|
|
})
|
|
|
|
Describe("logfmt output", func() {
|
|
It("should output simple message", func() {
|
|
formatter.DisableTimestamp = true
|
|
log.Debug("test")
|
|
Ω(output.GetValue()).Should(Equal("level=debug msg=test\n"))
|
|
})
|
|
|
|
It("should output message with additional field", func() {
|
|
formatter.DisableTimestamp = true
|
|
log.WithFields(logrus.Fields{"animal": "walrus"}).Debug("test")
|
|
Ω(output.GetValue()).Should(Equal("level=debug msg=test animal=walrus\n"))
|
|
})
|
|
})
|
|
|
|
Describe("Formatted output", func() {
|
|
It("should output formatted message", func() {
|
|
formatter.DisableTimestamp = true
|
|
formatter.ForceFormatting = true
|
|
log.Debug("test")
|
|
Ω(output.GetValue()).Should(Equal("DEBUG test\n"))
|
|
})
|
|
})
|
|
|
|
Describe("Theming support", func() {
|
|
|
|
})
|
|
})
|
|
|
|
func TestFormatter_SuppressErrorStackTraces(t *testing.T) {
|
|
formatter := new(prefixed.TextFormatter)
|
|
formatter.ForceFormatting = true
|
|
log := logrus.New()
|
|
log.Formatter = formatter
|
|
output := new(LogOutput)
|
|
log.Out = output
|
|
|
|
errFn := func() error {
|
|
return errors.New("inner")
|
|
}
|
|
|
|
log.WithError(errors.Wrap(errFn(), "outer")).Error("test")
|
|
require.Equal(t, true, regexp.MustCompile(`test error=outer: inner\n\s*$`).MatchString(output.GetValue()), fmt.Sprintf("wrong log output: %s", output.GetValue()))
|
|
}
|
|
|
|
func TestFormatter_EscapesControlCharacters(t *testing.T) {
|
|
formatter := new(prefixed.TextFormatter)
|
|
formatter.ForceFormatting = true
|
|
log := logrus.New()
|
|
log.Formatter = formatter
|
|
output := new(LogOutput)
|
|
log.Out = output
|
|
|
|
log.WithField("test", "foo\nbar").Error("testing things")
|
|
require.Equal(t, "[0000] ERROR testing things test=foobar"+"\n", output.GetValue())
|
|
}
|