mirror of
https://github.com/minio/mc.git
synced 2025-11-14 23:42:27 +03:00
Finish object handlers for mc commands, updated relevant tests respectively
This commit is contained in:
2
Godeps/Godeps.json
generated
2
Godeps/Godeps.json
generated
@@ -36,7 +36,7 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"ImportPath": "github.com/minio/objectstorage-go",
|
"ImportPath": "github.com/minio/objectstorage-go",
|
||||||
"Rev": "83fd992ca0e7ba5a26317a41c1c298244b0ce83d"
|
"Rev": "0b5d5f294de9f3871ae9cc23bb9753175da8f2dd"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"ImportPath": "github.com/shiena/ansicolor",
|
"ImportPath": "github.com/shiena/ansicolor",
|
||||||
|
|||||||
111
Godeps/_workspace/src/github.com/minio/objectstorage-go/api_test.go
generated
vendored
111
Godeps/_workspace/src/github.com/minio/objectstorage-go/api_test.go
generated
vendored
@@ -17,11 +17,14 @@
|
|||||||
package objectstorage
|
package objectstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"strconv"
|
"strconv"
|
||||||
"testing"
|
"testing"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ExampleGetPartSize() {
|
func ExampleGetPartSize() {
|
||||||
@@ -41,13 +44,16 @@ type bucketHandler struct {
|
|||||||
func (h bucketHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
func (h bucketHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
switch {
|
switch {
|
||||||
case r.Method == "GET":
|
case r.Method == "GET":
|
||||||
if r.URL.Path == "/" {
|
switch {
|
||||||
|
case r.URL.Path == "/":
|
||||||
response := []byte("<ListAllMyBucketsResult xmlns=\"http://doc.s3.amazonaws.com/2006-03-01\"><Buckets><Bucket><Name>bucket</Name><CreationDate>2015-05-20T23:05:09.230Z</CreationDate></Bucket></Buckets><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner></ListAllMyBucketsResult>")
|
response := []byte("<ListAllMyBucketsResult xmlns=\"http://doc.s3.amazonaws.com/2006-03-01\"><Buckets><Bucket><Name>bucket</Name><CreationDate>2015-05-20T23:05:09.230Z</CreationDate></Bucket></Buckets><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner></ListAllMyBucketsResult>")
|
||||||
w.Header().Set("Content-Length", strconv.Itoa(len(response)))
|
w.Header().Set("Content-Length", strconv.Itoa(len(response)))
|
||||||
w.Write(response)
|
w.Write(response)
|
||||||
|
case r.URL.Path == "/bucket":
|
||||||
|
response := []byte("<ListBucketResult xmlns=\"http://doc.s3.amazonaws.com/2006-03-01\"><Contents><ETag>259d04a13802ae09c7e41be50ccc6baa</ETag><Key>object</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Delimiter></Delimiter><EncodingType></EncodingType><IsTruncated>false</IsTruncated><Marker></Marker><MaxKeys>1000</MaxKeys><Name>testbucket</Name><NextMarker></NextMarker><Prefix></Prefix></ListBucketResult>")
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(response)))
|
||||||
|
w.Write(response)
|
||||||
}
|
}
|
||||||
case r.Method == "POST":
|
|
||||||
w.WriteHeader(http.StatusOK)
|
|
||||||
case r.Method == "PUT":
|
case r.Method == "PUT":
|
||||||
switch {
|
switch {
|
||||||
case r.URL.Path == h.resource:
|
case r.URL.Path == h.resource:
|
||||||
@@ -118,6 +124,16 @@ func TestBucketOperations(t *testing.T) {
|
|||||||
t.Errorf("Error")
|
t.Errorf("Error")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for o := range a.ListObjects("bucket", "", true) {
|
||||||
|
if o.Err != nil {
|
||||||
|
t.Fatalf(o.Err.Error())
|
||||||
|
}
|
||||||
|
if o.Data.Key != "object" {
|
||||||
|
t.Errorf("Error")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
err = a.DeleteBucket("bucket")
|
err = a.DeleteBucket("bucket")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("Error")
|
t.Errorf("Error")
|
||||||
@@ -141,10 +157,99 @@ type objectHandler struct {
|
|||||||
func (h objectHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
func (h objectHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
switch {
|
switch {
|
||||||
case r.Method == "PUT":
|
case r.Method == "PUT":
|
||||||
|
length, err := strconv.Atoi(r.Header.Get("Content-Length"))
|
||||||
|
if err != nil {
|
||||||
|
w.WriteHeader(http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
var buffer bytes.Buffer
|
||||||
|
_, err = io.CopyN(&buffer, r.Body, int64(length))
|
||||||
|
if err != nil {
|
||||||
|
w.WriteHeader(http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if !bytes.Equal(h.data, buffer.Bytes()) {
|
||||||
|
w.WriteHeader(http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.Header().Set("ETag", "9af2f8218b150c351ad802c6f3d66abe")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
case r.Method == "HEAD":
|
case r.Method == "HEAD":
|
||||||
|
if r.URL.Path != h.resource {
|
||||||
|
w.WriteHeader(http.StatusNotFound)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(h.data)))
|
||||||
|
w.Header().Set("Last-Modified", time.Now().UTC().Format(http.TimeFormat))
|
||||||
|
w.Header().Set("ETag", "9af2f8218b150c351ad802c6f3d66abe")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
case r.Method == "POST":
|
case r.Method == "POST":
|
||||||
case r.Method == "GET":
|
case r.Method == "GET":
|
||||||
|
if r.URL.Path != h.resource {
|
||||||
|
w.WriteHeader(http.StatusNotFound)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(h.data)))
|
||||||
|
w.Header().Set("Last-Modified", time.Now().UTC().Format(http.TimeFormat))
|
||||||
|
w.Header().Set("ETag", "9af2f8218b150c351ad802c6f3d66abe")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
io.Copy(w, bytes.NewReader(h.data))
|
||||||
case r.Method == "DELETE":
|
case r.Method == "DELETE":
|
||||||
|
if r.URL.Path != h.resource {
|
||||||
|
w.WriteHeader(http.StatusNotFound)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
h.resource = ""
|
||||||
|
h.data = nil
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestObjectOperations(t *testing.T) {
|
||||||
|
object := objectHandler(objectHandler{
|
||||||
|
resource: "/bucket/object",
|
||||||
|
data: []byte("Hello, World"),
|
||||||
|
})
|
||||||
|
server := httptest.NewServer(object)
|
||||||
|
defer server.Close()
|
||||||
|
|
||||||
|
a := New(&Config{Endpoint: server.URL})
|
||||||
|
data := []byte("Hello, World")
|
||||||
|
err := a.PutObject("bucket", "object", uint64(len(data)), bytes.NewReader(data))
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
metadata, err := a.StatObject("bucket", "object")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
if metadata.Key != "object" {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
if metadata.ETag != "9af2f8218b150c351ad802c6f3d66abe" {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
|
||||||
|
reader, metadata, err := a.GetObject("bucket", "object", 0, 0)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
if metadata.Key != "object" {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
if metadata.ETag != "9af2f8218b150c351ad802c6f3d66abe" {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
|
||||||
|
var buffer bytes.Buffer
|
||||||
|
_, err = io.Copy(&buffer, reader)
|
||||||
|
if !bytes.Equal(buffer.Bytes(), data) {
|
||||||
|
t.Fatalf("Error")
|
||||||
|
}
|
||||||
|
|
||||||
|
err = a.DeleteObject("bucket", "object")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
115
api_handlers_test.go
Normal file
115
api_handlers_test.go
Normal file
@@ -0,0 +1,115 @@
|
|||||||
|
/*
|
||||||
|
* Minio Client (C) 2015 Minio, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"path/filepath"
|
||||||
|
"strconv"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
type objectAPIHandler struct {
|
||||||
|
bucket string
|
||||||
|
object map[string][]byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h objectAPIHandler) getHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
switch {
|
||||||
|
case r.URL.Path == "/":
|
||||||
|
response := []byte("<ListAllMyBucketsResult xmlns=\"http://doc.s3.amazonaws.com/2006-03-01\"><Buckets><Bucket><Name>bucket</Name><CreationDate>2015-05-20T23:05:09.230Z</CreationDate></Bucket></Buckets><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner></ListAllMyBucketsResult>")
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(response)))
|
||||||
|
w.Write(response)
|
||||||
|
return
|
||||||
|
case r.URL.Path == "/bucket":
|
||||||
|
response := []byte("<ListBucketResult xmlns=\"http://doc.s3.amazonaws.com/2006-03-01\"><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object0</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object1</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object2</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object3</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object4</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object5</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object6</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Contents><ETag>b1946ac92492d2347c6235b4d2611184</ETag><Key>object7</Key><LastModified>2015-05-21T18:24:21.097Z</LastModified><Size>22061</Size><Owner><ID>minio</ID><DisplayName>minio</DisplayName></Owner><StorageClass>STANDARD</StorageClass></Contents><Delimiter></Delimiter><EncodingType></EncodingType><IsTruncated>false</IsTruncated><Marker></Marker><MaxKeys>1000</MaxKeys><Name>testbucket</Name><NextMarker></NextMarker><Prefix></Prefix></ListBucketResult>")
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(response)))
|
||||||
|
w.Write(response)
|
||||||
|
return
|
||||||
|
case r.URL.Path != "":
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(h.object[filepath.Base(r.URL.Path)])))
|
||||||
|
w.Header().Set("Last-Modified", time.Now().UTC().Format(http.TimeFormat))
|
||||||
|
w.Header().Set("ETag", "b1946ac92492d2347c6235b4d2611184")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
io.Copy(w, bytes.NewReader(h.object[filepath.Base(r.URL.Path)]))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h objectAPIHandler) headHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
switch {
|
||||||
|
case r.URL.Path == "/":
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
return
|
||||||
|
case r.URL.Path == "/bucket":
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
return
|
||||||
|
case r.URL.Path != "":
|
||||||
|
w.Header().Set("Content-Length", strconv.Itoa(len(h.object[filepath.Base(r.URL.Path)])))
|
||||||
|
w.Header().Set("Last-Modified", time.Now().UTC().Format(http.TimeFormat))
|
||||||
|
w.Header().Set("ETag", "b1946ac92492d2347c6235b4d2611184")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h objectAPIHandler) putHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
switch {
|
||||||
|
case r.URL.Path == "/":
|
||||||
|
w.WriteHeader(http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
case r.URL.Path == "/bucket":
|
||||||
|
_, ok := r.URL.Query()["acl"]
|
||||||
|
if ok {
|
||||||
|
if r.Header.Get("x-amz-acl") != "public-read-write" {
|
||||||
|
w.WriteHeader(http.StatusNotImplemented)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
return
|
||||||
|
case r.URL.Path != "":
|
||||||
|
length, err := strconv.Atoi(r.Header.Get("Content-Length"))
|
||||||
|
if err != nil {
|
||||||
|
w.WriteHeader(http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
var buffer bytes.Buffer
|
||||||
|
_, err = io.CopyN(&buffer, r.Body, int64(length))
|
||||||
|
if err != nil {
|
||||||
|
w.WriteHeader(http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
h.object[filepath.Base(r.URL.Path)] = buffer.Bytes()
|
||||||
|
w.Header().Set("ETag", "b1946ac92492d2347c6235b4d2611184")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h objectAPIHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
switch {
|
||||||
|
case r.Method == "GET":
|
||||||
|
h.getHandler(w, r)
|
||||||
|
case r.Method == "HEAD":
|
||||||
|
h.headHandler(w, r)
|
||||||
|
case r.Method == "PUT":
|
||||||
|
h.putHandler(w, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -32,13 +32,17 @@ func (s *CmdTestSuite) TestCatCmd(c *C) {
|
|||||||
defer os.RemoveAll(root)
|
defer os.RemoveAll(root)
|
||||||
|
|
||||||
objectPath := filepath.Join(root, "object1")
|
objectPath := filepath.Join(root, "object1")
|
||||||
|
objectPathServer := server.URL + "/bucket/object1"
|
||||||
data := "hello"
|
data := "hello"
|
||||||
dataLen := len(data)
|
dataLen := len(data)
|
||||||
err = putTarget(objectPath, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
err = putTarget(objectPath, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
|
err = putTarget(objectPathServer, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
sourceConfigMap := make(map[string]*hostConfig)
|
sourceConfigMap := make(map[string]*hostConfig)
|
||||||
sourceConfigMap[objectPath] = &hostConfig{}
|
sourceConfigMap[objectPath] = &hostConfig{}
|
||||||
|
sourceConfigMap[server.URL+"/bucket/object1"] = &hostConfig{}
|
||||||
|
|
||||||
_, err = doCatCmd(sourceConfigMap, false)
|
_, err = doCatCmd(sourceConfigMap, false)
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
|
|||||||
18
cmd_test.go
18
cmd_test.go
@@ -28,7 +28,6 @@ import (
|
|||||||
|
|
||||||
"errors"
|
"errors"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
|
|
||||||
. "github.com/minio/check"
|
. "github.com/minio/check"
|
||||||
@@ -49,20 +48,6 @@ func mustGetMcConfigDir() string {
|
|||||||
|
|
||||||
var server *httptest.Server
|
var server *httptest.Server
|
||||||
|
|
||||||
type objectAPIHandler struct {
|
|
||||||
bucket string
|
|
||||||
object []string
|
|
||||||
data []byte
|
|
||||||
}
|
|
||||||
|
|
||||||
func (h objectAPIHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
|
||||||
switch {
|
|
||||||
case r.Method == "GET":
|
|
||||||
case r.Method == "PUT":
|
|
||||||
case r.Method == "POST":
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *CmdTestSuite) SetUpSuite(c *C) {
|
func (s *CmdTestSuite) SetUpSuite(c *C) {
|
||||||
configDir, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
configDir, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
@@ -71,14 +56,13 @@ func (s *CmdTestSuite) SetUpSuite(c *C) {
|
|||||||
_, err = doConfig("generate", nil)
|
_, err = doConfig("generate", nil)
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
objectAPI := objectAPIHandler(objectAPIHandler{})
|
objectAPI := objectAPIHandler(objectAPIHandler{bucket: "bucket", object: make(map[string][]byte)})
|
||||||
server = httptest.NewServer(objectAPI)
|
server = httptest.NewServer(objectAPI)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *CmdTestSuite) TearDownSuite(c *C) {
|
func (s *CmdTestSuite) TearDownSuite(c *C) {
|
||||||
os.RemoveAll(customConfigDir)
|
os.RemoveAll(customConfigDir)
|
||||||
server.Close()
|
server.Close()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestGetNewClient(c *C) {
|
func (s *CmdTestSuite) TestGetNewClient(c *C) {
|
||||||
|
|||||||
20
cp_test.go
20
cp_test.go
@@ -49,6 +49,11 @@ func (s *CmdTestSuite) TestCpTypeA(c *C) {
|
|||||||
for err := range doCopyCmd([]string{sourcePath}, targetPath, bar) {
|
for err := range doCopyCmd([]string{sourcePath}, targetPath, bar) {
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
targetURL := server.URL + "/bucket/newObject"
|
||||||
|
for err := range doCopyCmd([]string{sourcePath}, targetURL, bar) {
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestCpTypeB(c *C) {
|
func (s *CmdTestSuite) TestCpTypeB(c *C) {
|
||||||
@@ -70,6 +75,11 @@ func (s *CmdTestSuite) TestCpTypeB(c *C) {
|
|||||||
for err := range doCopyCmd([]string{sourcePath}, target, bar) {
|
for err := range doCopyCmd([]string{sourcePath}, target, bar) {
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
targetURL := server.URL + "/bucket"
|
||||||
|
for err := range doCopyCmd([]string{sourcePath}, targetURL, bar) {
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestCpTypeC(c *C) {
|
func (s *CmdTestSuite) TestCpTypeC(c *C) {
|
||||||
@@ -93,6 +103,11 @@ func (s *CmdTestSuite) TestCpTypeC(c *C) {
|
|||||||
for err := range doCopyCmd([]string{source + "..."}, target, bar) {
|
for err := range doCopyCmd([]string{source + "..."}, target, bar) {
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
targetURL := server.URL + "/bucket"
|
||||||
|
for err := range doCopyCmd([]string{source + "..."}, targetURL, bar) {
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestCpTypeD(c *C) {
|
func (s *CmdTestSuite) TestCpTypeD(c *C) {
|
||||||
@@ -127,4 +142,9 @@ func (s *CmdTestSuite) TestCpTypeD(c *C) {
|
|||||||
for err := range doCopyCmd([]string{source1 + "...", source2 + "..."}, target, bar) {
|
for err := range doCopyCmd([]string{source1 + "...", source2 + "..."}, target, bar) {
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
targetURL := server.URL + "/bucket"
|
||||||
|
for err := range doCopyCmd([]string{source1 + "...", source2 + "..."}, targetURL, bar) {
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,6 +50,7 @@ func (s *CmdTestSuite) TestDiffObjects(c *C) {
|
|||||||
|
|
||||||
for diff := range doDiffCmd(objectPath1, objectPath2, false) {
|
for diff := range doDiffCmd(objectPath1, objectPath2, false) {
|
||||||
c.Assert(diff.err, IsNil)
|
c.Assert(diff.err, IsNil)
|
||||||
|
c.Assert(len(diff.message), Equals, 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -78,7 +79,9 @@ func (s *CmdTestSuite) TestDiffDirs(c *C) {
|
|||||||
err = putTarget(objectPath, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
err = putTarget(objectPath, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
for diff := range doDiffCmd(root1, root2, false) {
|
for diff := range doDiffCmd(root1, root2, false) {
|
||||||
c.Assert(diff.err, IsNil)
|
c.Assert(diff.err, IsNil)
|
||||||
|
c.Assert(len(diff.message), Equals, 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
23
ls_test.go
23
ls_test.go
@@ -26,7 +26,7 @@ import (
|
|||||||
. "github.com/minio/check"
|
. "github.com/minio/check"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestLSNonRecursive(c *C) {
|
func (s *CmdTestSuite) TestLSCmd(c *C) {
|
||||||
/// filesystem
|
/// filesystem
|
||||||
root, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
root, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
@@ -40,28 +40,23 @@ func (s *CmdTestSuite) TestLSNonRecursive(c *C) {
|
|||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
clnt, err := getNewClient(root, &hostConfig{}, false)
|
err = doListCmd(root, &hostConfig{}, false, false)
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
err = doList(clnt, root, false)
|
|
||||||
c.Assert(err, IsNil)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestLSRecursive(c *C) {
|
err = doListCmd(root, &hostConfig{}, true, false)
|
||||||
/// filesystem
|
|
||||||
root, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
defer os.RemoveAll(root)
|
|
||||||
|
|
||||||
for i := 0; i < 10; i++ {
|
for i := 0; i < 10; i++ {
|
||||||
objectPath := filepath.Join(root, "object"+strconv.Itoa(i))
|
objectPath := server.URL + "/bucket/object" + strconv.Itoa(i)
|
||||||
data := "hello"
|
data := "hello"
|
||||||
dataLen := len(data)
|
dataLen := len(data)
|
||||||
err = putTarget(objectPath, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
err := putTarget(objectPath, &hostConfig{}, uint64(dataLen), bytes.NewReader([]byte(data)))
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
}
|
}
|
||||||
|
err = doListCmd(server.URL+"/bucket", &hostConfig{}, false, false)
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
clnt, err := getNewClient(root, &hostConfig{}, true)
|
err = doListCmd(server.URL+"/bucket", &hostConfig{}, true, false)
|
||||||
c.Assert(err, IsNil)
|
|
||||||
err = doList(clnt, root, false)
|
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,17 +24,7 @@ import (
|
|||||||
. "github.com/minio/check"
|
. "github.com/minio/check"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestMbCmd(c *C) {
|
func (s *CmdTestSuite) TestMbAndAccessCmd(c *C) {
|
||||||
/// filesystem
|
|
||||||
root, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
|
||||||
c.Assert(err, IsNil)
|
|
||||||
defer os.RemoveAll(root)
|
|
||||||
|
|
||||||
_, err = doMakeBucketCmd(filepath.Join(root, "bucket"), &hostConfig{}, false)
|
|
||||||
c.Assert(err, IsNil)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *CmdTestSuite) TestAccessCmd(c *C) {
|
|
||||||
/// filesystem
|
/// filesystem
|
||||||
root, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
root, err := ioutil.TempDir(os.TempDir(), "cmd-")
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
@@ -45,4 +35,17 @@ func (s *CmdTestSuite) TestAccessCmd(c *C) {
|
|||||||
|
|
||||||
_, err = doUpdateAccessCmd(filepath.Join(root, "bucket"), "public-read-write", &hostConfig{}, false)
|
_, err = doUpdateAccessCmd(filepath.Join(root, "bucket"), "public-read-write", &hostConfig{}, false)
|
||||||
c.Assert(err, IsNil)
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
|
_, err = doUpdateAccessCmd(filepath.Join(root, "bucket"), "invalid", &hostConfig{}, false)
|
||||||
|
c.Assert(err, Not(IsNil))
|
||||||
|
|
||||||
|
_, err = doMakeBucketCmd(server.URL+"/bucket", &hostConfig{}, false)
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
|
_, err = doUpdateAccessCmd(server.URL+"/bucket", "public-read-write", &hostConfig{}, false)
|
||||||
|
c.Assert(err, IsNil)
|
||||||
|
|
||||||
|
_, err = doUpdateAccessCmd(server.URL+"/bucket", "invalid", &hostConfig{}, false)
|
||||||
|
c.Assert(err, Not(IsNil))
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user