import boto3 import pytest from boto3 import Session from botocore.client import ClientError from moto import mock_s3control @mock_s3control def test_get_public_access_block_for_account(): from moto.core import DEFAULT_ACCOUNT_ID as ACCOUNT_ID client = boto3.client("s3control", region_name="us-west-2") # With an invalid account ID: with pytest.raises(ClientError) as ce_err: client.get_public_access_block(AccountId="111111111111") assert ce_err.value.response["Error"]["Code"] == "AccessDenied" # Without one defined: with pytest.raises(ClientError) as ce_err: client.get_public_access_block(AccountId=ACCOUNT_ID) assert ( ce_err.value.response["Error"]["Code"] == "NoSuchPublicAccessBlockConfiguration" ) # Put a with an invalid account ID: with pytest.raises(ClientError) as ce_err: client.put_public_access_block( AccountId="111111111111", PublicAccessBlockConfiguration={"BlockPublicAcls": True}, ) assert ce_err.value.response["Error"]["Code"] == "AccessDenied" # Put with an invalid PAB: with pytest.raises(ClientError) as ce_err: client.put_public_access_block( AccountId=ACCOUNT_ID, PublicAccessBlockConfiguration={} ) assert ce_err.value.response["Error"]["Code"] == "InvalidRequest" assert ( "Must specify at least one configuration." in ce_err.value.response["Error"]["Message"] ) # Correct PAB: client.put_public_access_block( AccountId=ACCOUNT_ID, PublicAccessBlockConfiguration={ "BlockPublicAcls": True, "IgnorePublicAcls": True, "BlockPublicPolicy": True, "RestrictPublicBuckets": True, }, ) # Get the correct PAB (for all regions): for region in Session().get_available_regions("s3control"): region_client = boto3.client("s3control", region_name=region) assert region_client.get_public_access_block(AccountId=ACCOUNT_ID)[ "PublicAccessBlockConfiguration" ] == { "BlockPublicAcls": True, "IgnorePublicAcls": True, "BlockPublicPolicy": True, "RestrictPublicBuckets": True, } # Delete with an invalid account ID: with pytest.raises(ClientError) as ce_err: client.delete_public_access_block(AccountId="111111111111") assert ce_err.value.response["Error"]["Code"] == "AccessDenied" # Delete successfully: client.delete_public_access_block(AccountId=ACCOUNT_ID) # Confirm that it's deleted: with pytest.raises(ClientError) as ce_err: client.get_public_access_block(AccountId=ACCOUNT_ID) assert ( ce_err.value.response["Error"]["Code"] == "NoSuchPublicAccessBlockConfiguration" )