1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-24 05:36:19 +02:00
lazygit/pkg/gui/gui_test.go

140 lines
3.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
2020-10-04 18:41:33 +11:00
package gui
import (
"fmt"
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"
2021-04-05 20:37:18 +10:00
"github.com/jesseduffield/lazygit/pkg/integration"
2020-10-04 18:41:33 +11:00
"github.com/stretchr/testify/assert"
)
2021-04-05 20:37:18 +10:00
// This file is quite similar to integration/main.go. The main difference is that this file is
// run via `go test` whereas the other is run via `test/lazyintegration/main.go` which provides
// a convenient gui wrapper around our integration tests. The `go test` approach is better
// for CI and for running locally in the background to ensure you haven't broken
// anything while making changes. If you want to visually see what's happening when a test is run,
// you'll need to take the other approach
2020-10-04 18:41:33 +11:00
//
2021-04-05 20:37:18 +10:00
// As for this file, to run an integration test, e.g. for test 'commit', go:
// go test pkg/gui/gui_test.go -run /commit
2020-10-04 18:41:33 +11:00
//
2020-10-05 21:00:31 +11:00
// To update a snapshot for an integration test, pass UPDATE_SNAPSHOTS=true
// UPDATE_SNAPSHOTS=true go test pkg/gui/gui_test.go -run /commit
2020-10-04 18:41:33 +11:00
//
2021-04-05 20:37:18 +10:00
// integration tests are run in test/integration/<test_name>/actual and the final test does
2020-10-04 18:41:33 +11:00
// not clean up that directory so you can cd into it to see for yourself what
2021-04-05 20:37:18 +10:00
// happened when a test fails.
2020-10-04 18:41:33 +11:00
//
2020-10-06 09:16:16 +11:00
// To override speed, pass e.g. `SPEED=1` as an env var. Otherwise we start each test
// at a high speed and then drop down to lower speeds upon each failure until finally
// trying at the original playback speed (speed 1). A speed of 2 represents twice the
// original playback speed. Speed may be a decimal.
2020-10-04 18:41:33 +11:00
func Test(t *testing.T) {
2021-04-05 20:37:18 +10:00
record := false
2021-04-06 09:02:01 +10:00
updateSnapshots := os.Getenv("UPDATE_SNAPSHOTS") != ""
speedEnv := os.Getenv("SPEED")
includeSkipped := os.Getenv("INCLUDE_SKIPPED") != ""
2021-04-06 09:02:01 +10:00
err := integration.RunTests(
t.Logf,
runCmdHeadless,
func(test *integration.Test, f func(*testing.T) error) {
2021-04-06 09:02:01 +10:00
t.Run(test.Name, func(t *testing.T) {
err := f(t)
assert.NoError(t, err)
2021-04-06 09:02:01 +10:00
})
},
updateSnapshots,
record,
speedEnv,
func(t *testing.T, expected string, actual string) {
2021-04-06 09:02:01 +10:00
assert.Equal(t, expected, actual, fmt.Sprintf("expected:\n%s\nactual:\n%s\n", expected, actual))
},
includeSkipped,
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
2021-04-06 09:02:01 +10:00
f, err := pty.StartWithSize(cmd, &pty.Winsize{Rows: 100, Cols: 100})
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
2021-04-06 09:02:01 +10:00
return f.Close()
2020-10-04 18:41:33 +11:00
}
func TestGuiGenerateMenuCandidates(t *testing.T) {
type scenario struct {
testName string
cmdOut string
filter string
valueFormat string
labelFormat string
test func([]commandMenuEntry, error)
}
scenarios := []scenario{
{
"Extract remote branch name",
2021-07-22 19:45:43 +02:00
"upstream/pr-1",
"(?P<remote>[a-z_]+)/(?P<branch>.*)",
2021-07-22 19:45:43 +02:00
"{{ .branch }}",
"Remote: {{ .remote }}",
func(actualEntry []commandMenuEntry, err error) {
2021-07-22 19:45:43 +02:00
assert.NoError(t, err)
assert.EqualValues(t, "pr-1", actualEntry[0].value)
assert.EqualValues(t, "Remote: upstream", actualEntry[0].label)
},
},
{
"Multiple named groups with empty labelFormat",
2021-07-22 19:45:43 +02:00
"upstream/pr-1",
"(?P<remote>[a-z]*)/(?P<branch>.*)",
"{{ .branch }}|{{ .remote }}",
"",
func(actualEntry []commandMenuEntry, err error) {
2021-07-22 19:45:43 +02:00
assert.NoError(t, err)
assert.EqualValues(t, "pr-1|upstream", actualEntry[0].value)
assert.EqualValues(t, "pr-1|upstream", actualEntry[0].label)
},
},
{
"Multiple named groups with group ids",
2021-07-22 19:45:43 +02:00
"upstream/pr-1",
"(?P<remote>[a-z]*)/(?P<branch>.*)",
"{{ .group_2 }}|{{ .group_1 }}",
"Remote: {{ .group_1 }}",
func(actualEntry []commandMenuEntry, err error) {
2021-07-22 19:45:43 +02:00
assert.NoError(t, err)
assert.EqualValues(t, "pr-1|upstream", actualEntry[0].value)
assert.EqualValues(t, "Remote: upstream", actualEntry[0].label)
},
},
}
for _, s := range scenarios {
t.Run(s.testName, func(t *testing.T) {
s.test(NewDummyGui().GenerateMenuCandidates(s.cmdOut, s.filter, s.valueFormat, s.labelFormat))
})
}
}