2019-12-27 11:55:15 -03:00
|
|
|
package logext
|
|
|
|
|
|
|
|
import (
|
2021-07-23 08:09:29 -03:00
|
|
|
"bytes"
|
2022-09-11 15:32:23 -03:00
|
|
|
"io"
|
2021-07-23 08:09:29 -03:00
|
|
|
"os"
|
|
|
|
"strconv"
|
2019-12-27 11:55:15 -03:00
|
|
|
"testing"
|
|
|
|
|
2022-06-21 21:11:15 -03:00
|
|
|
"github.com/caarlos0/log"
|
2022-07-04 16:12:24 -03:00
|
|
|
"github.com/charmbracelet/lipgloss"
|
2021-07-23 08:09:29 -03:00
|
|
|
"github.com/goreleaser/goreleaser/internal/golden"
|
2022-07-04 16:12:24 -03:00
|
|
|
"github.com/muesli/termenv"
|
2019-12-27 11:55:15 -03:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestWriter(t *testing.T) {
|
2022-07-04 16:12:24 -03:00
|
|
|
lipgloss.SetColorProfile(termenv.Ascii)
|
|
|
|
|
2021-07-23 08:09:29 -03:00
|
|
|
t.Run("info", func(t *testing.T) {
|
|
|
|
for _, out := range []Output{Info, Error} {
|
|
|
|
t.Run(strconv.Itoa(int(out)), func(t *testing.T) {
|
|
|
|
t.Cleanup(func() {
|
2022-06-21 21:11:15 -03:00
|
|
|
log.Log = log.New(os.Stderr)
|
2021-07-23 08:09:29 -03:00
|
|
|
})
|
|
|
|
var b bytes.Buffer
|
2022-06-21 21:11:15 -03:00
|
|
|
log.Log = log.New(&b)
|
2022-09-11 15:32:23 -03:00
|
|
|
l, err := io.WriteString(NewWriter(log.Fields{"foo": "bar"}, out), "foo\nbar\n")
|
2021-07-23 08:09:29 -03:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 8, l)
|
|
|
|
require.Empty(t, b.String())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("debug", func(t *testing.T) {
|
|
|
|
for _, out := range []Output{Info, Error} {
|
|
|
|
t.Run(strconv.Itoa(int(out)), func(t *testing.T) {
|
|
|
|
t.Cleanup(func() {
|
2022-06-21 21:11:15 -03:00
|
|
|
log.Log = log.New(os.Stderr)
|
2021-07-23 08:09:29 -03:00
|
|
|
})
|
|
|
|
var b bytes.Buffer
|
2022-06-21 21:11:15 -03:00
|
|
|
log.Log = log.New(&b)
|
|
|
|
log.SetLevel(log.DebugLevel)
|
2022-09-11 15:32:23 -03:00
|
|
|
l, err := io.WriteString(NewWriter(log.Fields{"foo": "bar"}, out), "foo\nbar\n")
|
2021-07-23 08:09:29 -03:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, 8, l)
|
|
|
|
golden.RequireEqualTxt(t, b.Bytes())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
2019-12-27 11:55:15 -03:00
|
|
|
}
|