summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJesse Duffield <jessedduffield@gmail.com>2023-08-04 09:18:25 +1000
committerGitHub <noreply@github.com>2023-08-04 09:18:25 +1000
commitab5875c78fcd7fc2f0cdbc867dc84ef4331a5de3 (patch)
tree2c1f9e424d7875305e077cd3d21cf2afa549545d
parentc390c9d58edc18083ed7f1a672b03b7c4d982c12 (diff)
parentf6af4c29d4bd4826b570af6ac72bb8bc50c6f16c (diff)
Add more demos (#2874)
-rw-r--r--README.md22
-rw-r--r--pkg/integration/components/menu_driver.go6
-rw-r--r--pkg/integration/tests/demo/custom_command.go78
-rw-r--r--pkg/integration/tests/demo/custom_patch.go76
-rw-r--r--pkg/integration/tests/demo/undo.go71
-rw-r--r--pkg/integration/tests/demo/worktree_create_from_branches.go59
-rw-r--r--pkg/integration/tests/test_list.go4
7 files changed, 316 insertions, 0 deletions
diff --git a/README.md b/README.md
index f22393fd8..5849bbb28 100644
--- a/README.md
+++ b/README.md
@@ -107,6 +107,28 @@ You can filter a view with `/`. Here we filter down our branches view and then h
![filter](../assets/demo/filter-compressed.gif)
+### Invoke a custom command
+
+Lazygit has a very flexible [custom command system](docs/Custom_Command_Keybindings.md). In this example a custom command is defined which emulates the built-in branch checkout action.
+
+![custom_command](../assets/demo/custom_command-compressed.gif)
+
+### Worktrees
+
+You can create worktrees to have multiple branches going at once without the need for stashing or creating WIP commits when switching between them. Press `w` in the branches view to create a worktree from the selected branch and switch to it.
+
+![worktree_create_from_branches](../assets/demo/worktree_create_from_branches-compressed.gif)
+
+### Rebase magic (custom patches)
+
+You can build a custom patch from an old commit and then remove the patch from the commit, split out a new commit, apply the patch in reverse to the index, and more.
+
+In this example we have a redundant comment that we want to remove from an old commit. We hit `<enter>` on the commit to view its files, then `<enter>` on a file to focus the patch, then `<space>` to add the comment line to our custom patch, and then `ctrl+p` to view the custom patch options; selecting to remove the patch from the current commit.
+
+Learn more in the [Rebase magic Youtube tutorial](https://youtu.be/4XaToVut_hs).
+
+![custom_patch](../assets/demo/custom_patch-compressed.gif)
+
## Tutorials
[<img src="https://i.imgur.com/sVEktDn.png">](https://youtu.be/CPLdltN7wgE)
diff --git a/pkg/integration/components/menu_driver.go b/pkg/integration/components/menu_driver.go
index 4e0b0f6da..34d081dfa 100644
--- a/pkg/integration/components/menu_driver.go
+++ b/pkg/integration/components/menu_driver.go
@@ -60,6 +60,12 @@ func (self *MenuDriver) LineCount(matcher *IntMatcher) *MenuDriver {
return self
}
+func (self *MenuDriver) Wait(milliseconds int) *MenuDriver {
+ self.getViewDriver().Wait(milliseconds)
+
+ return self
+}
+
func (self *MenuDriver) checkNecessaryChecksCompleted() {
if !self.hasCheckedTitle {
self.t.Fail("You must check the title of a menu popup by calling Title() before calling Confirm()/Cancel().")
diff --git a/pkg/integration/tests/demo/custom_command.go b/pkg/integration/tests/demo/custom_command.go
new file mode 100644
index 000000000..46b6b515e
--- /dev/null
+++ b/pkg/integration/tests/demo/custom_command.go
@@ -0,0 +1,78 @@
+package demo
+
+import (
+ "github.com/jesseduffield/lazygit/pkg/config"
+ . "github.com/jesseduffield/lazygit/pkg/integration/components"
+)
+
+var customCommandContent = `
+customCommands:
+ - key: 'a'
+ command: 'git checkout {{.Form.Branch}}'
+ context: 'localBranches'
+ prompts:
+ - type: 'input'
+ title: 'Enter a branch name to checkout:'
+ key: 'Branch'
+ suggestions:
+ preset: 'branches'
+`
+
+var CustomCommand = NewIntegrationTest(NewIntegrationTestArgs{
+ Description: "Invoke a custom command",
+ ExtraCmdArgs: []string{},
+ Skip: false,
+ IsDemo: true,
+ SetupConfig: func(cfg *config.AppConfig) {
+ // No idea why I had to use version 2: it should be using my own computer's
+ // font and the one iterm uses is version 3.
+ cfg.UserConfig.Gui.NerdFontsVersion = "2"
+
+ cfg.UserConfig.CustomCommands = []config.CustomCommand{
+ {
+ Key: "a",
+ Context: "localBranches",
+ Command: `git checkout {{.Form.Branch}}`,
+ Prompts: []config.CustomCommandPrompt{
+ {
+ Key: "Branch",
+ Type: "input",
+ Title: "Enter a branch name to checkout",
+ Suggestions: config.CustomCommandSuggestions{
+ Preset: "branches",
+ },
+ },
+ },
+ },
+ }
+ },
+ SetupRepo: func(shell *Shell) {
+ shell.CreateNCommitsWithRandomMessages(30)
+ shell.NewBranch("feature/user-authentication")
+ shell.NewBranch("feature/payment-processing")
+ shell.NewBranch("feature/search-functionality")
+ shell.NewBranch("feature/mobile-responsive")
+ shell.EmptyCommit("Make mobile response")
+ shell.NewBranch("bugfix/fix-login-issue")
+ shell.HardReset("HEAD~1")
+ shell.NewBranch("bugfix/fix-crash-bug")
+ shell.CreateFile("custom_commands_example.yml", customCommandContent)
+ },
+ Run: func(t *TestDriver, keys config.KeybindingConfig) {
+ t.SetCaptionPrefix("Invoke a custom command")
+ t.Wait(1500)
+
+ t.Views().Branches().
+ Focus().
+ Wait(500).
+ Press("a").
+ Tap(func() {
+ t.Wait(500)
+
+ t.ExpectPopup().Prompt().
+ Title(Equals("Enter a branch name to checkout")).
+ Type("mobile").
+ ConfirmFirstSuggestion()
+ })
+ },
+})
diff --git a/pkg/integration/tests/demo/custom_patch.go b/pkg/integration/tests/demo/custom_patch.go
new file mode 100644
index 000000000..b110054a5
--- /dev/null
+++ b/pkg/integration/tests/demo/custom_patch.go
@@ -0,0 +1,76 @@
+package demo
+
+import (
+ "github.com/jesseduffield/lazygit/pkg/config"
+ . "github.com/jesseduffield/lazygit/pkg/integration/components"
+)
+
+var usersFileContent = `package main
+
+import "fmt"
+
+func main() {
+ // TODO: verify that this actuall works
+ fmt.Println("hello world")
+}
+`
+
+var CustomPatch = NewIntegrationTest(NewIntegrationTestArgs{
+ Description: "Remove a line from an old commit",
+ ExtraCmdArgs: []string{},
+ Skip: false,
+ IsDemo: true,
+ SetupConfig: func(cfg *config.AppConfig) {
+ // No idea why I had to use version 2: it should be using my own computer's
+ // font and the one iterm uses is version 3.
+ cfg.UserConfig.Gui.NerdFontsVersion = "2"
+ },
+ SetupRepo: func(shell *Shell) {
+ shell.CreateNCommitsWithRandomMessages(30)
+ shell.NewBranch("feature/user-authentication")
+ shell.EmptyCommit("Add user authentication feature")
+ shell.CreateFileAndAdd("src/users.go", "package main\n")
+ shell.Commit("Fix local session storage")
+ shell.CreateFile("src/authentication.go", "package main")
+ shell.CreateFile("src/session.go", "package main")
+ shell.UpdateFileAndAdd("src/users.go", usersFileContent)
+ shell.EmptyCommit("Stop using shims")
+ shell.UpdateFileAndAdd("src/authentication.go", "package authentication")
+ shell.UpdateFileAndAdd("src/session.go", "package session")
+ shell.Commit("Enhance user authentication feature")
+ },
+ Run: func(t *TestDriver, keys config.KeybindingConfig) {
+ t.SetCaptionPrefix("Remove a line from an old commit")
+ t.Wait(1000)
+
+ t.Views().Commits().
+ Focus().
+ NavigateToLine(Contains("Stop using shims")).
+ Wait(1000).
+ PressEnter().
+ Tap(func() {
+ t.Views().CommitFiles().
+ IsFocused().
+ NavigateToLine(Contains("users.go")).
+ Wait(1000).
+ PressEnter().
+ Tap(func() {
+ t.Views().PatchBuilding().
+ IsFocused().
+ NavigateToLine(Contains("TODO")).
+ Wait(500).
+ PressPrimaryAction().
+ PressEscape()
+ }).
+ Press(keys.Universal.CreatePatchOptionsMenu).
+ Tap(func() {
+ t.ExpectPopup().Menu().
+ Title(Equals("Patch options")).
+ Select(Contains("Remove patch from original commit")).
+ Wait(500).
+ Confirm()
+ }).
+ PressEscape()
+ })
+ },
+})
diff --git a/pkg/integration/tests/demo/undo.go b/pkg/integration/tests/demo/undo.go
new file mode 100644
index 000000000..f11a514ac
--- /dev/null
+++ b/pkg/integration/tests/demo/undo.go
@@ -0,0 +1,71 @@
+package demo
+
+import (
+ "github.com/jesseduffield/lazygit/pkg/config"
+ . "github.com/jesseduffield/lazygit/pkg/integration/components"
+)
+
+// TODO: fix confirmation view wrapping issue: https://github.com/jesseduffield/lazygit/issues/2872
+
+var Undo = NewIntegrationTest(NewIntegrationTestArgs{
+ Description: "Undo",
+ ExtraCmdArgs: []string{},
+ Skip: false,
+ IsDemo: true,
+ SetupConfig: func(config *config.AppConfig) {
+ // No idea why I had to use version 2: it should be using my own computer's
+ // font and the one iterm uses is version 3.
+ config.UserConfig.Gui.NerdFontsVersion = "2"
+ },
+ SetupRepo: func(shell *Shell) {
+ shell.CreateNCommitsWithRandomMessages(30)
+ },
+ Run: func(t *TestDriver, keys config.KeybindingConfig) {
+ t.SetCaptionPrefix("Undo commands")
+ t.Wait(1000)
+
+ confirmCommitDrop := func() {
+ t.ExpectPopup().Confirmation().
+ Title(Equals("Delete commit")).
+ Content(Equals("Are you sure you want to delete this commit?")).
+ Wait(500).
+ Confirm()
+ }
+
+ confirmUndo := func() {
+ t.ExpectPopup().Confirmation().
+ Title(Equals("Undo")).
+ Content(MatchesRegexp(`Are you sure you want to hard reset to '.*'\? An auto-stash will be performed if necessary\.`)).
+ Wait(500).
+ Confirm()
+ }
+
+ confirmRedo := func() {
+ t.ExpectPopup().Confirmation().
+ Title(Equals("Redo")).
+ Content(MatchesRegexp(`Are you sure you want to hard reset to '.*'\? An auto-stash will be performed if necessary\.`)).
+ Wait(500).
+ Confirm()
+ }
+
+ t.Views().Commits().Focus().
+ SetCaptionPrefix("Drop two commits").
+ Wait(1000).
+ Press(keys.Universal.Remove).
+ Tap(confirmCommitDrop).
+ Press(keys.Universal.Remove).
+ Tap(confirmCommitDrop).
+ SetCaptionPrefix("Undo the drops").
+ Wait(1000).
+ Press(keys.Universal.Undo).
+ Tap(confirmUndo).
+ Press(keys.Universal.Undo).
+ Tap(confirmUndo).
+ SetCaptionPrefix("Redo the drops").
+ Wait(1000).
+ Press(keys.Universal.Redo).
+ Tap(confirmRedo).
+ Press(keys.Universal.Redo).
+ Tap(confirmRedo)
+ },
+})
diff --git a/pkg/integration/tests/demo/worktree_create_from_branches.go b/pkg/integration/tests/demo/worktree_create_from_branches.go
new file mode 100644
index 000000000..d25b531d2
--- /dev/null
+++ b/pkg/integration/tests/demo/worktree_create_from_branches.go
@@ -0,0 +1,59 @@
+package demo
+
+import (
+ "github.com/jesseduffield/lazygit/pkg/config"
+ . "github.com/jesseduffield/lazygit/pkg/integration/components"
+)
+
+var WorktreeCreateFromBranches = NewIntegrationTest(NewIntegrationTestArgs{
+ Description: "Create a worktree from the branches view",
+ ExtraCmdArgs: []string{},
+ Skip: false,
+ IsDemo: true,
+ SetupConfig: func(cfg *config.AppConfig) {
+ // No idea why I had to use version 2: it should be using my own computer's
+ // font and the one iterm uses is version 3.
+ cfg.UserConfig.Gui.NerdFontsVersion = "2"
+ },
+ SetupRepo: func(shell *Shell) {
+ shell.CreateNCommitsWithRandomMessages(30)
+ shell.NewBranch("feature/user-authentication")
+ shell.EmptyCommit("Add user authentication feature")
+ shell.EmptyCommit("Fix local session storage")
+ shell.CreateFile("src/authentication.go", "package main")
+ shell.CreateFile("src/shims.go", "package main")
+ shell.CreateFile("src/session.go", "package main")
+ shell.EmptyCommit("Stop using shims")
+ shell.UpdateFile("src/authentication.go", "package authentication")
+ shell.UpdateFileAndAdd("src/shims.go", "// removing for now")
+ shell.UpdateFile("src/session.go", "package session")
+ },
+ Run: func(t *TestDriver, keys config.KeybindingConfig) {
+ t.SetCaptionPrefix("Create a worktree from a branch")
+ t.Wait(1000)
+
+ t.Views().Branches().
+ Focus().
+ NavigateToLine(Contains("master")).
+ Wait(500).
+ Press(keys.Worktrees.ViewWorktreeOptions).
+ Tap(func() {
+ t.Wait(500)
+
+ t.ExpectPopup().Menu().
+ Title(Equals("Worktree")).
+ Select(Contains("Create worktree from master").DoesNotContain("detached")).
+ Confirm()
+
+ t.ExpectPopup().Prompt().
+ Title(Equals("New worktree path")).
+ Type("../hotfix").
+ Confirm()
+
+ t.ExpectPopup().Prompt().
+ Title(Contains("New branch name")).
+ Type("hotfix/db-on-fire").
+ Confirm()
+ })
+ },
+})
diff --git a/pkg/integration/tests/test_list.go b/pkg/integration/tests/test_list.go
index 75508784e..f71a3981e 100644
--- a/pkg/integration/tests/test_list.go
+++ b/pkg/integration/tests/test_list.go
@@ -93,10 +93,14 @@ var tests = []*components.IntegrationTest{
demo.Bisect,
demo.CherryPick,
demo.CommitAndPush,
+ demo.CustomCommand,
+ demo.CustomPatch,
demo.Filter,
demo.InteractiveRebase,
demo.NukeWorkingTree,
demo.StageLines,
+ demo.Undo,
+ demo.WorktreeCreateFromBranches,
diff.Diff,
diff.DiffAndApplyPatch,
diff.DiffCommits,