More testing

master
Frederick F. Kautz IV 10 years ago
parent 7e61696901
commit 15d5e74837
  1. 6
      pkg/donutbox/donutmem/donutmem.go
  2. 22
      pkg/donutbox/donutmem/donutmem_test.go

@ -59,12 +59,15 @@ func (donutMem donutMem) CreateBucket(b string) error {
donutMem.buckets[b] = &newBucket donutMem.buckets[b] = &newBucket
return nil return nil
} }
func (donutMem donutMem) ListObjects(bucket, prefix string) ([]string, error) { func (donutMem donutMem) ListObjects(bucket, prefix string) ([]string, error) {
return nil, errors.New("Not Implemented") return nil, errors.New("Not Implemented")
} }
func (donutMem donutMem) GetBucketMetadata(bucket, name string) (io.Reader, error) { func (donutMem donutMem) GetBucketMetadata(bucket, name string) (io.Reader, error) {
return nil, errors.New("Not Implemented") return nil, errors.New("Not Implemented")
} }
func (donutMem donutMem) SetBucketMetadata(bucket, name string, metadata io.Reader) error { func (donutMem donutMem) SetBucketMetadata(bucket, name string, metadata io.Reader) error {
return errors.New("Not Implemented") return errors.New("Not Implemented")
} }
@ -117,6 +120,7 @@ func (donutMem donutMem) GetObjectWriter(bucket, key string, column uint, blockS
writer.CloseWithError(errors.New("Bucket does not exist")) writer.CloseWithError(errors.New("Bucket does not exist"))
return writer return writer
} }
func (donutMem donutMem) GetObjectReader(bucket, key string, column int) (io.Reader, error) { func (donutMem donutMem) GetObjectReader(bucket, key string, column int) (io.Reader, error) {
donutMem.lock.RLock() donutMem.lock.RLock()
defer donutMem.lock.RUnlock() defer donutMem.lock.RUnlock()
@ -132,9 +136,11 @@ func (donutMem donutMem) GetObjectReader(bucket, key string, column int) (io.Rea
} }
return nil, errors.New("Bucket not found") return nil, errors.New("Bucket not found")
} }
func (donutMem donutMem) StoreObjectMetadata(bucket, object, name string, reader io.Reader) error { func (donutMem donutMem) StoreObjectMetadata(bucket, object, name string, reader io.Reader) error {
return errors.New("Not Implemented") return errors.New("Not Implemented")
} }
func (donutMem donutMem) GetObjectMetadata(bucket, object, name string) (io.Reader, error) { func (donutMem donutMem) GetObjectMetadata(bucket, object, name string) (io.Reader, error) {
return nil, errors.New("Not Implemented") return nil, errors.New("Not Implemented")
} }

@ -28,13 +28,29 @@ func (s *MySuite) TestAPISuite(c *C) {
count, err = writer.Write([]byte(data)) count, err = writer.Write([]byte(data))
c.Assert(count, Equals, len(data)) c.Assert(count, Equals, len(data))
c.Assert(err, IsNil) c.Assert(err, IsNil)
writer.Close() err = writer.Close()
c.Assert(err, IsNil) c.Assert(err, IsNil)
// time.Sleep(1 * time.Second) // data should be available
reader, err := donut.GetObjectReader("foo", "bar", 0) reader, err := donut.GetObjectReader("foo", "bar", 0)
c.Assert(err, IsNil) c.Assert(err, IsNil)
result, err := ioutil.ReadAll(reader) result, err := ioutil.ReadAll(reader)
c.Assert(result, DeepEquals, []byte(data)) c.Assert(result, DeepEquals, []byte(data))
// try writing, should see error
writer = donut.GetObjectWriter("foo", "bar", 0, 2)
count, err = writer.Write([]byte("different data"))
c.Assert(count, Equals, 0)
c.Assert(err, Not(IsNil))
// try again, should see error
count, err = writer.Write([]byte("different data"))
c.Assert(count, Equals, 0)
c.Assert(err, Not(IsNil))
// data should not change
reader, err = donut.GetObjectReader("foo", "bar", 0)
c.Assert(err, IsNil)
result, err = ioutil.ReadAll(reader)
c.Assert(result, DeepEquals, []byte(data))
} }

Loading…
Cancel
Save