1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-26 05:37:18 +02:00
lazygit/pkg/commands/git_commands/commit_loader_test.go

252 lines
9.6 KiB
Go
Raw Normal View History

package git_commands
import (
2021-12-30 11:22:29 +11:00
"path/filepath"
2022-03-26 21:55:44 +09:00
"strings"
"testing"
2021-12-30 13:11:58 +11:00
"github.com/jesseduffield/lazygit/pkg/commands/models"
"github.com/jesseduffield/lazygit/pkg/commands/oscommands"
2021-12-30 13:35:10 +11:00
"github.com/jesseduffield/lazygit/pkg/commands/types/enums"
"github.com/jesseduffield/lazygit/pkg/utils"
"github.com/stretchr/testify/assert"
)
2022-05-08 14:23:29 +10:00
var commitsOutput = strings.Replace(`0eea75e8c631fba6b58135697835d58ba4c18dbc|1640826609|Jesse Duffield|jessedduffield@gmail.com| (HEAD -> better-tests)|b21997d6b4cbdf84b149|better typing for rebase mode
b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164|1640824515|Jesse Duffield|jessedduffield@gmail.com| (origin/better-tests)|e94e8fc5b6fab4cb755f|fix logging
e94e8fc5b6fab4cb755f29f1bdb3ee5e001df35c|1640823749|Jesse Duffield|jessedduffield@gmail.com||d8084cd558925eb7c9c3|refactor
d8084cd558925eb7c9c38afeed5725c21653ab90|1640821426|Jesse Duffield|jessedduffield@gmail.com||65f910ebd85283b5cce9|WIP
65f910ebd85283b5cce9bf67d03d3f1a9ea3813a|1640821275|Jesse Duffield|jessedduffield@gmail.com||26c07b1ab33860a1a759|WIP
26c07b1ab33860a1a7591a0638f9925ccf497ffa|1640750752|Jesse Duffield|jessedduffield@gmail.com||3d4470a6c072208722e5|WIP
3d4470a6c072208722e5ae9a54bcb9634959a1c5|1640748818|Jesse Duffield|jessedduffield@gmail.com||053a66a7be3da43aacdc|WIP
053a66a7be3da43aacdc7aa78e1fe757b82c4dd2|1640739815|Jesse Duffield|jessedduffield@gmail.com||985fe482e806b172aea4|refactoring the config struct`, "|", "\x00", -1)
2021-12-30 13:11:58 +11:00
func TestGetCommits(t *testing.T) {
type scenario struct {
2021-12-30 13:11:58 +11:00
testName string
2022-01-26 10:34:56 +11:00
runner *oscommands.FakeCmdObjRunner
2021-12-30 13:11:58 +11:00
expectedCommits []*models.Commit
expectedError error
logOrder string
2021-12-30 13:35:10 +11:00
rebaseMode enums.RebaseMode
2021-12-30 13:11:58 +11:00
currentBranchName string
opts GetCommitsOptions
}
scenarios := []scenario{
{
2021-12-30 13:11:58 +11:00
testName: "should return no commits if there are none",
logOrder: "topo-order",
2021-12-30 13:35:10 +11:00
rebaseMode: enums.REBASE_MODE_NONE,
2021-12-30 13:11:58 +11:00
currentBranchName: "master",
opts: GetCommitsOptions{RefName: "HEAD", IncludeRebaseCommits: false},
runner: oscommands.NewFakeRunner(t).
Expect(`git merge-base "HEAD" "HEAD"@{u}`, "b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164", nil).
2023-03-14 01:11:47 +09:00
Expect(`git log "HEAD" --topo-order --oneline --pretty=format:"%H%x00%at%x00%aN%x00%ae%x00%d%x00%p%x00%s" --abbrev=40 --no-show-signature --`, "", nil),
2021-12-30 13:11:58 +11:00
expectedCommits: []*models.Commit{},
expectedError: nil,
},
{
testName: "should use proper upstream name for branch",
logOrder: "topo-order",
rebaseMode: enums.REBASE_MODE_NONE,
currentBranchName: "mybranch",
opts: GetCommitsOptions{RefName: "refs/heads/mybranch", IncludeRebaseCommits: false},
runner: oscommands.NewFakeRunner(t).
Expect(`git merge-base "refs/heads/mybranch" "mybranch"@{u}`, "b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164", nil).
2023-03-14 01:11:47 +09:00
Expect(`git log "refs/heads/mybranch" --topo-order --oneline --pretty=format:"%H%x00%at%x00%aN%x00%ae%x00%d%x00%p%x00%s" --abbrev=40 --no-show-signature --`, "", nil),
expectedCommits: []*models.Commit{},
expectedError: nil,
},
{
2021-12-30 13:11:58 +11:00
testName: "should return commits if they are present",
logOrder: "topo-order",
2021-12-30 13:35:10 +11:00
rebaseMode: enums.REBASE_MODE_NONE,
2021-12-30 13:11:58 +11:00
currentBranchName: "master",
opts: GetCommitsOptions{RefName: "HEAD", IncludeRebaseCommits: false},
runner: oscommands.NewFakeRunner(t).
// here it's seeing which commits are yet to be pushed
Expect(`git merge-base "HEAD" "HEAD"@{u}`, "b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164", nil).
// here it's actually getting all the commits in a formatted form, one per line
2023-03-14 01:11:47 +09:00
Expect(`git log "HEAD" --topo-order --oneline --pretty=format:"%H%x00%at%x00%aN%x00%ae%x00%d%x00%p%x00%s" --abbrev=40 --no-show-signature --`, commitsOutput, nil).
2021-12-30 13:11:58 +11:00
// here it's seeing where our branch diverged from the master branch so that we can mark that commit and parent commits as 'merged'
Expect(`git merge-base "HEAD" "master"`, "26c07b1ab33860a1a7591a0638f9925ccf497ffa", nil),
2021-12-30 13:11:58 +11:00
expectedCommits: []*models.Commit{
{
Sha: "0eea75e8c631fba6b58135697835d58ba4c18dbc",
Name: "better typing for rebase mode",
Status: models.StatusUnpushed,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "(HEAD -> better-tests)",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640826609,
Parents: []string{
"b21997d6b4cbdf84b149",
},
},
{
Sha: "b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164",
Name: "fix logging",
Status: models.StatusPushed,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "(origin/better-tests)",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640824515,
Parents: []string{
"e94e8fc5b6fab4cb755f",
},
},
{
Sha: "e94e8fc5b6fab4cb755f29f1bdb3ee5e001df35c",
Name: "refactor",
Status: models.StatusPushed,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640823749,
Parents: []string{
"d8084cd558925eb7c9c3",
},
},
{
Sha: "d8084cd558925eb7c9c38afeed5725c21653ab90",
Name: "WIP",
Status: models.StatusPushed,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640821426,
Parents: []string{
"65f910ebd85283b5cce9",
},
},
{
Sha: "65f910ebd85283b5cce9bf67d03d3f1a9ea3813a",
Name: "WIP",
Status: models.StatusPushed,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640821275,
Parents: []string{
"26c07b1ab33860a1a759",
},
},
{
Sha: "26c07b1ab33860a1a7591a0638f9925ccf497ffa",
Name: "WIP",
Status: models.StatusMerged,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640750752,
Parents: []string{
"3d4470a6c072208722e5",
},
},
{
Sha: "3d4470a6c072208722e5ae9a54bcb9634959a1c5",
Name: "WIP",
Status: models.StatusMerged,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640748818,
Parents: []string{
"053a66a7be3da43aacdc",
},
},
{
Sha: "053a66a7be3da43aacdc7aa78e1fe757b82c4dd2",
Name: "refactoring the config struct",
Status: models.StatusMerged,
Action: models.ActionNone,
2021-12-30 13:11:58 +11:00
Tags: []string{},
ExtraInfo: "",
2022-05-08 14:23:29 +10:00
AuthorName: "Jesse Duffield",
AuthorEmail: "jessedduffield@gmail.com",
2021-12-30 13:11:58 +11:00
UnixTimestamp: 1640739815,
Parents: []string{
"985fe482e806b172aea4",
},
},
},
2021-12-30 13:11:58 +11:00
expectedError: nil,
},
{
testName: "should not specify order if `log.order` is `default`",
logOrder: "default",
rebaseMode: enums.REBASE_MODE_NONE,
currentBranchName: "master",
opts: GetCommitsOptions{RefName: "HEAD", IncludeRebaseCommits: false},
runner: oscommands.NewFakeRunner(t).
Expect(`git merge-base "HEAD" "HEAD"@{u}`, "b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164", nil).
2023-03-14 01:11:47 +09:00
Expect(`git log "HEAD" --oneline --pretty=format:"%H%x00%at%x00%aN%x00%ae%x00%d%x00%p%x00%s" --abbrev=40 --no-show-signature --`, "", nil),
expectedCommits: []*models.Commit{},
expectedError: nil,
},
{
testName: "should set filter path",
logOrder: "default",
rebaseMode: enums.REBASE_MODE_NONE,
currentBranchName: "master",
opts: GetCommitsOptions{RefName: "HEAD", FilterPath: "src"},
runner: oscommands.NewFakeRunner(t).
Expect(`git merge-base "HEAD" "HEAD"@{u}`, "b21997d6b4cbdf84b149d8e6a2c4d06a8e9ec164", nil).
Expect(`git log "HEAD" --oneline --pretty=format:"%H%x00%at%x00%aN%x00%ae%x00%d%x00%p%x00%s" --abbrev=40 --follow --no-show-signature -- "src"`, "", nil),
expectedCommits: []*models.Commit{},
expectedError: nil,
},
}
2021-12-30 13:11:58 +11:00
for _, scenario := range scenarios {
2022-01-08 15:46:35 +11:00
scenario := scenario
2021-12-30 13:11:58 +11:00
t.Run(scenario.testName, func(t *testing.T) {
common := utils.NewDummyCommon()
common.UserConfig.Git.Log.Order = scenario.logOrder
2021-12-30 13:35:10 +11:00
builder := &CommitLoader{
Common: common,
2021-12-30 17:19:01 +11:00
cmd: oscommands.NewDummyCmdObjBuilder(scenario.runner),
getCurrentBranchInfo: func() (BranchInfo, error) {
return BranchInfo{RefName: scenario.currentBranchName, DisplayName: scenario.currentBranchName, DetachedHead: false}, nil
2021-12-30 13:11:58 +11:00
},
2021-12-30 13:35:10 +11:00
getRebaseMode: func() (enums.RebaseMode, error) { return scenario.rebaseMode, nil },
2021-12-30 13:11:58 +11:00
dotGitDir: ".git",
readFile: func(filename string) ([]byte, error) {
return []byte(""), nil
},
walkFiles: func(root string, fn filepath.WalkFunc) error {
return nil
},
}
commits, err := builder.GetCommits(scenario.opts)
assert.Equal(t, scenario.expectedCommits, commits)
assert.Equal(t, scenario.expectedError, err)
2022-01-26 10:34:56 +11:00
scenario.runner.CheckForMissingCalls()
})
}
}