2022-11-10 21:19:29 -05:00
|
|
|
package git_commands
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2022-03-26 21:55:44 +09:00
|
|
|
"strings"
|
2022-01-26 10:34:56 +11:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/commands/models"
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/commands/oscommands"
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/utils"
|
|
|
|
"github.com/sanity-io/litter"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2022-03-26 22:03:32 +09:00
|
|
|
var reflogOutput = strings.Replace(`c3c4b66b64c97ffeecde|1643150483|checkout: moving from A to B|51baa8c1
|
|
|
|
c3c4b66b64c97ffeecde|1643150483|checkout: moving from B to A|51baa8c1
|
|
|
|
c3c4b66b64c97ffeecde|1643150483|checkout: moving from A to B|51baa8c1
|
|
|
|
c3c4b66b64c97ffeecde|1643150483|checkout: moving from master to A|51baa8c1
|
|
|
|
f4ddf2f0d4be4ccc7efa|1643149435|checkout: moving from A to master|51baa8c1
|
2022-03-26 21:55:44 +09:00
|
|
|
`, "|", "\x00", -1)
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
func TestGetReflogCommits(t *testing.T) {
|
|
|
|
type scenario struct {
|
|
|
|
testName string
|
|
|
|
runner *oscommands.FakeCmdObjRunner
|
|
|
|
lastReflogCommit *models.Commit
|
|
|
|
filterPath string
|
|
|
|
expectedCommits []*models.Commit
|
|
|
|
expectedOnlyObtainedNew bool
|
|
|
|
expectedError error
|
|
|
|
}
|
|
|
|
|
|
|
|
scenarios := []scenario{
|
|
|
|
{
|
|
|
|
testName: "no reflog entries",
|
|
|
|
runner: oscommands.NewFakeRunner(t).
|
2022-05-04 19:41:37 +09:00
|
|
|
Expect(`git -c log.showSignature=false log -g --abbrev=40 --format="%h%x00%ct%x00%gs%x00%p"`, "", nil),
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
lastReflogCommit: nil,
|
|
|
|
expectedCommits: []*models.Commit{},
|
|
|
|
expectedOnlyObtainedNew: false,
|
|
|
|
expectedError: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
testName: "some reflog entries",
|
|
|
|
runner: oscommands.NewFakeRunner(t).
|
2022-05-04 19:41:37 +09:00
|
|
|
Expect(`git -c log.showSignature=false log -g --abbrev=40 --format="%h%x00%ct%x00%gs%x00%p"`, reflogOutput, nil),
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
lastReflogCommit: nil,
|
|
|
|
expectedCommits: []*models.Commit{
|
|
|
|
{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from A to B",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from B to A",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from A to B",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from master to A",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
{
|
|
|
|
Sha: "f4ddf2f0d4be4ccc7efa",
|
|
|
|
Name: "checkout: moving from A to master",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643149435,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedOnlyObtainedNew: false,
|
|
|
|
expectedError: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
testName: "some reflog entries where last commit is given",
|
|
|
|
runner: oscommands.NewFakeRunner(t).
|
2022-05-04 19:41:37 +09:00
|
|
|
Expect(`git -c log.showSignature=false log -g --abbrev=40 --format="%h%x00%ct%x00%gs%x00%p"`, reflogOutput, nil),
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
lastReflogCommit: &models.Commit{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from B to A",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
expectedCommits: []*models.Commit{
|
|
|
|
{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from A to B",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedOnlyObtainedNew: true,
|
|
|
|
expectedError: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
testName: "when passing filterPath",
|
|
|
|
runner: oscommands.NewFakeRunner(t).
|
2022-05-04 19:41:37 +09:00
|
|
|
Expect(`git -c log.showSignature=false log -g --abbrev=40 --format="%h%x00%ct%x00%gs%x00%p" --follow -- "path"`, reflogOutput, nil),
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
lastReflogCommit: &models.Commit{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from B to A",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
filterPath: "path",
|
|
|
|
expectedCommits: []*models.Commit{
|
|
|
|
{
|
|
|
|
Sha: "c3c4b66b64c97ffeecde",
|
|
|
|
Name: "checkout: moving from A to B",
|
2023-04-03 12:40:29 +02:00
|
|
|
Status: models.StatusReflog,
|
2022-01-26 10:34:56 +11:00
|
|
|
UnixTimestamp: 1643150483,
|
2022-03-26 22:03:32 +09:00
|
|
|
Parents: []string{"51baa8c1"},
|
2022-01-26 10:34:56 +11:00
|
|
|
},
|
|
|
|
},
|
|
|
|
expectedOnlyObtainedNew: true,
|
|
|
|
expectedError: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
testName: "when command returns error",
|
|
|
|
runner: oscommands.NewFakeRunner(t).
|
2022-05-04 19:41:37 +09:00
|
|
|
Expect(`git -c log.showSignature=false log -g --abbrev=40 --format="%h%x00%ct%x00%gs%x00%p"`, "", errors.New("haha")),
|
2022-01-26 10:34:56 +11:00
|
|
|
|
|
|
|
lastReflogCommit: nil,
|
|
|
|
filterPath: "",
|
|
|
|
expectedCommits: nil,
|
|
|
|
expectedOnlyObtainedNew: false,
|
|
|
|
expectedError: errors.New("haha"),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, scenario := range scenarios {
|
|
|
|
scenario := scenario
|
|
|
|
t.Run(scenario.testName, func(t *testing.T) {
|
|
|
|
builder := &ReflogCommitLoader{
|
|
|
|
Common: utils.NewDummyCommon(),
|
|
|
|
cmd: oscommands.NewDummyCmdObjBuilder(scenario.runner),
|
|
|
|
}
|
|
|
|
|
|
|
|
commits, onlyObtainednew, err := builder.GetReflogCommits(scenario.lastReflogCommit, scenario.filterPath)
|
|
|
|
assert.Equal(t, scenario.expectedOnlyObtainedNew, onlyObtainednew)
|
|
|
|
assert.Equal(t, scenario.expectedError, err)
|
|
|
|
t.Logf("actual commits: \n%s", litter.Sdump(commits))
|
|
|
|
assert.Equal(t, scenario.expectedCommits, commits)
|
|
|
|
|
|
|
|
scenario.runner.CheckForMissingCalls()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|