aboutsummaryrefslogtreecommitdiffstats
path: root/plumbing/transport/test/common.go
diff options
context:
space:
mode:
authorSantiago M. Mola <santi@mola.io>2016-12-09 14:44:03 +0100
committerGitHub <noreply@github.com>2016-12-09 14:44:03 +0100
commit0e1a52757a3938e97cf7d31e0dff3c9949001763 (patch)
tree8b998fdc3eaaf6b2d6c69a125759a778664207a5 /plumbing/transport/test/common.go
parent4f16cc925238aae81586e917d26b8ff6b6a340bd (diff)
downloadgo-git-0e1a52757a3938e97cf7d31e0dff3c9949001763.tar.gz
transport: add git-send-pack support to local/ssh. (#163)
* protocol/packp: add Packfile field to ReferenceUpdateRequest. * protocol/packp: add NewReferenceUpdateRequestFromCapabilities. * NewReferenceUpdateRequestFromCapabilities can be used to create a ReferenceUpdateRequest with initial capabilities compatible with the server. * protocol/packp: fix new line handling on report status. * transport/file: test error on unexisting command.
Diffstat (limited to 'plumbing/transport/test/common.go')
-rw-r--r--plumbing/transport/test/common.go196
1 files changed, 0 insertions, 196 deletions
diff --git a/plumbing/transport/test/common.go b/plumbing/transport/test/common.go
deleted file mode 100644
index 2984154..0000000
--- a/plumbing/transport/test/common.go
+++ /dev/null
@@ -1,196 +0,0 @@
-// Package test implements common test suite for different transport
-// implementations.
-//
-package test
-
-import (
- "bytes"
- "io"
- "io/ioutil"
-
- "gopkg.in/src-d/go-git.v4/plumbing"
- "gopkg.in/src-d/go-git.v4/plumbing/format/packfile"
- "gopkg.in/src-d/go-git.v4/plumbing/protocol/packp"
- "gopkg.in/src-d/go-git.v4/plumbing/transport"
- "gopkg.in/src-d/go-git.v4/storage/memory"
-
- . "gopkg.in/check.v1"
- "gopkg.in/src-d/go-git.v4/plumbing/protocol/packp/capability"
-)
-
-type FetchPackSuite struct {
- Endpoint transport.Endpoint
- EmptyEndpoint transport.Endpoint
- NonExistentEndpoint transport.Endpoint
- Client transport.Client
-}
-
-func (s *FetchPackSuite) TestInfoEmpty(c *C) {
- r, err := s.Client.NewFetchPackSession(s.EmptyEndpoint)
- c.Assert(err, IsNil)
- info, err := r.AdvertisedReferences()
- c.Assert(err, Equals, transport.ErrEmptyRemoteRepository)
- c.Assert(info, IsNil)
-}
-
-func (s *FetchPackSuite) TestInfoNotExists(c *C) {
- r, err := s.Client.NewFetchPackSession(s.NonExistentEndpoint)
- c.Assert(err, IsNil)
- info, err := r.AdvertisedReferences()
- c.Assert(err, Equals, transport.ErrRepositoryNotFound)
- c.Assert(info, IsNil)
-
- r, err = s.Client.NewFetchPackSession(s.NonExistentEndpoint)
- c.Assert(err, IsNil)
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
- reader, err := r.FetchPack(req)
- c.Assert(err, Equals, transport.ErrRepositoryNotFound)
- c.Assert(reader, IsNil)
-}
-
-func (s *FetchPackSuite) TestCallAdvertisedReferenceTwice(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- ar1, err := r.AdvertisedReferences()
- c.Assert(err, IsNil)
- c.Assert(ar1, NotNil)
- ar2, err := r.AdvertisedReferences()
- c.Assert(err, IsNil)
- c.Assert(ar2, DeepEquals, ar1)
-}
-
-func (s *FetchPackSuite) TestDefaultBranch(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- info, err := r.AdvertisedReferences()
- c.Assert(err, IsNil)
- symrefs := info.Capabilities.Get(capability.SymRef)
- c.Assert(symrefs, HasLen, 1)
- c.Assert(symrefs[0], Equals, "HEAD:refs/heads/master")
-}
-
-func (s *FetchPackSuite) TestAdvertisedReferencesFilterUnsupported(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- info, err := r.AdvertisedReferences()
- c.Assert(err, IsNil)
- c.Assert(info.Capabilities.Supports(capability.MultiACK), Equals, false)
-}
-
-func (s *FetchPackSuite) TestCapabilities(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- info, err := r.AdvertisedReferences()
- c.Assert(err, IsNil)
- c.Assert(info.Capabilities.Get(capability.Agent), HasLen, 1)
-}
-
-func (s *FetchPackSuite) TestFullFetchPack(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- info, err := r.AdvertisedReferences()
- c.Assert(err, IsNil)
- c.Assert(info, NotNil)
-
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
-
- reader, err := r.FetchPack(req)
- c.Assert(err, IsNil)
-
- s.checkObjectNumber(c, reader, 28)
-}
-
-func (s *FetchPackSuite) TestFetchPack(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
-
- reader, err := r.FetchPack(req)
- c.Assert(err, IsNil)
-
- s.checkObjectNumber(c, reader, 28)
-}
-
-func (s *FetchPackSuite) TestFetchPackInvalidReq(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
- req.Capabilities.Set(capability.Sideband)
- req.Capabilities.Set(capability.Sideband64k)
-
- _, err = r.FetchPack(req)
- c.Assert(err, NotNil)
-}
-
-func (s *FetchPackSuite) TestFetchPackNoChanges(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
- req.Haves = append(req.Haves, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
-
- reader, err := r.FetchPack(req)
- c.Assert(err, Equals, transport.ErrEmptyUploadPackRequest)
- c.Assert(reader, IsNil)
-}
-
-func (s *FetchPackSuite) TestFetchPackMulti(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
- defer func() { c.Assert(r.Close(), IsNil) }()
-
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("6ecf0ef2c2dffb796033e5a02219af86ec6584e5"))
- req.Wants = append(req.Wants, plumbing.NewHash("e8d3ffab552895c19b9fcf7aa264d277cde33881"))
-
- reader, err := r.FetchPack(req)
- c.Assert(err, IsNil)
-
- s.checkObjectNumber(c, reader, 31)
-}
-
-func (s *FetchPackSuite) TestFetchError(c *C) {
- r, err := s.Client.NewFetchPackSession(s.Endpoint)
- c.Assert(err, IsNil)
-
- req := packp.NewUploadPackRequest()
- req.Wants = append(req.Wants, plumbing.NewHash("1111111111111111111111111111111111111111"))
-
- reader, err := r.FetchPack(req)
- c.Assert(err, Equals, transport.ErrEmptyUploadPackRequest)
- c.Assert(reader, IsNil)
-
- //XXX: We do not test Close error, since implementations might return
- // different errors if a previous error was found.
-}
-
-func (s *FetchPackSuite) checkObjectNumber(c *C, r io.Reader, n int) {
- b, err := ioutil.ReadAll(r)
- c.Assert(err, IsNil)
- buf := bytes.NewBuffer(b)
- scanner := packfile.NewScanner(buf)
- storage := memory.NewStorage()
- d, err := packfile.NewDecoder(scanner, storage)
- c.Assert(err, IsNil)
- _, err = d.Decode()
- c.Assert(err, IsNil)
- c.Assert(len(storage.Objects), Equals, n)
-}