git-lfs/test/git-lfs-test-server-api/testdownload.go

126 lines
3.3 KiB
Go
Raw Normal View History

2015-11-25 15:00:04 +00:00
package main
import (
"bytes"
"errors"
"fmt"
2015-11-26 09:46:39 +00:00
2016-11-15 17:01:18 +00:00
"github.com/git-lfs/git-lfs/tools"
"github.com/git-lfs/git-lfs/tq"
2015-11-25 15:00:04 +00:00
)
// "download" - all present
func downloadAllExist(manifest *tq.Manifest, oidsExist, oidsMissing []TestObject) error {
retobjs, err := callBatchApi(manifest, tq.Download, oidsExist)
2015-11-25 15:00:04 +00:00
if err != nil {
return err
}
if len(retobjs) != len(oidsExist) {
return fmt.Errorf("Incorrect number of returned objects, expected %d, got %d", len(oidsExist), len(retobjs))
}
var errbuf bytes.Buffer
for _, o := range retobjs {
rel, _ := o.Rel("download")
if rel == nil {
2015-11-25 15:00:04 +00:00
errbuf.WriteString(fmt.Sprintf("Missing download link for %s\n", o.Oid))
}
}
if errbuf.Len() > 0 {
return errors.New(errbuf.String())
}
return nil
}
// "download" - all missing (test includes 404 error entry)
func downloadAllMissing(manifest *tq.Manifest, oidsExist, oidsMissing []TestObject) error {
retobjs, err := callBatchApi(manifest, tq.Download, oidsMissing)
2015-11-25 15:00:04 +00:00
if err != nil {
return err
}
if len(retobjs) != len(oidsMissing) {
return fmt.Errorf("Incorrect number of returned objects, expected %d, got %d", len(oidsMissing), len(retobjs))
2015-11-25 15:00:04 +00:00
}
var errbuf bytes.Buffer
for _, o := range retobjs {
link, _ := o.Rel("download")
if link != nil {
2015-11-25 15:00:04 +00:00
errbuf.WriteString(fmt.Sprintf("Download link should not exist for %s, was %s\n", o.Oid, link))
}
if o.Error == nil {
errbuf.WriteString(fmt.Sprintf("Download should include an error for missing object %s\n", o.Oid))
2015-11-25 15:00:04 +00:00
} else if o.Error.Code != 404 {
errbuf.WriteString(fmt.Sprintf("Download error code for missing object %s should be 404, got %d\n", o.Oid, o.Error.Code))
}
}
if errbuf.Len() > 0 {
return errors.New(errbuf.String())
}
return nil
}
2015-11-26 09:46:39 +00:00
// "download" - mixture
func downloadMixed(manifest *tq.Manifest, oidsExist, oidsMissing []TestObject) error {
2016-07-07 16:16:13 +00:00
existSet := tools.NewStringSetWithCapacity(len(oidsExist))
2015-11-26 11:46:13 +00:00
for _, o := range oidsExist {
existSet.Add(o.Oid)
}
2016-07-07 16:16:13 +00:00
missingSet := tools.NewStringSetWithCapacity(len(oidsMissing))
2015-11-26 11:46:13 +00:00
for _, o := range oidsMissing {
missingSet.Add(o.Oid)
2015-11-26 09:46:39 +00:00
}
2015-11-26 11:46:13 +00:00
calloids := interleaveTestData(oidsExist, oidsMissing)
retobjs, err := callBatchApi(manifest, tq.Download, calloids)
2015-11-26 09:46:39 +00:00
if err != nil {
return err
}
2015-11-26 11:46:13 +00:00
count := len(oidsExist) + len(oidsMissing)
2015-11-26 09:46:39 +00:00
if len(retobjs) != count {
return fmt.Errorf("Incorrect number of returned objects, expected %d, got %d", count, len(retobjs))
}
var errbuf bytes.Buffer
for _, o := range retobjs {
link, _ := o.Rel("download")
2015-11-26 09:46:39 +00:00
if missingSet.Contains(o.Oid) {
if link != nil {
2015-11-26 09:46:39 +00:00
errbuf.WriteString(fmt.Sprintf("Download link should not exist for %s, was %s\n", o.Oid, link))
}
if o.Error == nil {
2015-11-26 10:31:05 +00:00
errbuf.WriteString(fmt.Sprintf("Download should include an error for missing object %s", o.Oid))
2015-11-26 09:46:39 +00:00
} else if o.Error.Code != 404 {
errbuf.WriteString(fmt.Sprintf("Download error code for missing object %s should be 404, got %d\n", o.Oid, o.Error.Code))
}
}
if existSet.Contains(o.Oid) && link == nil {
2015-11-26 09:46:39 +00:00
errbuf.WriteString(fmt.Sprintf("Missing download link for %s\n", o.Oid))
}
}
if errbuf.Len() > 0 {
return errors.New(errbuf.String())
}
return nil
}
2015-11-25 15:00:04 +00:00
func init() {
addTest("Test download: all existing", downloadAllExist)
addTest("Test download: all missing", downloadAllMissing)
2015-11-26 09:46:39 +00:00
addTest("Test download: mixed", downloadMixed)
2015-11-25 15:00:04 +00:00
}