mirror of
https://github.com/ceph/s3-tests.git
synced 2024-11-21 23:29:47 +00:00
Merge pull request #404 from flipkart-incubator/aws_sse_s3
rgw/s3_boto3: Add tests for bucket encryption APIs
This commit is contained in:
commit
513ecdfdd0
1 changed files with 83 additions and 0 deletions
|
@ -13218,3 +13218,86 @@ def test_multipart_upload_on_a_bucket_with_policy():
|
||||||
(upload_id, data, parts) = _multipart_upload(bucket_name=bucket_name, key=key, size=objlen, client=client)
|
(upload_id, data, parts) = _multipart_upload(bucket_name=bucket_name, key=key, size=objlen, client=client)
|
||||||
response = client.complete_multipart_upload(Bucket=bucket_name, Key=key, UploadId=upload_id, MultipartUpload={'Parts': parts})
|
response = client.complete_multipart_upload(Bucket=bucket_name, Key=key, UploadId=upload_id, MultipartUpload={'Parts': parts})
|
||||||
eq(response['ResponseMetadata']['HTTPStatusCode'], 200)
|
eq(response['ResponseMetadata']['HTTPStatusCode'], 200)
|
||||||
|
|
||||||
|
|
||||||
|
@attr(resource='bucket')
|
||||||
|
@attr(method='put')
|
||||||
|
@attr(operation='put bucket encryption on bucket')
|
||||||
|
@attr(assertion='succeeds')
|
||||||
|
def test_put_bucket_encryption():
|
||||||
|
bucket_name = get_new_bucket()
|
||||||
|
client = get_client()
|
||||||
|
|
||||||
|
server_side_encryption_conf = {
|
||||||
|
'Rules': [
|
||||||
|
{
|
||||||
|
'ApplyServerSideEncryptionByDefault': {
|
||||||
|
'SSEAlgorithm': 'AES256'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
response = client.put_bucket_encryption(Bucket=bucket_name, ServerSideEncryptionConfiguration=server_side_encryption_conf)
|
||||||
|
eq(response['ResponseMetadata']['HTTPStatusCode'], 200)
|
||||||
|
|
||||||
|
|
||||||
|
@attr(resource='bucket')
|
||||||
|
@attr(method='get')
|
||||||
|
@attr(operation='get bucket encryption on bucket')
|
||||||
|
@attr(assertion='succeeds')
|
||||||
|
def test_get_bucket_encryption():
|
||||||
|
bucket_name = get_new_bucket()
|
||||||
|
client = get_client()
|
||||||
|
|
||||||
|
response_code = ""
|
||||||
|
try:
|
||||||
|
client.get_bucket_encryption(Bucket=bucket_name)
|
||||||
|
except ClientError as e:
|
||||||
|
response_code = e.response['Error']['Code']
|
||||||
|
|
||||||
|
eq(response_code, 'ServerSideEncryptionConfigurationNotFoundError')
|
||||||
|
|
||||||
|
server_side_encryption_conf = {
|
||||||
|
'Rules': [
|
||||||
|
{
|
||||||
|
'ApplyServerSideEncryptionByDefault': {
|
||||||
|
'SSEAlgorithm': 'AES256'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
client.put_bucket_encryption(Bucket=bucket_name, ServerSideEncryptionConfiguration=server_side_encryption_conf)
|
||||||
|
|
||||||
|
response = client.get_bucket_encryption(Bucket=bucket_name)
|
||||||
|
eq(response['ResponseMetadata']['HTTPStatusCode'], 200)
|
||||||
|
eq(response['ServerSideEncryptionConfiguration']['Rules'][0]['ApplyServerSideEncryptionByDefault']['SSEAlgorithm'],
|
||||||
|
server_side_encryption_conf['Rules'][0]['ApplyServerSideEncryptionByDefault']['SSEAlgorithm'])
|
||||||
|
|
||||||
|
|
||||||
|
@attr(resource='bucket')
|
||||||
|
@attr(method='delete')
|
||||||
|
@attr(operation='delete bucket encryption on bucket')
|
||||||
|
@attr(assertion='succeeds')
|
||||||
|
def test_delete_bucket_encryption():
|
||||||
|
bucket_name = get_new_bucket()
|
||||||
|
client = get_client()
|
||||||
|
|
||||||
|
response = client.delete_bucket_encryption(Bucket=bucket_name)
|
||||||
|
eq(response['ResponseMetadata']['HTTPStatusCode'], 204)
|
||||||
|
|
||||||
|
server_side_encryption_conf = {
|
||||||
|
'Rules': [
|
||||||
|
{
|
||||||
|
'ApplyServerSideEncryptionByDefault': {
|
||||||
|
'SSEAlgorithm': 'AES256'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
client.put_bucket_encryption(Bucket=bucket_name, ServerSideEncryptionConfiguration=server_side_encryption_conf)
|
||||||
|
|
||||||
|
response = client.delete_bucket_encryption(Bucket=bucket_name)
|
||||||
|
eq(response['ResponseMetadata']['HTTPStatusCode'], 204)
|
||||||
|
|
Loading…
Reference in a new issue