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.

174 lines
4.3 KiB

package cos
import (
"context"
"encoding/xml"
"fmt"
"net/http"
"reflect"
"testing"
)
func TestObjectService_GetACL(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{
"acl": "",
}
testFormValues(t, r, vs)
fmt.Fprint(w, `<AccessControlPolicy>
<Owner>
<ID>qcs::cam::uin/100000760461:uin/100000760461</ID>
<DisplayName>qcs::cam::uin/100000760461:uin/100000760461</DisplayName>
</Owner>
<AccessControlList>
<Grant>
<Grantee xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="RootAccount">
<ID>qcs::cam::uin/100000760461:uin/100000760461</ID>
<DisplayName>qcs::cam::uin/100000760461:uin/100000760461</DisplayName>
</Grantee>
<Permission>FULL_CONTROL</Permission>
</Grant>
<Grant>
<Grantee xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="RootAccount">
<ID>qcs::cam::uin/100000760461:uin/100000760461</ID>
<DisplayName>qcs::cam::uin/100000760461:uin/100000760461</DisplayName>
</Grantee>
<Permission>READ</Permission>
</Grant>
</AccessControlList>
</AccessControlPolicy>`)
})
ref, _, err := client.Object.GetACL(context.Background(), name)
if err != nil {
t.Fatalf("Object.GetACL returned error: %v", err)
}
want := &ObjectGetACLResult{
XMLName: xml.Name{Local: "AccessControlPolicy"},
Owner: &Owner{
ID: "qcs::cam::uin/100000760461:uin/100000760461",
DisplayName: "qcs::cam::uin/100000760461:uin/100000760461",
},
AccessControlList: []ACLGrant{
{
Grantee: &ACLGrantee{
Type: "RootAccount",
ID: "qcs::cam::uin/100000760461:uin/100000760461",
DisplayName: "qcs::cam::uin/100000760461:uin/100000760461",
},
Permission: "FULL_CONTROL",
},
{
Grantee: &ACLGrantee{
Type: "RootAccount",
ID: "qcs::cam::uin/100000760461:uin/100000760461",
DisplayName: "qcs::cam::uin/100000760461:uin/100000760461",
},
Permission: "READ",
},
},
}
if !reflect.DeepEqual(ref, want) {
t.Errorf("Object.GetACL returned %+v, want %+v", ref, want)
}
}
func TestObjectService_PutACL_with_header_opt(t *testing.T) {
setup()
defer teardown()
opt := &ObjectPutACLOptions{
Header: &ACLHeaderOptions{
XCosACL: "private",
},
}
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodPut)
vs := values{
"acl": "",
}
testFormValues(t, r, vs)
testHeader(t, r, "x-cos-acl", "private")
want := 0
v, _ := r.Body.Read([]byte{})
if !reflect.DeepEqual(v, want) {
t.Errorf("Object.PutACL request body: %#v, want %#v", v, want)
}
})
_, err := client.Object.PutACL(context.Background(), name, opt)
if err != nil {
t.Fatalf("Object.PutACL returned error: %v", err)
}
}
func TestObjectService_PutACL_with_body_opt(t *testing.T) {
setup()
defer teardown()
opt := &ObjectPutACLOptions{
Body: &ACLXml{
Owner: &Owner{
ID: "qcs::cam::uin/100000760461:uin/100000760461",
DisplayName: "qcs::cam::uin/100000760461:uin/100000760461",
},
AccessControlList: []ACLGrant{
{
Grantee: &ACLGrantee{
Type: "RootAccount",
ID: "qcs::cam::uin/100000760461:uin/100000760461",
DisplayName: "qcs::cam::uin/100000760461:uin/100000760461",
},
Permission: "FULL_CONTROL",
},
{
Grantee: &ACLGrantee{
Type: "RootAccount",
ID: "qcs::cam::uin/100000760461:uin/100000760461",
DisplayName: "qcs::cam::uin/100000760461:uin/100000760461",
},
Permission: "READ",
},
},
},
}
name := "test/hello.txt"
mux.HandleFunc("/test/hello.txt", func(w http.ResponseWriter, r *http.Request) {
v := new(ACLXml)
xml.NewDecoder(r.Body).Decode(v)
testMethod(t, r, http.MethodPut)
vs := values{
"acl": "",
}
testFormValues(t, r, vs)
testHeader(t, r, "x-cos-acl", "")
want := opt.Body
want.XMLName = xml.Name{Local: "AccessControlPolicy"}
if !reflect.DeepEqual(v, want) {
t.Errorf("Object.PutACL request body: %+v, want %+v", v, want)
}
})
_, err := client.Object.PutACL(context.Background(), name, opt)
if err != nil {
t.Fatalf("Object.PutACL returned error: %v", err)
}
}