From 9b2a0c453801ffd3f30256a27746b977f9119148 Mon Sep 17 00:00:00 2001 From: Stefan Haller Date: Mon, 23 Sep 2024 09:42:12 +0200 Subject: [PATCH] Add test for copying a commit author to the clipboard The test shows that we are including single quotes in strange places. --- .../tests/commit/copy_author_to_clipboard.go | 51 +++++++++++++++++++ pkg/integration/tests/test_list.go | 1 + 2 files changed, 52 insertions(+) create mode 100644 pkg/integration/tests/commit/copy_author_to_clipboard.go diff --git a/pkg/integration/tests/commit/copy_author_to_clipboard.go b/pkg/integration/tests/commit/copy_author_to_clipboard.go new file mode 100644 index 000000000..6b9319f36 --- /dev/null +++ b/pkg/integration/tests/commit/copy_author_to_clipboard.go @@ -0,0 +1,51 @@ +package commit + +import ( + "github.com/jesseduffield/lazygit/pkg/config" + . "github.com/jesseduffield/lazygit/pkg/integration/components" +) + +// We're emulating the clipboard by writing to a file called clipboard + +var CopyAuthorToClipboard = NewIntegrationTest(NewIntegrationTestArgs{ + Description: "Copy a commit author name to the clipboard", + ExtraCmdArgs: []string{}, + Skip: false, + SetupConfig: func(config *config.AppConfig) { + // Include delimiters around the text so that we can assert on the entire content + config.GetUserConfig().OS.CopyToClipboardCmd = "echo /{{text}}/ > clipboard" + }, + + SetupRepo: func(shell *Shell) { + shell.SetAuthor("John Doe", "john@doe.com") + shell.EmptyCommit("commit") + }, + + Run: func(t *TestDriver, keys config.KeybindingConfig) { + t.Views().Commits(). + Focus(). + Lines( + Contains("commit").IsSelected(), + ). + Press(keys.Commits.CopyCommitAttributeToClipboard) + + t.ExpectPopup().Menu(). + Title(Equals("Copy to clipboard")). + Select(Contains("Commit author")). + Confirm() + + t.ExpectToast(Equals("Commit author copied to clipboard")) + + t.Views().Files(). + Focus(). + Press(keys.Files.RefreshFiles). + Lines( + Contains("clipboard").IsSelected(), + ) + + /* EXPECTED: + t.Views().Main().Content(Contains("/John Doe /")) + ACTUAL: */ + t.Views().Main().Content(Contains("/'John Doe /")) + }, +}) diff --git a/pkg/integration/tests/test_list.go b/pkg/integration/tests/test_list.go index db79247ff..281b0a2b3 100644 --- a/pkg/integration/tests/test_list.go +++ b/pkg/integration/tests/test_list.go @@ -87,6 +87,7 @@ var tests = []*components.IntegrationTest{ commit.CommitWithGlobalPrefix, commit.CommitWithNonMatchingBranchName, commit.CommitWithPrefix, + commit.CopyAuthorToClipboard, commit.CreateAmendCommit, commit.CreateFixupCommitInBranchStack, commit.CreateTag,