1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-22 05:29:44 +02:00

88 lines
1.9 KiB
Go
Raw Normal View History

2021-09-16 21:38:43 +08:00
//go:build !windows
2021-04-08 21:24:49 +10:00
// +build !windows
2022-08-14 14:33:44 +10:00
package clients
2020-10-04 18:41:33 +11:00
2023-02-26 11:23:36 +11:00
// This file allows you to use `go test` to run integration tests.
// See See pkg/integration/README.md for more info.
2022-08-07 22:09:39 +10:00
2020-10-04 18:41:33 +11:00
import (
"bytes"
"errors"
2021-04-05 13:07:25 +10:00
"io"
2020-10-04 18:41:33 +11:00
"io/ioutil"
"os"
2021-04-06 09:02:01 +10:00
"os/exec"
2020-10-04 18:41:33 +11:00
"testing"
2021-04-05 13:07:25 +10:00
"github.com/creack/pty"
2022-08-12 09:24:39 +10:00
"github.com/jesseduffield/lazygit/pkg/integration/components"
2022-08-14 11:24:07 +10:00
"github.com/jesseduffield/lazygit/pkg/integration/tests"
2020-10-04 18:41:33 +11:00
"github.com/stretchr/testify/assert"
)
func TestIntegration(t *testing.T) {
if testing.Short() {
t.Skip("Skipping integration tests in short mode")
}
parallelTotal := tryConvert(os.Getenv("PARALLEL_TOTAL"), 1)
parallelIndex := tryConvert(os.Getenv("PARALLEL_INDEX"), 0)
testNumber := 0
2022-08-14 11:24:07 +10:00
err := components.RunTests(
tests.GetTests(),
2021-04-06 09:02:01 +10:00
t.Logf,
runCmdHeadless,
2022-08-12 09:19:39 +10:00
func(test *components.IntegrationTest, f func() error) {
defer func() { testNumber += 1 }()
if testNumber%parallelTotal != parallelIndex {
return
}
2022-08-07 22:09:39 +10:00
t.Run(test.Name(), func(t *testing.T) {
t.Parallel()
err := f()
assert.NoError(t, err)
2021-04-06 09:02:01 +10:00
})
},
false,
2022-08-14 14:33:44 +10:00
0,
// Allow two attempts at each test to get around flakiness
2,
2021-04-06 09:02:01 +10:00
)
2020-10-04 18:41:33 +11:00
2021-04-06 09:02:01 +10:00
assert.NoError(t, err)
}
2020-10-06 09:23:09 +11:00
2021-04-06 09:02:01 +10:00
func runCmdHeadless(cmd *exec.Cmd) error {
cmd.Env = append(
cmd.Env,
"HEADLESS=true",
"TERM=xterm",
)
2020-10-06 09:23:09 +11:00
// not writing stderr to the pty because we want to capture a panic if
// there is one. But some commands will not be in tty mode if stderr is
// not a terminal. We'll need to keep an eye out for that.
stderr := new(bytes.Buffer)
cmd.Stderr = stderr
// these rows and columns are ignored because internally we use tcell's
// simulation screen. However we still need the pty for the sake of
// running other commands in a pty.
f, err := pty.StartWithSize(cmd, &pty.Winsize{Rows: 300, Cols: 300})
2021-04-06 09:02:01 +10:00
if err != nil {
return err
}
2020-10-04 18:41:33 +11:00
2021-04-06 09:02:01 +10:00
_, _ = io.Copy(ioutil.Discard, f)
2020-10-04 18:41:33 +11:00
if cmd.Wait() != nil {
// return an error with the stderr output
return errors.New(stderr.String())
}
2021-04-06 09:02:01 +10:00
return f.Close()
2020-10-04 18:41:33 +11:00
}