git: port over existing commands.refUpdate tests

This commit is contained in:
rick olson 2018-01-05 15:18:17 -07:00
parent 8c1ad56924
commit 140c334db3
2 changed files with 83 additions and 4 deletions

@ -94,8 +94,4 @@ func refCommitish(r *Ref) string {
// copy of env
type Env interface {
Get(key string) (val string, ok bool)
GetAll(key string) (vals []string)
Bool(key string, def bool) (val bool)
Int(key string, def int) (val int)
All() map[string][]string
}

83
git/refs_test.go Normal file

@ -0,0 +1,83 @@
package git
import (
"testing"
"github.com/stretchr/testify/assert"
)
func TestRefUpdateDefault(t *testing.T) {
pushModes := []string{"simple", ""}
for _, pushMode := range pushModes {
env := newEnv(map[string][]string{
"push.default": []string{pushMode},
"branch.left.remote": []string{"ignore"},
"branch.left.merge": []string{"me"},
})
u := NewRefUpdate(env, "origin", ParseRef("refs/heads/left", ""), nil)
assert.Equal(t, "left", u.Right().Name, "pushmode=%q", pushMode)
assert.Equal(t, RefTypeLocalBranch, u.Right().Type, "pushmode=%q", pushMode)
}
}
func TestRefUpdateTrackedDefault(t *testing.T) {
pushModes := []string{"simple", "upstream", "tracking", ""}
for _, pushMode := range pushModes {
env := newEnv(map[string][]string{
"push.default": []string{pushMode},
"branch.left.remote": []string{"origin"},
"branch.left.merge": []string{"refs/heads/tracked"},
})
u := NewRefUpdate(env, "origin", ParseRef("refs/heads/left", ""), nil)
assert.Equal(t, "tracked", u.Right().Name, "pushmode=%s", pushMode)
assert.Equal(t, RefTypeLocalBranch, u.Right().Type, "pushmode=%q", pushMode)
}
}
func TestRefUpdateCurrentDefault(t *testing.T) {
env := newEnv(map[string][]string{
"push.default": []string{"current"},
"branch.left.remote": []string{"origin"},
"branch.left.merge": []string{"tracked"},
})
u := NewRefUpdate(env, "origin", ParseRef("refs/heads/left", ""), nil)
assert.Equal(t, "left", u.Right().Name)
assert.Equal(t, RefTypeLocalBranch, u.Right().Type)
}
func TestRefUpdateExplicitLeftAndRight(t *testing.T) {
u := NewRefUpdate(nil, "", ParseRef("refs/heads/left", "abc123"), ParseRef("refs/heads/right", "def456"))
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())
u = NewRefUpdate(nil, "", ParseRef("refs/heads/left", ""), ParseRef("refs/heads/right", ""))
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())
}
func newEnv(m map[string][]string) *mapEnv {
return &mapEnv{data: m}
}
type mapEnv struct {
data map[string][]string
}
func (m *mapEnv) Get(key string) (string, bool) {
vals, ok := m.data[key]
if ok && len(vals) > 0 {
return vals[0], true
}
return "", false
}