diff --git a/s3tests_boto3/functional/test_s3.py b/s3tests_boto3/functional/test_s3.py index 85dfba16..8d1b7e6f 100644 --- a/s3tests_boto3/functional/test_s3.py +++ b/s3tests_boto3/functional/test_s3.py @@ -1694,6 +1694,24 @@ def test_multi_object_delete(): response = client.list_objects(Bucket=bucket_name) assert 'Contents' not in response +def test_multi_object_delete_empty_list(): + bucket_name = get_new_bucket() + client = get_client() + + e = assert_raises(ClientError, client.delete_objects, Bucket=bucket_name, Delete={'Objects': [], 'Quiet': False}) + status, error_code = _get_status_and_error_code(e.response) + assert status == 400 + assert error_code == 'MalformedXML' + +def test_multi_object_delete_empty_list_access_forbidden(): + bucket_name = get_new_bucket() + alt_client = get_alt_client() + + e = assert_raises(ClientError, alt_client.delete_objects, Bucket=bucket_name, Delete={'Objects': [], 'Quiet': False}) + status, error_code = _get_status_and_error_code(e.response) + assert status == 400 + assert error_code == 'MalformedXML' + @pytest.mark.list_objects_v2 def test_multi_objectv2_delete(): key_names = ['key0', 'key1', 'key2']