aboutsummaryrefslogtreecommitdiffstats
path: root/remote_test.go
diff options
context:
space:
mode:
authorMáximo Cuadros <mcuadros@gmail.com>2016-08-13 22:32:34 +0200
committerMáximo Cuadros <mcuadros@gmail.com>2016-08-13 22:32:34 +0200
commit79087748f60f9aba219624a0fe9f4d33a0b51236 (patch)
tree1c0d17543ad742d1e97276796140f8b398b74802 /remote_test.go
parenta65bcbc63bef24cf219c63d1b8cfb309c95d1c0f (diff)
downloadgo-git-79087748f60f9aba219624a0fe9f4d33a0b51236.tar.gz
Repository.Clone and Remote.Fetch tests and improvements
Diffstat (limited to 'remote_test.go')
-rw-r--r--remote_test.go82
1 files changed, 71 insertions, 11 deletions
diff --git a/remote_test.go b/remote_test.go
index df93b59..798d75d 100644
--- a/remote_test.go
+++ b/remote_test.go
@@ -3,6 +3,7 @@ package git
import (
"gopkg.in/src-d/go-git.v4/clients/http"
"gopkg.in/src-d/go-git.v4/core"
+ "gopkg.in/src-d/go-git.v4/storage/memory"
. "gopkg.in/check.v1"
)
@@ -13,10 +14,29 @@ type RemoteSuite struct {
var _ = Suite(&RemoteSuite{})
+func (s *RemoteSuite) TestNewRemote(c *C) {
+ r, err := NewRemote(RepositoryFixture)
+ c.Assert(err, IsNil)
+ c.Assert(r.Endpoint.String(), Equals, RepositoryFixture)
+}
+
+func (s *RemoteSuite) TestNewRemoteInvalidEndpoint(c *C) {
+ r, err := NewRemote("qux")
+ c.Assert(err, NotNil)
+ c.Assert(r, IsNil)
+}
+
+func (s *RemoteSuite) TestNewRemoteInvalidSchemaEndpoint(c *C) {
+ r, err := NewRemote("qux://foo")
+ c.Assert(err, NotNil)
+ c.Assert(r, IsNil)
+}
+
func (s *RemoteSuite) TestNewAuthenticatedRemote(c *C) {
a := &http.BasicAuth{}
r, err := NewAuthenticatedRemote(RepositoryFixture, a)
c.Assert(err, IsNil)
+ c.Assert(r.Endpoint.String(), Equals, RepositoryFixture)
c.Assert(r.Auth, Equals, a)
}
@@ -26,6 +46,15 @@ func (s *RemoteSuite) TestConnect(c *C) {
c.Assert(r.Connect(), IsNil)
}
+func (s *RemoteSuite) TestInfo(c *C) {
+ r, err := NewRemote(RepositoryFixture)
+ c.Assert(err, IsNil)
+ c.Assert(r.Info(), IsNil)
+ c.Assert(r.Connect(), IsNil)
+ c.Assert(r.Info(), NotNil)
+ c.Assert(r.Info().Capabilities.Get("ofs-delta"), NotNil)
+}
+
func (s *RemoteSuite) TestDefaultBranch(c *C) {
r, err := NewRemote(RepositoryFixture)
r.upSrv = &MockGitUploadPackService{}
@@ -44,7 +73,6 @@ func (s *RemoteSuite) TestCapabilities(c *C) {
c.Assert(r.Capabilities().Get("agent").Values, HasLen, 1)
}
-/*
func (s *RemoteSuite) TestFetch(c *C) {
r, err := NewRemote(RepositoryFixture)
r.upSrv = &MockGitUploadPackService{}
@@ -52,31 +80,63 @@ func (s *RemoteSuite) TestFetch(c *C) {
c.Assert(err, IsNil)
c.Assert(r.Connect(), IsNil)
- req := &common.GitUploadPackRequest{}
- req.Want(r.Head().Hash())
+ sto := memory.NewObjectStorage()
+ err = r.Fetch(sto, &FetchOptions{
+ ReferenceName: core.HEAD,
+ })
- reader, err := r.Fetch(req)
c.Assert(err, IsNil)
+ c.Assert(sto.Objects, HasLen, 28)
+}
- packfileReader := packfile.NewStream(reader)
- d := packfile.NewDecoder(packfileReader)
+func (s *RemoteSuite) TestFetchInvalidBranch(c *C) {
+ r, err := NewRemote(RepositoryFixture)
+ r.upSrv = &MockGitUploadPackService{}
- sto := memory.NewObjectStorage()
- err = d.Decode(sto)
c.Assert(err, IsNil)
- c.Assert(sto.Objects, HasLen, 28)
+ c.Assert(r.Connect(), IsNil)
+
+ sto := memory.NewObjectStorage()
+ err = r.Fetch(sto, &FetchOptions{
+ ReferenceName: core.ReferenceName("qux"),
+ })
+
+ c.Assert(err, NotNil)
}
-*/
func (s *RemoteSuite) TestHead(c *C) {
r, err := NewRemote(RepositoryFixture)
r.upSrv = &MockGitUploadPackService{}
+ c.Assert(err, IsNil)
+ err = r.Connect()
+ c.Assert(err, IsNil)
+ c.Assert(r.Head().Hash(), Equals, core.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
+}
+
+func (s *RemoteSuite) TestRef(c *C) {
+ r, err := NewRemote(RepositoryFixture)
+ r.upSrv = &MockGitUploadPackService{}
c.Assert(err, IsNil)
err = r.Connect()
c.Assert(err, IsNil)
+ ref, err := r.Ref(core.HEAD, false)
c.Assert(err, IsNil)
- c.Assert(r.Head().Hash(), Equals, core.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
+ c.Assert(ref.Name(), Equals, core.HEAD)
+
+ ref, err = r.Ref(core.HEAD, true)
+ c.Assert(err, IsNil)
+ c.Assert(ref.Name(), Equals, core.ReferenceName("refs/heads/master"))
+}
+
+func (s *RemoteSuite) TestRefs(c *C) {
+ r, err := NewRemote(RepositoryFixture)
+ r.upSrv = &MockGitUploadPackService{}
+ c.Assert(err, IsNil)
+
+ err = r.Connect()
+ c.Assert(err, IsNil)
+ c.Assert(r.Refs(), NotNil)
}