mirror of
https://github.com/versity/versitygw.git
synced 2026-01-08 04:35:15 +00:00
119 lines
2.9 KiB
Bash
119 lines
2.9 KiB
Bash
#!/usr/bin/env bats
|
|
|
|
# Copyright 2024 Versity Software
|
|
# This file is 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.
|
|
|
|
test_put_bucket_acl_s3cmd() {
|
|
if [[ $DIRECT != "true" ]]; then
|
|
skip "https://github.com/versity/versitygw/issues/695"
|
|
fi
|
|
run setup_bucket "s3cmd" "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
|
|
run put_bucket_ownership_controls "$BUCKET_ONE_NAME" "BucketOwnerPreferred"
|
|
assert_success
|
|
|
|
username=$USERNAME_ONE
|
|
if [[ $DIRECT != "true" ]]; then
|
|
run setup_user "$username" "HIJKLMN" "user"
|
|
assert_success
|
|
fi
|
|
sleep 5
|
|
|
|
run get_check_default_acl_s3cmd "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
|
|
if [[ $DIRECT == "true" ]]; then
|
|
run put_public_access_block_enable_public_acls "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
fi
|
|
run put_bucket_canned_acl_s3cmd "$BUCKET_ONE_NAME" "--acl-public"
|
|
assert_success
|
|
|
|
run get_check_post_change_acl_s3cmd "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
}
|
|
|
|
test_common_put_bucket_acl() {
|
|
if [[ $RECREATE_BUCKETS == "false" ]]; then
|
|
skip "https://github.com/versity/versitygw/issues/716"
|
|
fi
|
|
assert [ $# -eq 1 ]
|
|
|
|
run setup_bucket "$1" "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
|
|
run put_bucket_ownership_controls "$BUCKET_ONE_NAME" "BucketOwnerPreferred"
|
|
assert_success
|
|
|
|
username=$USERNAME_ONE
|
|
run setup_user "$username" "HIJKLMN" "user"
|
|
assert_success
|
|
|
|
run get_check_acl_id "$1" "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
|
|
acl_file="test-acl"
|
|
run create_test_files "$acl_file"
|
|
assert_success
|
|
|
|
if [[ $DIRECT == "true" ]]; then
|
|
grantee="{\"Type\": \"Group\", \"URI\": \"http://acs.amazonaws.com/groups/global/AllUsers\"}"
|
|
else
|
|
grantee="{\"ID\": \"$username\", \"Type\": \"CanonicalUser\"}"
|
|
fi
|
|
|
|
cat <<EOF > "$TEST_FILE_FOLDER"/"$acl_file"
|
|
{
|
|
"Grants": [
|
|
{
|
|
"Grantee": $grantee,
|
|
"Permission": "READ"
|
|
}
|
|
],
|
|
"Owner": {
|
|
"ID": "$AWS_ACCESS_KEY_ID"
|
|
}
|
|
}
|
|
EOF
|
|
|
|
run put_bucket_acl_s3api "$BUCKET_ONE_NAME" "$TEST_FILE_FOLDER"/"$acl_file"
|
|
assert_success
|
|
|
|
run get_check_acl_after_first_put "$1" "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
|
|
cat <<EOF > "$TEST_FILE_FOLDER"/"$acl_file"
|
|
{
|
|
"Grants": [
|
|
{
|
|
"Grantee": {
|
|
"ID": "$username",
|
|
"Type": "CanonicalUser"
|
|
},
|
|
"Permission": "FULL_CONTROL"
|
|
}
|
|
],
|
|
"Owner": {
|
|
"ID": "$AWS_ACCESS_KEY_ID"
|
|
}
|
|
}
|
|
EOF
|
|
|
|
run put_bucket_acl_s3api "$BUCKET_ONE_NAME" "$TEST_FILE_FOLDER"/"$acl_file"
|
|
assert_success
|
|
|
|
run get_check_acl_after_second_put "$1" "$BUCKET_ONE_NAME"
|
|
assert_success
|
|
} |