summaryrefslogtreecommitdiffstats
path: root/pkg/gui/gui_test.go
diff options
context:
space:
mode:
authorJesse Duffield <jessedduffield@gmail.com>2021-04-05 20:37:18 +1000
committerJesse Duffield <jessedduffield@gmail.com>2021-04-06 19:34:32 +1000
commit8e9d08bc10f206fae889f4529931e3e7277860c7 (patch)
tree451f20aefa557ef67d2edcf8dabb20b0d3c20f35 /pkg/gui/gui_test.go
parent9593129e6a3bf88a7e8f20e0b3dfb371e80b834b (diff)
minor cleanup of integration code
Diffstat (limited to 'pkg/gui/gui_test.go')
-rw-r--r--pkg/gui/gui_test.go310
1 files changed, 42 insertions, 268 deletions
diff --git a/pkg/gui/gui_test.go b/pkg/gui/gui_test.go
index fc1e59d4b..6b5cd9167 100644
--- a/pkg/gui/gui_test.go
+++ b/pkg/gui/gui_test.go
@@ -1,233 +1,103 @@
package gui
import (
- "encoding/json"
"fmt"
"io"
"io/ioutil"
"os"
"path/filepath"
- "strconv"
- "strings"
"testing"
"github.com/creack/pty"
"github.com/jesseduffield/lazygit/pkg/commands/oscommands"
- "github.com/jesseduffield/lazygit/pkg/secureexec"
+ "github.com/jesseduffield/lazygit/pkg/integration"
"github.com/stretchr/testify/assert"
)
-// heads up: this code needs some cleanup. It's currently partially duplicated in integration/main.go
-// To run an integration test, e.g. for test 'commit', go:
-// go test pkg/gui/gui_test.go -run /commit
+// 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
//
-// To record keypresses for an integration test, pass RECORD_EVENTS=true like so:
-// RECORD_EVENTS=true go test pkg/gui/gui_test.go -run /commit
+// As for this file, to run an integration test, e.g. for test 'commit', go:
+// go test pkg/gui/gui_test.go -run /commit
//
// To update a snapshot for an integration test, pass UPDATE_SNAPSHOTS=true
// UPDATE_SNAPSHOTS=true go test pkg/gui/gui_test.go -run /commit
//
-// When RECORD_EVENTS is true, updates will be updated automatically
-//
-// integration tests are run in test/integration_test and the final test does
+// integration tests are run in test/integration/<test_name>/actual and the final test does
// not clean up that directory so you can cd into it to see for yourself what
-// happened when a test failed.
+// happened when a test fails.
//
// 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 must be an integer.
-type integrationTest struct {
- Name string `json:"name"`
- Speed int `json:"speed"`
- Description string `json:"description"`
-}
-
-func loadTests(t *testing.T, testDir string) []*integrationTest {
- paths, err := filepath.Glob(filepath.Join(testDir, "/*/test.json"))
- assert.NoError(t, err)
-
- tests := make([]*integrationTest, len(paths))
-
- for i, path := range paths {
- data, err := ioutil.ReadFile(path)
- assert.NoError(t, err)
-
- test := &integrationTest{}
-
- err = json.Unmarshal(data, test)
- assert.NoError(t, err)
-
- test.Name = strings.TrimPrefix(filepath.Dir(path), testDir+"/")
-
- tests[i] = test
- }
-
- return tests
-}
-
-func generateSnapshot(t *testing.T, dir string) string {
- osCommand := oscommands.NewDummyOSCommand()
-
- _, err := os.Stat(filepath.Join(dir, ".git"))
- if err != nil {
- return "git directory not found"
- }
-
- snapshot := ""
-
- statusCmd := fmt.Sprintf(`git -C %s status`, dir)
- statusCmdOutput, err := osCommand.RunCommandWithOutput(statusCmd)
- assert.NoError(t, err)
-
- snapshot += statusCmdOutput + "\n"
-
- logCmd := fmt.Sprintf(`git -C %s log --pretty=%%B -p -1`, dir)
- logCmdOutput, err := osCommand.RunCommandWithOutput(logCmd)
- assert.NoError(t, err)
-
- snapshot += logCmdOutput + "\n"
-
- err = filepath.Walk(dir, func(path string, f os.FileInfo, err error) error {
- assert.NoError(t, err)
-
- if f.IsDir() {
- if f.Name() == ".git" {
- return filepath.SkipDir
- }
- return nil
- }
-
- bytes, err := ioutil.ReadFile(path)
- assert.NoError(t, err)
- snapshot += string(bytes) + "\n"
-
- return nil
- })
-
- assert.NoError(t, err)
-
- return snapshot
-}
-
-func findOrCreateDir(path string) {
- _, err := os.Stat(path)
- if err != nil {
- if os.IsNotExist(err) {
- err = os.MkdirAll(path, 0777)
- if err != nil {
- panic(err)
- }
- } else {
- panic(err)
- }
- }
-}
-
-func getTestSpeeds(testStartSpeed int, updateSnapshots bool) []int {
- if updateSnapshots {
- // have to go at original speed if updating snapshots in case we go to fast and create a junk snapshot
- return []int{1}
- }
-
- speedEnv := os.Getenv("SPEED")
- if speedEnv != "" {
- speed, err := strconv.Atoi(speedEnv)
- if err != nil {
- panic(err)
- }
- return []int{speed}
- }
-
- // default is 10, 5, 1
- startSpeed := 10
- if testStartSpeed != 0 {
- startSpeed = testStartSpeed
- }
- speeds := []int{startSpeed}
- if startSpeed > 5 {
- speeds = append(speeds, 5)
- }
- speeds = append(speeds, 1)
-
- return speeds
-}
-
-func tempLazygitPath() string {
- return filepath.Join("/tmp", "lazygit", "test_lazygit")
-}
-
func Test(t *testing.T) {
- rootDir := getRootDirectory()
+ rootDir := integration.GetRootDirectory()
err := os.Chdir(rootDir)
assert.NoError(t, err)
testDir := filepath.Join(rootDir, "test", "integration")
osCommand := oscommands.NewDummyOSCommand()
- err = osCommand.RunCommand("go build -o %s", tempLazygitPath())
+ err = osCommand.RunCommand("go build -o %s", integration.TempLazygitPath())
assert.NoError(t, err)
- tests := loadTests(t, testDir)
+ tests, err := integration.LoadTests(testDir)
+ assert.NoError(t, err)
- record := os.Getenv("RECORD_EVENTS") != ""
+ record := false
updateSnapshots := record || os.Getenv("UPDATE_SNAPSHOTS") != ""
for _, test := range tests {
test := test
t.Run(test.Name, func(t *testing.T) {
- speeds := getTestSpeeds(test.Speed, updateSnapshots)
+ speeds := integration.GetTestSpeeds(test.Speed, updateSnapshots)
+ testPath := filepath.Join(testDir, test.Name)
+ actualDir := filepath.Join(testPath, "actual")
+ expectedDir := filepath.Join(testPath, "expected")
+ t.Logf("testPath: %s, actualDir: %s, expectedDir: %s", testPath, actualDir, expectedDir)
for i, speed := range speeds {
t.Logf("%s: attempting test at speed %d\n", test.Name, speed)
- testPath := filepath.Join(testDir, test.Name)
- actualDir := filepath.Join(testPath, "actual")
- expectedDir := filepath.Join(testPath, "expected")
- t.Logf("testPath: %s, actualDir: %s, expectedDir: %s", testPath, actualDir, expectedDir)
- findOrCreateDir(testPath)
-
- prepareIntegrationTestDir(actualDir)
-
- err := createFixture(testPath, actualDir)
+ integration.FindOrCreateDir(testPath)
+ integration.PrepareIntegrationTestDir(actualDir)
+ err := integration.CreateFixture(testPath, actualDir)
assert.NoError(t, err)
configDir := filepath.Join(testPath, "used_config")
- runLazygit(t, testPath, rootDir, configDir, record, speed)
-
- if updateSnapshots {
- err = oscommands.CopyDir(actualDir, expectedDir)
- assert.NoError(t, err)
- }
+ cmd, err := integration.GetLazygitCommand(testPath, rootDir, record, speed)
+ assert.NoError(t, err)
- actual := generateSnapshot(t, actualDir)
+ cmd.Env = append(
+ cmd.Env,
+ "HEADLESS=true",
+ "TERM=xterm",
+ )
- expected := ""
+ f, err := pty.StartWithSize(cmd, &pty.Winsize{Rows: 100, Cols: 100})
+ assert.NoError(t, err)
- func() {
- // git refuses to track .git folders in subdirectories so we need to rename it
- // to git_keep after running a test
+ _, _ = io.Copy(ioutil.Discard, f)
- defer func() {
- err = os.Rename(
- filepath.Join(expectedDir, ".git"),
- filepath.Join(expectedDir, ".git_keep"),
- )
+ assert.NoError(t, err)
- assert.NoError(t, err)
- }()
+ _ = f.Close()
- // ignoring this error because we might not have a .git_keep file here yet.
- _ = os.Rename(
- filepath.Join(expectedDir, ".git_keep"),
- filepath.Join(expectedDir, ".git"),
- )
+ if updateSnapshots {
+ err = oscommands.CopyDir(actualDir, expectedDir)
+ assert.NoError(t, err)
+ }
- expected = generateSnapshot(t, expectedDir)
- }()
+ actual, expected, err := integration.GenerateSnapshots(actualDir, expectedDir)
+ assert.NoError(t, err)
if expected == actual {
t.Logf("%s: success at speed %d\n", test.Name, speed)
@@ -246,99 +116,3 @@ func Test(t *testing.T) {
})
}
}
-
-func createFixture(testPath, actualDir string) error {
- osCommand := oscommands.NewDummyOSCommand()
- bashScriptPath := filepath.Join(testPath, "setup.sh")
- cmd := secureexec.Command("bash", bashScriptPath, actualDir)
-
- if err := osCommand.RunExecutable(cmd); err != nil {
- return err
- }
-
- return nil
-}
-
-func getRootDirectory() string {
- path, err := os.Getwd()
- if err != nil {
- panic(err)
- }
-
- for {
- _, err := os.Stat(filepath.Join(path, ".git"))
-
- if err == nil {
- return path
- }
-
- if !os.IsNotExist(err) {
- panic(err)
- }
-
- path = filepath.Dir(path)
-
- if path == "/" {
- panic("must run in lazygit folder or child folder")
- }
- }
-}
-
-func runLazygit(t *testing.T, testPath string, rootDir string, configDir string, record bool, speed int) {
- osCommand := oscommands.NewDummyOSCommand()
-
- replayPath := filepath.Join(testPath, "recording.json")
- templateConfigDir := filepath.Join(rootDir, "test", "default_test_config")
- actualDir := filepath.Join(testPath, "actual")
-
- exists, err := osCommand.FileExists(filepath.Join(testPath, "config"))
- assert.NoError(t, err)
-
- if exists {
- templateConfigDir = filepath.Join(testPath, "config")
- }
-
- err = os.RemoveAll(configDir)
- assert.NoError(t, err)
- err = oscommands.CopyDir(templateConfigDir, configDir)
- assert.NoError(t, err)
-
- cmdStr := fmt.Sprintf("%s -debug --use-config-dir=%s --path=%s", tempLazygitPath(), configDir, actualDir)
-
- cmd := osCommand.ExecutableFromString(cmdStr)
- cmd.Env = append(cmd.Env, fmt.Sprintf("REPLAY_SPEED=%d", speed))
-
- cmd.Env = append(
- cmd.Env,
- fmt.Sprintf("REPLAY_EVENTS_FROM=%s", replayPath),
- "HEADLESS=true",
- "TERM=xterm",
- )
-
- f, err := pty.StartWithSize(cmd, &pty.Winsize{Rows: 100, Cols: 100})
- assert.NoError(t, err)
-
- _, _ = io.Copy(ioutil.Discard, f)
-
- assert.NoError(t, err)
-
- _ = f.Close()
-}
-
-func prepareIntegrationTestDir(actualDir string) {
- // remove contents of integration test directory
- dir, err := ioutil.ReadDir(actualDir)
- if err != nil {
- if os.IsNotExist(err) {
- err = os.Mkdir(actualDir, 0777)
- if err != nil {
- panic(err)
- }
- } else {
- panic(err)
- }
- }
- for _, d := range dir {
- os.RemoveAll(filepath.Join(actualDir, d.Name()))
- }
-}