2022-07-27 17:20:54 +00:00
|
|
|
package prefixed_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"regexp"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
2023-03-17 18:52:56 +00:00
|
|
|
prefixed "github.com/prysmaticlabs/prysm/v4/runtime/logging/logrus-prefixed-formatter"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/testing/require"
|
2022-07-27 17:20:54 +00:00
|
|
|
|
|
|
|
. "github.com/onsi/ginkgo"
|
|
|
|
. "github.com/onsi/gomega"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
var _ = Describe("Formatter", func() {
|
2023-03-17 18:52:56 +00:00
|
|
|
var formatter *prefixed.TextFormatter
|
2022-07-27 17:20:54 +00:00
|
|
|
var log *logrus.Logger
|
|
|
|
var output *LogOutput
|
|
|
|
|
|
|
|
BeforeEach(func() {
|
|
|
|
output = new(LogOutput)
|
2023-03-17 18:52:56 +00:00
|
|
|
formatter = new(prefixed.TextFormatter)
|
2022-07-27 17:20:54 +00:00
|
|
|
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) {
|
2023-03-17 18:52:56 +00:00
|
|
|
formatter := new(prefixed.TextFormatter)
|
2022-07-27 17:20:54 +00:00
|
|
|
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()))
|
|
|
|
}
|
2022-08-08 18:12:12 +00:00
|
|
|
|
|
|
|
func TestFormatter_EscapesControlCharacters(t *testing.T) {
|
2023-03-17 18:52:56 +00:00
|
|
|
formatter := new(prefixed.TextFormatter)
|
2022-08-08 18:12:12 +00:00
|
|
|
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())
|
|
|
|
}
|