2018-04-22 21:40:03 -03:00
|
|
|
package output_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
2023-03-09 02:34:52 +01:00
|
|
|
"errors"
|
2018-04-22 21:40:03 -03:00
|
|
|
"fmt"
|
2019-04-21 16:55:47 -03:00
|
|
|
"io"
|
2018-04-22 21:40:03 -03:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2023-04-06 11:18:41 +01:00
|
|
|
"github.com/stretchr/testify/require"
|
2021-01-07 11:48:33 -03:00
|
|
|
|
2023-04-06 12:07:57 +01:00
|
|
|
"github.com/go-task/task/v3/internal/orderedmap"
|
2021-01-07 11:48:33 -03:00
|
|
|
"github.com/go-task/task/v3/internal/output"
|
2022-12-19 01:06:09 +00:00
|
|
|
"github.com/go-task/task/v3/internal/templater"
|
|
|
|
"github.com/go-task/task/v3/taskfile"
|
2018-04-22 21:40:03 -03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestInterleaved(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
|
|
|
var o output.Output = output.Interleaved{}
|
2023-03-31 19:13:29 +00:00
|
|
|
w, _, _ := o.WrapWriter(&b, io.Discard, "", nil)
|
2018-04-22 21:40:03 -03:00
|
|
|
|
|
|
|
fmt.Fprintln(w, "foo\nbar")
|
|
|
|
assert.Equal(t, "foo\nbar\n", b.String())
|
|
|
|
fmt.Fprintln(w, "baz")
|
|
|
|
assert.Equal(t, "foo\nbar\nbaz\n", b.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGroup(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
|
|
|
var o output.Output = output.Group{}
|
2023-03-31 19:13:29 +00:00
|
|
|
stdOut, stdErr, cleanup := o.WrapWriter(&b, io.Discard, "", nil)
|
2018-04-22 21:40:03 -03:00
|
|
|
|
2022-07-06 10:43:32 -03:00
|
|
|
fmt.Fprintln(stdOut, "out\nout")
|
2018-04-22 21:40:03 -03:00
|
|
|
assert.Equal(t, "", b.String())
|
2022-07-06 10:43:32 -03:00
|
|
|
fmt.Fprintln(stdErr, "err\nerr")
|
2018-04-22 21:40:03 -03:00
|
|
|
assert.Equal(t, "", b.String())
|
2022-07-06 10:43:32 -03:00
|
|
|
fmt.Fprintln(stdOut, "out")
|
|
|
|
assert.Equal(t, "", b.String())
|
|
|
|
fmt.Fprintln(stdErr, "err")
|
|
|
|
assert.Equal(t, "", b.String())
|
|
|
|
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(nil))
|
2022-07-06 10:43:32 -03:00
|
|
|
assert.Equal(t, "out\nout\nerr\nerr\nout\nerr\n", b.String())
|
2018-04-22 21:40:03 -03:00
|
|
|
}
|
|
|
|
|
2022-01-14 00:11:47 +00:00
|
|
|
func TestGroupWithBeginEnd(t *testing.T) {
|
|
|
|
tmpl := templater.Templater{
|
|
|
|
Vars: &taskfile.Vars{
|
2023-04-06 12:07:57 +01:00
|
|
|
OrderedMap: orderedmap.FromMap(map[string]taskfile.Var{
|
2022-01-14 00:11:47 +00:00
|
|
|
"VAR1": {Static: "example-value"},
|
2023-04-06 12:07:57 +01:00
|
|
|
}),
|
2022-01-14 00:11:47 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
var o output.Output = output.Group{
|
|
|
|
Begin: "::group::{{ .VAR1 }}",
|
|
|
|
End: "::endgroup::",
|
|
|
|
}
|
|
|
|
t.Run("simple", func(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
2023-03-31 19:13:29 +00:00
|
|
|
w, _, cleanup := o.WrapWriter(&b, io.Discard, "", &tmpl)
|
2022-01-14 00:11:47 +00:00
|
|
|
|
|
|
|
fmt.Fprintln(w, "foo\nbar")
|
|
|
|
assert.Equal(t, "", b.String())
|
|
|
|
fmt.Fprintln(w, "baz")
|
|
|
|
assert.Equal(t, "", b.String())
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(nil))
|
2022-01-14 00:11:47 +00:00
|
|
|
assert.Equal(t, "::group::example-value\nfoo\nbar\nbaz\n::endgroup::\n", b.String())
|
|
|
|
})
|
|
|
|
t.Run("no output", func(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
2023-03-31 19:13:29 +00:00
|
|
|
_, _, cleanup := o.WrapWriter(&b, io.Discard, "", &tmpl)
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(nil))
|
2022-01-14 00:11:47 +00:00
|
|
|
assert.Equal(t, "", b.String())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-03-09 02:34:52 +01:00
|
|
|
func TestGroupErrorOnlySwallowsOutputOnNoError(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
|
|
|
var o output.Output = output.Group{
|
|
|
|
ErrorOnly: true,
|
|
|
|
}
|
2023-03-31 19:13:29 +00:00
|
|
|
stdOut, stdErr, cleanup := o.WrapWriter(&b, io.Discard, "", nil)
|
2023-03-09 02:34:52 +01:00
|
|
|
|
|
|
|
_, _ = fmt.Fprintln(stdOut, "std-out")
|
|
|
|
_, _ = fmt.Fprintln(stdErr, "std-err")
|
|
|
|
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(nil))
|
2023-03-09 02:34:52 +01:00
|
|
|
assert.Empty(t, b.String())
|
|
|
|
}
|
2023-03-31 19:13:29 +00:00
|
|
|
|
2023-03-09 02:34:52 +01:00
|
|
|
func TestGroupErrorOnlyShowsOutputOnError(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
|
|
|
var o output.Output = output.Group{
|
|
|
|
ErrorOnly: true,
|
|
|
|
}
|
2023-03-31 19:13:29 +00:00
|
|
|
stdOut, stdErr, cleanup := o.WrapWriter(&b, io.Discard, "", nil)
|
2023-03-09 02:34:52 +01:00
|
|
|
|
|
|
|
_, _ = fmt.Fprintln(stdOut, "std-out")
|
|
|
|
_, _ = fmt.Fprintln(stdErr, "std-err")
|
|
|
|
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(errors.New("any-error")))
|
2023-03-09 02:34:52 +01:00
|
|
|
assert.Equal(t, "std-out\nstd-err\n", b.String())
|
|
|
|
}
|
|
|
|
|
2018-04-22 21:40:03 -03:00
|
|
|
func TestPrefixed(t *testing.T) {
|
|
|
|
var b bytes.Buffer
|
|
|
|
var o output.Output = output.Prefixed{}
|
2023-03-31 19:13:29 +00:00
|
|
|
w, _, cleanup := o.WrapWriter(&b, io.Discard, "prefix", nil)
|
2018-04-22 21:40:03 -03:00
|
|
|
|
|
|
|
t.Run("simple use cases", func(t *testing.T) {
|
|
|
|
b.Reset()
|
|
|
|
|
|
|
|
fmt.Fprintln(w, "foo\nbar")
|
|
|
|
assert.Equal(t, "[prefix] foo\n[prefix] bar\n", b.String())
|
|
|
|
fmt.Fprintln(w, "baz")
|
|
|
|
assert.Equal(t, "[prefix] foo\n[prefix] bar\n[prefix] baz\n", b.String())
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(nil))
|
2018-04-22 21:40:03 -03:00
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("multiple writes for a single line", func(t *testing.T) {
|
|
|
|
b.Reset()
|
|
|
|
|
|
|
|
for _, char := range []string{"T", "e", "s", "t", "!"} {
|
|
|
|
fmt.Fprint(w, char)
|
|
|
|
assert.Equal(t, "", b.String())
|
|
|
|
}
|
|
|
|
|
2023-04-06 11:18:41 +01:00
|
|
|
require.NoError(t, cleanup(nil))
|
2018-04-22 21:40:03 -03:00
|
|
|
assert.Equal(t, "[prefix] Test!\n", b.String())
|
|
|
|
})
|
|
|
|
}
|