package config import ( "testing" . "gopkg.in/check.v1" "gopkg.in/src-d/go-git.v4/plumbing" ) 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) } 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) 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) }