1
0
mirror of https://github.com/minio/mc.git synced 2025-11-14 23:42:27 +03:00

Implement fsClient tests - fixes #433

This commit is contained in:
Harshavardhana
2015-04-20 02:34:06 -07:00
parent f0aceedbd3
commit a4c1d26ccb
2 changed files with 120 additions and 26 deletions

View File

@@ -17,8 +17,13 @@
package fs package fs
import ( import (
"bytes"
"crypto/md5"
"encoding/base64"
"io"
"io/ioutil" "io/ioutil"
"os" "os"
"path/filepath"
"testing" "testing"
. "github.com/minio-io/check" . "github.com/minio-io/check"
@@ -30,18 +35,40 @@ type MySuite struct{}
var _ = Suite(&MySuite{}) var _ = Suite(&MySuite{})
// TODO - implement these func (s *MySuite) TestList(c *C) {
func (s *MySuite) TestListBuckets(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-") root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil) c.Assert(err, IsNil)
defer os.RemoveAll(root) defer os.RemoveAll(root)
}
func (s *MySuite) TestListObjects(c *C) { objectPath := filepath.Join(root, "object1")
root, err := ioutil.TempDir(os.TempDir(), "fs-") fsc := GetNewClient(objectPath)
data := "hello"
binarySum := md5.Sum([]byte(data))
etag := base64.StdEncoding.EncodeToString(binarySum[:])
dataLen := int64(len(data))
writer, err := fsc.Put(etag, dataLen)
c.Assert(err, IsNil) c.Assert(err, IsNil)
defer os.RemoveAll(root)
size, err := io.CopyN(writer, bytes.NewBufferString(data), dataLen)
c.Assert(err, IsNil)
c.Assert(size, Equals, dataLen)
objectPath = filepath.Join(root, "object2")
fsc = GetNewClient(objectPath)
writer, err = fsc.Put(etag, dataLen)
c.Assert(err, IsNil)
size, err = io.CopyN(writer, bytes.NewBufferString(data), dataLen)
c.Assert(err, IsNil)
c.Assert(size, Equals, dataLen)
fsc = GetNewClient(root)
items, err := fsc.List()
c.Assert(err, IsNil)
c.Assert(len(items), Equals, 2)
} }
func (s *MySuite) TestPutBucket(c *C) { func (s *MySuite) TestPutBucket(c *C) {
@@ -49,28 +76,96 @@ func (s *MySuite) TestPutBucket(c *C) {
c.Assert(err, IsNil) c.Assert(err, IsNil)
defer os.RemoveAll(root) defer os.RemoveAll(root)
} bucketPath := filepath.Join(root, "bucket")
fsc := GetNewClient(bucketPath)
func (s *MySuite) TestPutObject(c *C) { err = fsc.PutBucket()
root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil) c.Assert(err, IsNil)
defer os.RemoveAll(root)
}
func (s *MySuite) TestGetObject(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil)
defer os.RemoveAll(root)
}
func (s *MySuite) TestStatObject(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil)
defer os.RemoveAll(root)
} }
func (s *MySuite) TestStatBucket(c *C) { func (s *MySuite) TestStatBucket(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-") root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil) c.Assert(err, IsNil)
defer os.RemoveAll(root) defer os.RemoveAll(root)
bucketPath := filepath.Join(root, "bucket")
fsc := GetNewClient(bucketPath)
err = fsc.PutBucket()
c.Assert(err, IsNil)
err = fsc.StatBucket()
c.Assert(err, IsNil)
}
func (s *MySuite) TestPutObject(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil)
defer os.RemoveAll(root)
objectPath := filepath.Join(root, "object")
fsc := GetNewClient(objectPath)
data := "hello"
binarySum := md5.Sum([]byte(data))
etag := base64.StdEncoding.EncodeToString(binarySum[:])
dataLen := int64(len(data))
writer, err := fsc.Put(etag, dataLen)
c.Assert(err, IsNil)
size, err := io.CopyN(writer, bytes.NewBufferString(data), dataLen)
c.Assert(err, IsNil)
c.Assert(size, Equals, dataLen)
}
func (s *MySuite) TestGetObject(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil)
defer os.RemoveAll(root)
objectPath := filepath.Join(root, "object")
fsc := GetNewClient(objectPath)
data := "hello"
binarySum := md5.Sum([]byte(data))
etag := base64.StdEncoding.EncodeToString(binarySum[:])
dataLen := int64(len(data))
writer, err := fsc.Put(etag, dataLen)
c.Assert(err, IsNil)
_, err = io.CopyN(writer, bytes.NewBufferString(data), dataLen)
c.Assert(err, IsNil)
reader, size, _, err := fsc.Get()
c.Assert(err, IsNil)
var results bytes.Buffer
_, err = io.CopyN(&results, reader, size)
c.Assert(err, IsNil)
c.Assert([]byte(data), DeepEquals, results.Bytes())
}
func (s *MySuite) TestGetObjectMetadata(c *C) {
root, err := ioutil.TempDir(os.TempDir(), "fs-")
c.Assert(err, IsNil)
defer os.RemoveAll(root)
objectPath := filepath.Join(root, "object")
fsc := GetNewClient(objectPath)
data := "hello"
binarySum := md5.Sum([]byte(data))
etag := base64.StdEncoding.EncodeToString(binarySum[:])
dataLen := int64(len(data))
writer, err := fsc.Put(etag, dataLen)
c.Assert(err, IsNil)
_, err = io.CopyN(writer, bytes.NewBufferString(data), dataLen)
c.Assert(err, IsNil)
item, err := fsc.GetObjectMetadata()
c.Assert(err, IsNil)
c.Assert(item.Name, Equals, "object")
c.Assert(item.Size, Equals, dataLen)
} }

View File

@@ -182,8 +182,7 @@ func (f *fsClient) PutBucket() error {
// StatBucket - // StatBucket -
func (f *fsClient) StatBucket() error { func (f *fsClient) StatBucket() error {
bucket, _ := f.url2Object() st, err := os.Stat(f.Path)
st, err := os.Stat(bucket)
if os.IsNotExist(err) { if os.IsNotExist(err) {
return iodine.New(client.BucketNotFound{Bucket: ""}, nil) return iodine.New(client.BucketNotFound{Bucket: ""}, nil)
} }