2017-11-02 19:30:31 +00:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/git-lfs/git-lfs/config"
|
|
|
|
"github.com/git-lfs/git-lfs/git"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRefUpdateDefault(t *testing.T) {
|
|
|
|
pushModes := []string{"simple", ""}
|
|
|
|
for _, pushMode := range pushModes {
|
|
|
|
cfg := config.NewFrom(config.Values{
|
|
|
|
Git: map[string][]string{
|
|
|
|
"push.default": []string{pushMode},
|
|
|
|
"branch.left.remote": []string{"ignore"},
|
|
|
|
"branch.left.merge": []string{"me"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2017-11-08 22:04:40 +00:00
|
|
|
u := newRefUpdate(cfg.Git, "origin", git.ParseRef("refs/heads/left", ""), nil)
|
2017-11-02 19:30:31 +00:00
|
|
|
assert.Equal(t, "left", u.Right().Name, "pushmode=%q", pushMode)
|
2017-11-08 22:04:40 +00:00
|
|
|
assert.Equal(t, git.RefTypeLocalBranch, u.Right().Type, "pushmode=%q", pushMode)
|
2017-11-02 19:30:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRefUpdateTrackedDefault(t *testing.T) {
|
|
|
|
pushModes := []string{"simple", "upstream", "tracking", ""}
|
|
|
|
for _, pushMode := range pushModes {
|
|
|
|
cfg := config.NewFrom(config.Values{
|
|
|
|
Git: map[string][]string{
|
|
|
|
"push.default": []string{pushMode},
|
|
|
|
"branch.left.remote": []string{"origin"},
|
2017-11-08 22:04:40 +00:00
|
|
|
"branch.left.merge": []string{"refs/heads/tracked"},
|
2017-11-02 19:30:31 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2017-11-08 22:04:40 +00:00
|
|
|
u := newRefUpdate(cfg.Git, "origin", git.ParseRef("refs/heads/left", ""), nil)
|
2017-11-02 19:30:31 +00:00
|
|
|
assert.Equal(t, "tracked", u.Right().Name, "pushmode=%s", pushMode)
|
2017-11-08 22:04:40 +00:00
|
|
|
assert.Equal(t, git.RefTypeLocalBranch, u.Right().Type, "pushmode=%q", pushMode)
|
2017-11-02 19:30:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRefUpdateCurrentDefault(t *testing.T) {
|
|
|
|
cfg := config.NewFrom(config.Values{
|
|
|
|
Git: map[string][]string{
|
|
|
|
"push.default": []string{"current"},
|
|
|
|
"branch.left.remote": []string{"origin"},
|
|
|
|
"branch.left.merge": []string{"tracked"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2017-11-08 22:04:40 +00:00
|
|
|
u := newRefUpdate(cfg.Git, "origin", git.ParseRef("refs/heads/left", ""), nil)
|
2017-11-02 19:30:31 +00:00
|
|
|
assert.Equal(t, "left", u.Right().Name)
|
2017-11-08 22:04:40 +00:00
|
|
|
assert.Equal(t, git.RefTypeLocalBranch, u.Right().Type)
|
2017-11-02 19:30:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestRefUpdateExplicitLeftAndRight(t *testing.T) {
|
2017-11-08 22:04:40 +00:00
|
|
|
u := newRefUpdate(nil, "", git.ParseRef("refs/heads/left", "abc123"), git.ParseRef("refs/heads/right", "def456"))
|
2017-11-02 19:30:31 +00:00
|
|
|
assert.Equal(t, "left", u.Left().Name)
|
|
|
|
assert.Equal(t, "abc123", u.Left().Sha)
|
|
|
|
assert.Equal(t, "abc123", u.LeftCommitish())
|
|
|
|
assert.Equal(t, "right", u.Right().Name)
|
|
|
|
assert.Equal(t, "def456", u.Right().Sha)
|
|
|
|
assert.Equal(t, "def456", u.RightCommitish())
|
|
|
|
|
2017-11-08 22:04:40 +00:00
|
|
|
u = newRefUpdate(nil, "", git.ParseRef("refs/heads/left", ""), git.ParseRef("refs/heads/right", ""))
|
2017-11-02 19:30:31 +00:00
|
|
|
assert.Equal(t, "left", u.Left().Name)
|
|
|
|
assert.Equal(t, "", u.Left().Sha)
|
|
|
|
assert.Equal(t, "left", u.LeftCommitish())
|
|
|
|
assert.Equal(t, "right", u.Right().Name)
|
|
|
|
assert.Equal(t, "", u.Right().Sha)
|
|
|
|
assert.Equal(t, "right", u.RightCommitish())
|
|
|
|
}
|