mirror of
https://github.com/jesseduffield/lazygit.git
synced 2026-04-26 21:04:27 +02:00
b8d23dd5a5
Set the sort order's default from the former foldersFirst to mixed, so this is a change in behavior. I find this useful because it now matches git's order, so if you look at the diff of a commit, the TOC at the top has the same order as the file tree you see when entering the commit.
173 lines
5.7 KiB
Go
173 lines
5.7 KiB
Go
package commit
|
|
|
|
import (
|
|
"github.com/jesseduffield/lazygit/pkg/config"
|
|
. "github.com/jesseduffield/lazygit/pkg/integration/components"
|
|
)
|
|
|
|
var DiscardOldFileChanges = NewIntegrationTest(NewIntegrationTestArgs{
|
|
Description: "Discarding a range of files from an old commit.",
|
|
ExtraCmdArgs: []string{},
|
|
Skip: false,
|
|
SetupConfig: func(config *config.AppConfig) {},
|
|
SetupRepo: func(shell *Shell) {
|
|
shell.CreateFileAndAdd("dir1/d1_file0", "file0\n")
|
|
shell.CreateFileAndAdd("dir1/subd1/subfile0", "file1\n")
|
|
shell.CreateFileAndAdd("dir2/d2_file1", "d2f1 content\n")
|
|
shell.CreateFileAndAdd("dir2/d2_file2", "d2f4 content\n")
|
|
shell.Commit("remove one file from this commit")
|
|
|
|
shell.UpdateFileAndAdd("dir2/d2_file1", "d2f1 content\nsecond line\n")
|
|
shell.DeleteFileAndAdd("dir2/d2_file2")
|
|
shell.CreateFileAndAdd("dir2/d2_file3", "d2f3 content\n")
|
|
shell.CreateFileAndAdd("dir2/d2_file4", "d2f2 content\n")
|
|
shell.Commit("remove four files from this commit")
|
|
|
|
shell.CreateFileAndAdd("dir1/fileToRemove", "file to remove content\n")
|
|
shell.CreateFileAndAdd("dir1/multiLineFile", "this file has\ncontent on\nthree lines\n")
|
|
shell.CreateFileAndAdd("dir1/subd1/file2ToRemove", "file2 to remove content\n")
|
|
shell.Commit("remove changes in multiple dirs from this commit")
|
|
},
|
|
Run: func(t *TestDriver, keys config.KeybindingConfig) {
|
|
t.Views().Commits().
|
|
Focus().
|
|
Lines(
|
|
Contains("remove changes in multiple dirs from this commit").IsSelected(),
|
|
Contains("remove four files from this commit"),
|
|
Contains("remove one file from this commit"),
|
|
).
|
|
NavigateToLine(Contains("remove one file from this commit")).
|
|
PressEnter()
|
|
|
|
// Check removing a single file from an old commit
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Equals("▼ /").IsSelected(),
|
|
Equals(" ▼ dir1"),
|
|
Equals(" A d1_file0"),
|
|
Equals(" ▼ subd1"),
|
|
Equals(" A subfile0"),
|
|
Equals(" ▼ dir2"),
|
|
Equals(" A d2_file1"),
|
|
Equals(" A d2_file2"),
|
|
).
|
|
NavigateToLine(Contains("d1_file0")).
|
|
Press(keys.Universal.Remove)
|
|
|
|
t.ExpectPopup().Confirmation().
|
|
Title(Equals("Discard file changes")).
|
|
Content(Equals("Are you sure you want to discard changes to the selected file(s) from this commit?\n\nThis action will start a rebase, reverting these file changes. Be aware that if subsequent commits depend on these changes, you may need to resolve conflicts.")).
|
|
Confirm()
|
|
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Equals("▼ /"),
|
|
Equals(" ▼ dir1/subd1"),
|
|
Equals(" A subfile0").IsSelected(),
|
|
Equals(" ▼ dir2"),
|
|
Equals(" A d2_file1"),
|
|
Equals(" A d2_file2"),
|
|
).
|
|
PressEscape()
|
|
|
|
// Check removing 4 files in the same directory
|
|
t.Views().Commits().
|
|
Focus().
|
|
Lines(
|
|
Contains("remove changes in multiple dirs from this commit"),
|
|
Contains("remove four files from this commit"),
|
|
Contains("remove one file from this commit").IsSelected(),
|
|
).
|
|
NavigateToLine(Contains("remove four files from this commit")).
|
|
PressEnter()
|
|
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Equals("▼ dir2").IsSelected(),
|
|
Equals(" M d2_file1"),
|
|
Equals(" D d2_file2"),
|
|
Equals(" A d2_file3"),
|
|
Equals(" A d2_file4"),
|
|
).
|
|
NavigateToLine(Contains("d2_file1")).
|
|
Press(keys.Universal.ToggleRangeSelect).
|
|
NavigateToLine(Contains("d2_file4")).
|
|
Press(keys.Universal.Remove)
|
|
|
|
t.ExpectPopup().Confirmation().
|
|
Title(Equals("Discard file changes")).
|
|
Content(Equals("Are you sure you want to discard changes to the selected file(s) from this commit?\n\nThis action will start a rebase, reverting these file changes. Be aware that if subsequent commits depend on these changes, you may need to resolve conflicts.")).
|
|
Confirm()
|
|
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Contains("(none)"),
|
|
).
|
|
PressEscape()
|
|
|
|
// Check removing multiple files from 2 directories w/ a custom patch.
|
|
// This checks node selection logic & if the custom patch is getting reset.
|
|
t.Views().Commits().
|
|
IsFocused().
|
|
Lines(
|
|
Contains("remove changes in multiple dirs from this commit"),
|
|
Contains("remove four files from this commit").IsSelected(),
|
|
Contains("remove one file from this commit"),
|
|
).
|
|
NavigateToLine(Contains("remove changes in multiple dirs from this commit")).
|
|
PressEnter()
|
|
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Equals("▼ dir1").IsSelected(),
|
|
Equals(" A fileToRemove"),
|
|
Equals(" A multiLineFile"),
|
|
Equals(" ▼ subd1"),
|
|
Equals(" A file2ToRemove"),
|
|
).
|
|
NavigateToLine(Contains("multiLineFile")).
|
|
PressEnter()
|
|
|
|
t.Views().PatchBuilding().
|
|
IsFocused().
|
|
SelectedLine(
|
|
Contains("+this file has"),
|
|
).
|
|
PressPrimaryAction().
|
|
PressEscape()
|
|
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Equals("▼ dir1"),
|
|
Equals(" A fileToRemove"),
|
|
Equals(" ◐ multiLineFile").IsSelected(),
|
|
Equals(" ▼ subd1"),
|
|
Equals(" A file2ToRemove"),
|
|
).
|
|
NavigateToLine(Contains("dir1")).
|
|
Press(keys.Universal.ToggleRangeSelect).
|
|
NavigateToLine(Contains("subd1")).
|
|
Press(keys.Universal.Remove)
|
|
|
|
t.ExpectPopup().Confirmation().
|
|
Title(Equals("Discard file changes")).
|
|
Content(Equals("Are you sure you want to discard changes to the selected file(s) from this commit?\n\nThis action will start a rebase, reverting these file changes. Be aware that if subsequent commits depend on these changes, you may need to resolve conflicts.\n\nNote: This will reset the active custom patch!")).
|
|
Confirm()
|
|
|
|
// "Building patch" will still be in this view if the patch isn't reset properly
|
|
t.Views().Information().Content(DoesNotContain("Building patch"))
|
|
|
|
t.Views().CommitFiles().
|
|
IsFocused().
|
|
Lines(
|
|
Contains("(none)"),
|
|
)
|
|
},
|
|
})
|