mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-08-07 22:02:56 +03:00
Add integration test
This commit is contained in:
@@ -360,8 +360,8 @@ func (self *Shell) CloneIntoRemote(name string) *Shell {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (self *Shell) CloneIntoSubmodule(submoduleName string, submodulePath string) *Shell {
|
func (self *Shell) CloneIntoSubmodule(submoduleName string, submodulePath string) *Shell {
|
||||||
self.Clone("other_repo")
|
self.Clone(submoduleName)
|
||||||
self.RunCommand([]string{"git", "submodule", "add", "--name", submoduleName, "../other_repo", submodulePath})
|
self.RunCommand([]string{"git", "submodule", "add", "--name", submoduleName, "../" + submoduleName, submodulePath})
|
||||||
|
|
||||||
return self
|
return self
|
||||||
}
|
}
|
||||||
|
@@ -44,7 +44,7 @@ var Remove = NewIntegrationTest(NewIntegrationTestArgs{
|
|||||||
t.Views().Main().Content(
|
t.Views().Main().Content(
|
||||||
Contains("-[submodule \"my_submodule_name\"]").
|
Contains("-[submodule \"my_submodule_name\"]").
|
||||||
Contains("- path = my_submodule_path").
|
Contains("- path = my_submodule_path").
|
||||||
Contains("- url = ../other_repo"),
|
Contains("- url = ../my_submodule_name"),
|
||||||
)
|
)
|
||||||
|
|
||||||
t.FileSystem().PathNotPresent(gitDirSubmodulePath)
|
t.FileSystem().PathNotPresent(gitDirSubmodulePath)
|
||||||
|
126
pkg/integration/tests/submodule/reset_folder.go
Normal file
126
pkg/integration/tests/submodule/reset_folder.go
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
package submodule
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/jesseduffield/lazygit/pkg/config"
|
||||||
|
. "github.com/jesseduffield/lazygit/pkg/integration/components"
|
||||||
|
)
|
||||||
|
|
||||||
|
var ResetFolder = NewIntegrationTest(NewIntegrationTestArgs{
|
||||||
|
Description: "Reset submodule changes located in a nested folder.",
|
||||||
|
ExtraCmdArgs: []string{},
|
||||||
|
Skip: false,
|
||||||
|
SetupConfig: func(cfg *config.AppConfig) {},
|
||||||
|
SetupRepo: func(shell *Shell) {
|
||||||
|
shell.EmptyCommit("first commit")
|
||||||
|
shell.CreateDir("dir")
|
||||||
|
shell.CloneIntoSubmodule("submodule1", "dir/submodule1")
|
||||||
|
shell.CloneIntoSubmodule("submodule2", "dir/submodule2")
|
||||||
|
shell.GitAddAll()
|
||||||
|
shell.Commit("add submodules")
|
||||||
|
|
||||||
|
shell.CreateFile("dir/submodule1/file", "")
|
||||||
|
shell.CreateFile("dir/submodule2/file", "")
|
||||||
|
shell.CreateFile("dir/file", "")
|
||||||
|
},
|
||||||
|
Run: func(t *TestDriver, keys config.KeybindingConfig) {
|
||||||
|
t.Views().Files().Focus().
|
||||||
|
Lines(
|
||||||
|
Equals("▼ dir").IsSelected(),
|
||||||
|
Equals(" ?? file"),
|
||||||
|
Equals(" M submodule1 (submodule)"),
|
||||||
|
Equals(" M submodule2 (submodule)"),
|
||||||
|
).
|
||||||
|
// Verify we cannot reset the entire folder (has nested file and submodule changes).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectToast(Contains("Disabled: Range select not supported for submodules"))
|
||||||
|
}).
|
||||||
|
// Verify we cannot reset submodule + file or submodule + submodule via range select.
|
||||||
|
SelectNextItem().
|
||||||
|
Press(keys.Universal.ToggleRangeSelect).
|
||||||
|
SelectNextItem().
|
||||||
|
Lines(
|
||||||
|
Equals("▼ dir"),
|
||||||
|
Equals(" ?? file").IsSelected(),
|
||||||
|
Equals(" M submodule1 (submodule)").IsSelected(),
|
||||||
|
Equals(" M submodule2 (submodule)"),
|
||||||
|
).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectToast(Contains("Disabled: Range select not supported for submodules"))
|
||||||
|
}).
|
||||||
|
Press(keys.Universal.ToggleRangeSelect).
|
||||||
|
Press(keys.Universal.ToggleRangeSelect).
|
||||||
|
SelectNextItem().
|
||||||
|
Lines(
|
||||||
|
Equals("▼ dir"),
|
||||||
|
Equals(" ?? file"),
|
||||||
|
Equals(" M submodule1 (submodule)").IsSelected(),
|
||||||
|
Equals(" M submodule2 (submodule)").IsSelected(),
|
||||||
|
).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectToast(Contains("Disabled: Range select not supported for submodules"))
|
||||||
|
}).
|
||||||
|
// Reset the file change.
|
||||||
|
Press(keys.Universal.ToggleRangeSelect).
|
||||||
|
NavigateToLine(Contains("file")).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectPopup().Menu().
|
||||||
|
Title(Equals("Discard changes")).
|
||||||
|
Select(Contains("Discard all changes")).
|
||||||
|
Confirm()
|
||||||
|
}).
|
||||||
|
NavigateToLine(Contains("▼ dir")).
|
||||||
|
Lines(
|
||||||
|
Equals("▼ dir").IsSelected(),
|
||||||
|
Equals(" M submodule1 (submodule)"),
|
||||||
|
Equals(" M submodule2 (submodule)"),
|
||||||
|
).
|
||||||
|
// Verify we still cannot reset the entire folder (has two submodule changes).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectToast(Contains("Disabled: Range select not supported for submodules"))
|
||||||
|
}).
|
||||||
|
// Reset one of the submodule changes.
|
||||||
|
SelectNextItem().
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectPopup().Menu().
|
||||||
|
Title(Equals("dir/submodule1")).
|
||||||
|
Select(Contains("Stash uncommitted submodule changes and update")).
|
||||||
|
Confirm()
|
||||||
|
}).
|
||||||
|
NavigateToLine(Contains("▼ dir")).
|
||||||
|
Lines(
|
||||||
|
Equals("▼ dir").IsSelected(),
|
||||||
|
Equals(" M submodule2 (submodule)"),
|
||||||
|
).
|
||||||
|
// Now we can reset the folder (equivalent to resetting just the nested submodule change).
|
||||||
|
// Range selecting both the folder and submodule change is allowed.
|
||||||
|
Press(keys.Universal.ToggleRangeSelect).
|
||||||
|
SelectNextItem().
|
||||||
|
Lines(
|
||||||
|
Equals("▼ dir").IsSelected(),
|
||||||
|
Equals(" M submodule2 (submodule)").IsSelected(),
|
||||||
|
).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectPopup().Menu().
|
||||||
|
Title(Equals("dir/submodule2")).
|
||||||
|
Select(Contains("Stash uncommitted submodule changes and update")).
|
||||||
|
Cancel()
|
||||||
|
}).
|
||||||
|
// Or just selecting the folder itself.
|
||||||
|
NavigateToLine(Contains("▼ dir")).
|
||||||
|
Press(keys.Universal.Remove).
|
||||||
|
Tap(func() {
|
||||||
|
t.ExpectPopup().Menu().
|
||||||
|
Title(Equals("dir/submodule2")).
|
||||||
|
Select(Contains("Stash uncommitted submodule changes and update")).
|
||||||
|
Confirm()
|
||||||
|
}).
|
||||||
|
IsEmpty()
|
||||||
|
},
|
||||||
|
})
|
@@ -345,6 +345,7 @@ var tests = []*components.IntegrationTest{
|
|||||||
submodule.Remove,
|
submodule.Remove,
|
||||||
submodule.RemoveNested,
|
submodule.RemoveNested,
|
||||||
submodule.Reset,
|
submodule.Reset,
|
||||||
|
submodule.ResetFolder,
|
||||||
sync.FetchPrune,
|
sync.FetchPrune,
|
||||||
sync.FetchWhenSortedByDate,
|
sync.FetchWhenSortedByDate,
|
||||||
sync.ForcePush,
|
sync.ForcePush,
|
||||||
|
Reference in New Issue
Block a user