github.com/josephspurrier/go-swagger@v0.2.1-0.20221129144919-1f672a142a00/cmd/swagger/commands/internal/cmdtest/output.go (about) 1 // Package cmdtest provides test utilities 2 // to assert the output of CLI commands 3 package cmdtest 4 5 import ( 6 "io" 7 "os" 8 "strings" 9 "testing" 10 11 "github.com/stretchr/testify/assert" 12 "github.com/stretchr/testify/require" 13 ) 14 15 // AssertReadersContent compares the contents from io.Readers, optionally stripping blanks 16 func AssertReadersContent(t testing.TB, noBlanks bool, expected, actual io.Reader) bool { 17 e, err := io.ReadAll(expected) 18 require.NoError(t, err) 19 20 a, err := io.ReadAll(actual) 21 require.NoError(t, err) 22 23 var wants, got strings.Builder 24 _, _ = wants.Write(e) 25 _, _ = got.Write(a) 26 27 if noBlanks { 28 r := strings.NewReplacer(" ", "", "\t", "", "\n", "", "\r", "") 29 return assert.Equalf(t, r.Replace(wants.String()), r.Replace(got.String()), "expected:\n%s\ngot %s", wants.String(), got.String()) 30 } 31 return assert.Equal(t, wants.String(), got.String()) 32 } 33 34 // CatchStdOut captures the standard output from a runnable function. 35 // You shouln't run this in parallel. 36 func CatchStdOut(t testing.TB, runnable func() error) ([]byte, error) { 37 realStdout := os.Stdout 38 defer func() { os.Stdout = realStdout }() 39 r, fakeStdout, err := os.Pipe() 40 require.NoError(t, err) 41 os.Stdout = fakeStdout 42 e := runnable() 43 // need to close here, otherwise ReadAll never gets "EOF". 44 require.NoError(t, fakeStdout.Close()) 45 newOutBytes, err := io.ReadAll(r) 46 require.NoError(t, err) 47 require.NoError(t, r.Close()) 48 return newOutBytes, e 49 }