203 lines
6.5 KiB
Go
203 lines
6.5 KiB
Go
package config
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/go-git/go-git/v5/plumbing"
|
|
. "gopkg.in/check.v1"
|
|
)
|
|
|
|
type RefSpecSuite struct{}
|
|
|
|
var _ = Suite(&RefSpecSuite{})
|
|
|
|
func Test(t *testing.T) { TestingT(t) }
|
|
|
|
func (s *RefSpecSuite) TestRefSpecIsValid(c *C) {
|
|
spec := RefSpec("+refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.Validate(), Equals, nil)
|
|
|
|
spec = RefSpec("refs/heads/*:refs/remotes/origin/")
|
|
c.Assert(spec.Validate(), Equals, ErrRefSpecMalformedWildcard)
|
|
|
|
spec = RefSpec("refs/heads/master:refs/remotes/origin/master")
|
|
c.Assert(spec.Validate(), Equals, nil)
|
|
|
|
spec = RefSpec(":refs/heads/master")
|
|
c.Assert(spec.Validate(), Equals, nil)
|
|
|
|
spec = RefSpec(":refs/heads/*")
|
|
c.Assert(spec.Validate(), Equals, ErrRefSpecMalformedWildcard)
|
|
|
|
spec = RefSpec(":*")
|
|
c.Assert(spec.Validate(), Equals, ErrRefSpecMalformedWildcard)
|
|
|
|
spec = RefSpec("refs/heads/*")
|
|
c.Assert(spec.Validate(), Equals, ErrRefSpecMalformedSeparator)
|
|
|
|
spec = RefSpec("refs/heads:")
|
|
c.Assert(spec.Validate(), Equals, ErrRefSpecMalformedSeparator)
|
|
|
|
spec = RefSpec("12039e008f9a4e3394f3f94f8ea897785cb09448:refs/heads/foo")
|
|
c.Assert(spec.Validate(), Equals, nil)
|
|
|
|
spec = RefSpec("12039e008f9a4e3394f3f94f8ea897785cb09448:refs/heads/*")
|
|
c.Assert(spec.Validate(), Equals, ErrRefSpecMalformedWildcard)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecIsForceUpdate(c *C) {
|
|
spec := RefSpec("+refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.IsForceUpdate(), Equals, true)
|
|
|
|
spec = RefSpec("refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.IsForceUpdate(), Equals, false)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecIsDelete(c *C) {
|
|
spec := RefSpec(":refs/heads/master")
|
|
c.Assert(spec.IsDelete(), Equals, true)
|
|
|
|
spec = RefSpec("+refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.IsDelete(), Equals, false)
|
|
|
|
spec = RefSpec("refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.IsDelete(), Equals, false)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecIsExactSHA1(c *C) {
|
|
spec := RefSpec("foo:refs/heads/master")
|
|
c.Assert(spec.IsExactSHA1(), Equals, false)
|
|
|
|
spec = RefSpec("12039e008f9a4e3394f3f94f8ea897785cb09448:refs/heads/foo")
|
|
c.Assert(spec.IsExactSHA1(), Equals, true)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecSrc(c *C) {
|
|
spec := RefSpec("refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.Src(), Equals, "refs/heads/*")
|
|
|
|
spec = RefSpec("+refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(spec.Src(), Equals, "refs/heads/*")
|
|
|
|
spec = RefSpec(":refs/heads/master")
|
|
c.Assert(spec.Src(), Equals, "")
|
|
|
|
spec = RefSpec("refs/heads/love+hate:refs/heads/love+hate")
|
|
c.Assert(spec.Src(), Equals, "refs/heads/love+hate")
|
|
|
|
spec = RefSpec("+refs/heads/love+hate:refs/heads/love+hate")
|
|
c.Assert(spec.Src(), Equals, "refs/heads/love+hate")
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecMatch(c *C) {
|
|
spec := RefSpec("refs/heads/master:refs/remotes/origin/master")
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/foo")), Equals, false)
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/master")), Equals, true)
|
|
|
|
spec = RefSpec("+refs/heads/master:refs/remotes/origin/master")
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/foo")), Equals, false)
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/master")), Equals, true)
|
|
|
|
spec = RefSpec(":refs/heads/master")
|
|
c.Assert(spec.Match(plumbing.ReferenceName("")), Equals, true)
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/master")), Equals, false)
|
|
|
|
spec = RefSpec("refs/heads/love+hate:heads/love+hate")
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/love+hate")), Equals, true)
|
|
|
|
spec = RefSpec("+refs/heads/love+hate:heads/love+hate")
|
|
c.Assert(spec.Match(plumbing.ReferenceName("refs/heads/love+hate")), Equals, true)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecMatchGlob(c *C) {
|
|
tests := map[string]map[string]bool{
|
|
"refs/heads/*:refs/remotes/origin/*": {
|
|
"refs/tag/foo": false,
|
|
"refs/heads/foo": true,
|
|
},
|
|
"refs/heads/*bc:refs/remotes/origin/*bc": {
|
|
"refs/heads/abc": true,
|
|
"refs/heads/bc": true,
|
|
"refs/heads/abx": false,
|
|
},
|
|
"refs/heads/a*c:refs/remotes/origin/a*c": {
|
|
"refs/heads/abc": true,
|
|
"refs/heads/ac": true,
|
|
"refs/heads/abx": false,
|
|
},
|
|
"refs/heads/ab*:refs/remotes/origin/ab*": {
|
|
"refs/heads/abc": true,
|
|
"refs/heads/ab": true,
|
|
"refs/heads/xbc": false,
|
|
},
|
|
}
|
|
|
|
for specStr, data := range tests {
|
|
spec := RefSpec(specStr)
|
|
for ref, matches := range data {
|
|
c.Assert(spec.Match(plumbing.ReferenceName(ref)),
|
|
Equals,
|
|
matches,
|
|
Commentf("while matching spec %q against ref %q", specStr, ref),
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecDst(c *C) {
|
|
spec := RefSpec("refs/heads/master:refs/remotes/origin/master")
|
|
c.Assert(
|
|
spec.Dst(plumbing.ReferenceName("refs/heads/master")).String(), Equals,
|
|
"refs/remotes/origin/master",
|
|
)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecDstBlob(c *C) {
|
|
ref := "refs/heads/abc"
|
|
tests := map[string]string{
|
|
"refs/heads/*:refs/remotes/origin/*": "refs/remotes/origin/abc",
|
|
"refs/heads/*bc:refs/remotes/origin/*": "refs/remotes/origin/a",
|
|
"refs/heads/*bc:refs/remotes/origin/*bc": "refs/remotes/origin/abc",
|
|
"refs/heads/a*c:refs/remotes/origin/*": "refs/remotes/origin/b",
|
|
"refs/heads/a*c:refs/remotes/origin/a*c": "refs/remotes/origin/abc",
|
|
"refs/heads/ab*:refs/remotes/origin/*": "refs/remotes/origin/c",
|
|
"refs/heads/ab*:refs/remotes/origin/ab*": "refs/remotes/origin/abc",
|
|
"refs/heads/*abc:refs/remotes/origin/*abc": "refs/remotes/origin/abc",
|
|
"refs/heads/abc*:refs/remotes/origin/abc*": "refs/remotes/origin/abc",
|
|
// for these two cases, git specifically logs:
|
|
// error: * Ignoring funny ref 'refs/remotes/origin/' locally
|
|
// and ignores the ref; go-git does not currently do this validation,
|
|
// but probably should.
|
|
// "refs/heads/*abc:refs/remotes/origin/*": "",
|
|
// "refs/heads/abc*:refs/remotes/origin/*": "",
|
|
}
|
|
|
|
for specStr, dst := range tests {
|
|
spec := RefSpec(specStr)
|
|
c.Assert(spec.Dst(plumbing.ReferenceName(ref)).String(),
|
|
Equals,
|
|
dst,
|
|
Commentf("while getting dst from spec %q with ref %q", specStr, ref),
|
|
)
|
|
}
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestRefSpecReverse(c *C) {
|
|
spec := RefSpec("refs/heads/*:refs/remotes/origin/*")
|
|
c.Assert(
|
|
spec.Reverse(), Equals,
|
|
RefSpec("refs/remotes/origin/*:refs/heads/*"),
|
|
)
|
|
}
|
|
|
|
func (s *RefSpecSuite) TestMatchAny(c *C) {
|
|
specs := []RefSpec{
|
|
"refs/heads/bar:refs/remotes/origin/foo",
|
|
"refs/heads/foo:refs/remotes/origin/bar",
|
|
}
|
|
|
|
c.Assert(MatchAny(specs, plumbing.ReferenceName("refs/heads/foo")), Equals, true)
|
|
c.Assert(MatchAny(specs, plumbing.ReferenceName("refs/heads/bar")), Equals, true)
|
|
c.Assert(MatchAny(specs, plumbing.ReferenceName("refs/heads/master")), Equals, false)
|
|
}
|