Adding list bucket tests and fixing inmemory behavior.

This commit is contained in:
Frederick F. Kautz IV 2015-01-29 11:23:03 -08:00
parent 1306543b76
commit 7ca87e06aa
2 changed files with 41 additions and 3 deletions

View File

@ -112,10 +112,11 @@ func (storage *storage) ListObjects(bucket, prefix string, count int) ([]mstorag
} }
func (storage *storage) ListBuckets(prefix string) ([]mstorage.BucketMetadata, error) { func (storage *storage) ListBuckets(prefix string) ([]mstorage.BucketMetadata, error) {
// TODO prefix handling
var results []mstorage.BucketMetadata var results []mstorage.BucketMetadata
for _, bucket := range storage.bucketdata { for key, bucket := range storage.bucketdata {
results = append(results, bucket.metadata) if strings.HasPrefix(key, prefix) {
results = append(results, bucket.metadata)
}
} }
return results, nil return results, nil
} }

View File

@ -16,6 +16,7 @@ func APITestSuite(c *C, create func() Storage) {
testNonExistantBucketOperations(c, create) testNonExistantBucketOperations(c, create)
testBucketRecreateFails(c, create) testBucketRecreateFails(c, create)
testPutObjectInSubdir(c, create) testPutObjectInSubdir(c, create)
testListBuckets(c, create)
} }
func testCreateBucket(c *C, create func() Storage) { func testCreateBucket(c *C, create func() Storage) {
@ -156,3 +157,39 @@ func testPutObjectInSubdir(c *C, create func() Storage) {
c.Assert(int64(len(bytesBuffer.Bytes())), Equals, length) c.Assert(int64(len(bytesBuffer.Bytes())), Equals, length)
c.Assert(err, IsNil) c.Assert(err, IsNil)
} }
func testListBuckets(c *C, create func() Storage) {
storage := create()
// test empty list
buckets, err := storage.ListBuckets("")
c.Assert(len(buckets), Equals, 0)
c.Assert(err, IsNil)
// add one and test exists
err = storage.StoreBucket("bucket1")
c.Assert(err, IsNil)
buckets, err = storage.ListBuckets("")
c.Assert(len(buckets), Equals, 1)
c.Assert(err, IsNil)
// add two and test exists
err = storage.StoreBucket("bucket2")
c.Assert(err, IsNil)
buckets, err = storage.ListBuckets("")
c.Assert(len(buckets), Equals, 2)
c.Assert(err, IsNil)
// add three and test exists + prefix
err = storage.StoreBucket("bucket22")
buckets, err = storage.ListBuckets("")
c.Assert(len(buckets), Equals, 3)
c.Assert(err, IsNil)
buckets, err = storage.ListBuckets("bucket2")
c.Assert(len(buckets), Equals, 2)
c.Assert(err, IsNil)
}