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:
@@ -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)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user