aboutsummaryrefslogtreecommitdiffstats
path: root/plumbing/protocol/packp/uppackresp_test.go
diff options
context:
space:
mode:
authorSantiago M. Mola <santi@mola.io>2017-01-04 11:18:41 +0100
committerGitHub <noreply@github.com>2017-01-04 11:18:41 +0100
commit841abfb7dc640755c443432064252907e3e55c95 (patch)
tree8af69dcd3b301a10a3e493e2cd805cdec6dcaecd /plumbing/protocol/packp/uppackresp_test.go
parent90d67bb648ae32d5b1a0f7b1af011da6dfb24315 (diff)
downloadgo-git-841abfb7dc640755c443432064252907e3e55c95.tar.gz
server: add git server implementation (#190)
* server: add generic server implementation (transport-independent), both for git-upload-pack and git-receive-pack. * server: move internal functions to internal/common. * cli: add git-receive-pack and git-upload-pack implementations. * format/packfile: add UpdateObjectStorage function, extracted from Remote. * transport: implement tranport RPC-like, only with git-upload-pack and git-receive-pack methods. Client renamed to Transport. * storer: add storer.Storer interface. * protocol/packp: add UploadPackResponse constructor with packfile. * protocol/packp: fix UploadPackResponse encoding, add tests. * protocol/packp/capability: implement All.
Diffstat (limited to 'plumbing/protocol/packp/uppackresp_test.go')
-rw-r--r--plumbing/protocol/packp/uppackresp_test.go44
1 files changed, 44 insertions, 0 deletions
diff --git a/plumbing/protocol/packp/uppackresp_test.go b/plumbing/protocol/packp/uppackresp_test.go
index c81bb76..c27fdda 100644
--- a/plumbing/protocol/packp/uppackresp_test.go
+++ b/plumbing/protocol/packp/uppackresp_test.go
@@ -7,6 +7,7 @@ import (
"gopkg.in/src-d/go-git.v4/plumbing/protocol/packp/capability"
. "gopkg.in/check.v1"
+ "gopkg.in/src-d/go-git.v4/plumbing"
)
type UploadPackResponseSuite struct{}
@@ -80,3 +81,46 @@ func (s *UploadPackResponseSuite) TestReadNoDecode(c *C) {
c.Assert(err, Equals, ErrUploadPackResponseNotDecoded)
c.Assert(n, Equals, 0)
}
+
+func (s *UploadPackResponseSuite) TestEncodeNAK(c *C) {
+ pf := ioutil.NopCloser(bytes.NewBuffer([]byte("[PACK]")))
+ req := NewUploadPackRequest()
+ res := NewUploadPackResponseWithPackfile(req, pf)
+ defer func() { c.Assert(res.Close(), IsNil) }()
+
+ b := bytes.NewBuffer(nil)
+ c.Assert(res.Encode(b), IsNil)
+
+ expected := "0008NAK\n[PACK]"
+ c.Assert(string(b.Bytes()), Equals, expected)
+}
+
+func (s *UploadPackResponseSuite) TestEncodeDepth(c *C) {
+ pf := ioutil.NopCloser(bytes.NewBuffer([]byte("[PACK]")))
+ req := NewUploadPackRequest()
+ req.Depth = DepthCommits(1)
+
+ res := NewUploadPackResponseWithPackfile(req, pf)
+ defer func() { c.Assert(res.Close(), IsNil) }()
+
+ b := bytes.NewBuffer(nil)
+ c.Assert(res.Encode(b), IsNil)
+
+ expected := "00000008NAK\n[PACK]"
+ c.Assert(string(b.Bytes()), Equals, expected)
+}
+
+func (s *UploadPackResponseSuite) TestEncodeMultiACK(c *C) {
+ pf := ioutil.NopCloser(bytes.NewBuffer([]byte("[PACK]")))
+ req := NewUploadPackRequest()
+
+ res := NewUploadPackResponseWithPackfile(req, pf)
+ defer func() { c.Assert(res.Close(), IsNil) }()
+ res.ACKs = []plumbing.Hash{
+ plumbing.NewHash("5dc01c595e6c6ec9ccda4f6f69c131c0dd945f81"),
+ plumbing.NewHash("5dc01c595e6c6ec9ccda4f6f69c131c0dd945f82"),
+ }
+
+ b := bytes.NewBuffer(nil)
+ c.Assert(res.Encode(b), NotNil)
+}