blob: a908e54cf0c892765c87ee0e9362a2e3dda3dc01 [file] [log] [blame]
// Copyright 2014 Google LLC
//
// 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 storage
import (
"context"
"net/http"
"testing"
"cloud.google.com/go/internal/testutil"
storagepb "cloud.google.com/go/storage/internal/apiv2/stubs"
)
func TestSetACL(t *testing.T) {
ctx := context.Background()
mt := &mockTransport{}
client := mockClient(t, mt)
bh := &ACLHandle{c: client, bucket: "B"}
oh := &ACLHandle{c: client, bucket: "B", object: "O"}
for _, test := range []struct {
desc string
f func() error
want map[string]interface{}
}{
{
desc: "bucket Set",
f: func() error { return bh.Set(ctx, AllUsers, RoleReader) },
want: map[string]interface{}{
"bucket": "B",
"entity": "allUsers",
"role": "READER",
},
},
{
desc: "object Set",
f: func() error { return oh.Set(ctx, ACLEntity("e"), RoleWriter) },
want: map[string]interface{}{
"bucket": "B",
"entity": "e",
"role": "WRITER",
},
}} {
mt.addResult(&http.Response{StatusCode: 200, Body: bodyReader("{}")}, nil)
if err := test.f(); err != nil {
t.Fatal(err)
}
got := mt.gotJSONBody()
if diff := testutil.Diff(got, test.want); diff != "" {
t.Errorf("%s: %s", test.desc, diff)
}
}
}
func TestToProtoObjectACL(t *testing.T) {
for i, tst := range []struct {
rules []ACLRule
want []*storagepb.ObjectAccessControl
}{
{nil, nil},
{
rules: []ACLRule{
{Entity: "foo", Role: "bar", Domain: "do not copy me!", Email: "donotcopy@"},
{Entity: "bar", Role: "foo", ProjectTeam: &ProjectTeam{ProjectNumber: "1234", Team: "donotcopy"}},
},
want: []*storagepb.ObjectAccessControl{
{Entity: "foo", Role: "bar"},
{Entity: "bar", Role: "foo"},
},
},
} {
got := toProtoObjectACL(tst.rules)
if diff := testutil.Diff(got, tst.want); diff != "" {
t.Errorf("#%d: got(-),want(+):\n%s", i, diff)
}
}
}
func TestFromProtoToObjectACLRules(t *testing.T) {
for i, tst := range []struct {
want []ACLRule
acls []*storagepb.ObjectAccessControl
}{
{nil, nil},
{
want: []ACLRule{
{Entity: "foo", Role: "bar", ProjectTeam: &ProjectTeam{ProjectNumber: "1234", Team: "foo"}},
{Entity: "bar", Role: "foo", EntityID: "baz", Domain: "domain"},
},
acls: []*storagepb.ObjectAccessControl{
{Entity: "foo", Role: "bar", ProjectTeam: &storagepb.ProjectTeam{ProjectNumber: "1234", Team: "foo"}},
{Entity: "bar", Role: "foo", EntityId: "baz", Domain: "domain"},
},
},
} {
got := toObjectACLRulesFromProto(tst.acls)
if diff := testutil.Diff(got, tst.want); diff != "" {
t.Errorf("#%d: got(-),want(+):\n%s", i, diff)
}
}
}