Skip to content

Commit

Permalink
test: add an integration test for creating tag on branches
Browse files Browse the repository at this point in the history
  • Loading branch information
Ryooooooga committed Feb 19, 2023
1 parent 67b08ac commit 36c2b00
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 0 deletions.
4 changes: 4 additions & 0 deletions pkg/integration/components/git.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@ func (self *Git) CurrentBranchName(expectedName string) *Git {
return self.assert("git rev-parse --abbrev-ref HEAD", expectedName)
}

func (self *Git) TagNamesAt(ref string, expectedNames []string) *Git {
return self.assert(fmt.Sprintf(`git tag --contains "%s"`, ref), strings.Join(expectedNames, "\n"))
}

func (self *Git) assert(cmdStr string, expected string) *Git {
self.assertWithRetries(func() (bool, string) {
output, err := self.shell.runCommandWithOutput(cmdStr)
Expand Down
47 changes: 47 additions & 0 deletions pkg/integration/tests/branch/create_tag.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
package branch

import (
"github.com/jesseduffield/lazygit/pkg/config"
. "github.com/jesseduffield/lazygit/pkg/integration/components"
)

var CreateTag = NewIntegrationTest(NewIntegrationTestArgs{
Description: "Create a new tag on branch",
ExtraCmdArgs: "",
Skip: false,
SetupConfig: func(config *config.AppConfig) {},
SetupRepo: func(shell *Shell) {
shell.
CreateNCommits(10).
NewBranch("new-branch").
EmptyCommit("new commit")
},
Run: func(t *TestDriver, keys config.KeybindingConfig) {
t.Views().Branches().
Focus().
Lines(
MatchesRegexp(`\*\s*new-branch`).IsSelected(),
MatchesRegexp(`master`),
).
SelectNextItem().
Press(keys.Branches.CreateTag)

t.ExpectPopup().Menu().
Title(Equals("Create tag")).
Confirm()

t.ExpectPopup().Prompt().
Title(Equals("Tag name:")).
Type("new-tag").
Confirm()

t.Views().Tags().
Lines(
MatchesRegexp(`new-tag`).IsSelected(),
)

t.Git().
TagNamesAt("HEAD", []string{}).
TagNamesAt("master", []string{"new-tag"})
},
})
1 change: 1 addition & 0 deletions pkg/integration/tests/tests_gen.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ var tests = []*components.IntegrationTest{
bisect.Basic,
bisect.FromOtherBranch,
branch.CheckoutByName,
branch.CreateTag,
branch.Delete,
branch.DetachedHead,
branch.OpenWithCliArg,
Expand Down

0 comments on commit 36c2b00

Please sign in to comment.