You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

274 lines
6.1 KiB

package cos
import (
"bytes"
"context"
"encoding/xml"
"fmt"
"io/ioutil"
"net/http"
"reflect"
"testing"
)
func TestObjectService_Get(t *testing.T) {
setup()
defer teardown()
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, "GET")
vs := values{
"response-content-type": "text/html",
}
testFormValues(t, r, vs)
testHeader(t, r, "Range", "bytes=0-3")
fmt.Fprint(w, `hello`)
})
opt := &ObjectGetOptions{
ResponseContentType: "text/html",
Range: "bytes=0-3",
}
resp, err := client.Object.Get(context.Background(), name, opt)
if err != nil {
t.Fatalf("Object.Get returned error: %v", err)
}
b, _ := ioutil.ReadAll(resp.Body)
ref := string(b)
want := "hello"
if !reflect.DeepEqual(ref, want) {
t.Errorf("Object.Get returned %+v, want %+v", ref, want)
}
}
func TestObjectService_Put(t *testing.T) {
setup()
defer teardown()
opt := &ObjectPutOptions{
ObjectPutHeaderOptions: &ObjectPutHeaderOptions{
ContentType: "text/html",
},
ACLHeaderOptions: &ACLHeaderOptions{
XCosACL: "private",
},
}
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodPut)
testHeader(t, r, "x-cos-acl", "private")
testHeader(t, r, "Content-Type", "text/html")
b, _ := ioutil.ReadAll(r.Body)
v := string(b)
want := "hello"
if !reflect.DeepEqual(v, want) {
t.Errorf("Object.Put request body: %#v, want %#v", v, want)
}
})
r := bytes.NewReader([]byte("hello"))
_, err := client.Object.Put(context.Background(), name, r, opt)
if err != nil {
t.Fatalf("Object.Put returned error: %v", err)
}
}
func TestObjectService_Delete(t *testing.T) {
setup()
defer teardown()
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodDelete)
w.WriteHeader(http.StatusNoContent)
})
_, err := client.Object.Delete(context.Background(), name)
if err != nil {
t.Fatalf("Object.Delete returned error: %v", err)
}
}
func TestObjectService_Head(t *testing.T) {
setup()
defer teardown()
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, "HEAD")
testHeader(t, r, "If-Modified-Since", "Mon, 12 Jun 2017 05:36:19 GMT")
})
opt := &ObjectHeadOptions{
IfModifiedSince: "Mon, 12 Jun 2017 05:36:19 GMT",
}
_, err := client.Object.Head(context.Background(), name, opt)
if err != nil {
t.Fatalf("Object.Head returned error: %v", err)
}
}
func TestObjectService_Options(t *testing.T) {
setup()
defer teardown()
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodOptions)
testHeader(t, r, "Access-Control-Request-Method", "PUT")
testHeader(t, r, "Origin", "www.qq.com")
})
opt := &ObjectOptionsOptions{
Origin: "www.qq.com",
AccessControlRequestMethod: "PUT",
}
_, err := client.Object.Options(context.Background(), name, opt)
if err != nil {
t.Fatalf("Object.Options returned error: %v", err)
}
}
// func TestObjectService_Append(t *testing.T) {
// setup()
// defer teardown()
// opt := &ObjectPutOptions{
// ObjectPutHeaderOptions: &ObjectPutHeaderOptions{
// ContentType: "text/html",
// },
// ACLHeaderOptions: &ACLHeaderOptions{
// XCosACL: "private",
// },
// }
// name := "test/hello.txt"
// position := 0
// mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
// vs := values{
// "append": "",
// "position": "0",
// }
// testFormValues(t, r, vs)
// testMethod(t, r, http.MethodPost)
// testHeader(t, r, "x-cos-acl", "private")
// testHeader(t, r, "Content-Type", "text/html")
// b, _ := ioutil.ReadAll(r.Body)
// v := string(b)
// want := "hello"
// if !reflect.DeepEqual(v, want) {
// t.Errorf("Object.Append request body: %#v, want %#v", v, want)
// }
// })
// r := bytes.NewReader([]byte("hello"))
// _, err := client.Object.Append(context.Background(), name, position, r, opt)
// if err != nil {
// t.Fatalf("Object.Append returned error: %v", err)
// }
// }
func TestObjectService_DeleteMulti(t *testing.T) {
setup()
defer teardown()
mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodPost)
vs := values{
"delete": "",
}
testFormValues(t, r, vs)
fmt.Fprint(w, `<DeleteResult>
<Deleted>
<Key>test1</Key>
</Deleted>
<Deleted>
<Key>test3</Key>
</Deleted>
<Deleted>
<Key>test2</Key>
</Deleted>
</DeleteResult>`)
})
opt := &ObjectDeleteMultiOptions{
Objects: []Object{
{
Key: "test1",
},
{
Key: "test3",
},
{
Key: "test2",
},
},
}
ref, _, err := client.Object.DeleteMulti(context.Background(), opt)
if err != nil {
t.Fatalf("Object.DeleteMulti returned error: %v", err)
}
want := &ObjectDeleteMultiResult{
XMLName: xml.Name{Local: "DeleteResult"},
DeletedObjects: []Object{
{
Key: "test1",
},
{
Key: "test3",
},
{
Key: "test2",
},
},
}
if !reflect.DeepEqual(ref, want) {
t.Errorf("Object.DeleteMulti returned %+v, want %+v", ref, want)
}
}
func TestObjectService_Copy(t *testing.T) {
setup()
defer teardown()
mux.HandleFunc("/test.go.copy", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodPut)
fmt.Fprint(w, `<CopyObjectResult>
<ETag>"098f6bcd4621d373cade4e832627b4f6"</ETag>
<LastModified>2017-12-13T14:53:12</LastModified>
</CopyObjectResult>`)
})
sourceURL := "test-1253846586.cos.ap-guangzhou.myqcloud.com/test.source"
ref, _, err := client.Object.Copy(context.Background(), "test.go.copy", sourceURL, nil)
if err != nil {
t.Fatalf("Object.Copy returned error: %v", err)
}
want := &ObjectCopyResult{
XMLName: xml.Name{Local: "CopyObjectResult"},
ETag: `"098f6bcd4621d373cade4e832627b4f6"`,
LastModified: "2017-12-13T14:53:12",
}
if !reflect.DeepEqual(ref, want) {
t.Errorf("Object.Copy returned %+v, want %+v", ref, want)
}
}