2022-01-18 20:10:22 +00:00
|
|
|
"""Test that using both s3 and s3control do not interfere"""
|
|
|
|
import boto3
|
|
|
|
import sure # noqa # pylint: disable=unused-import
|
|
|
|
|
|
|
|
from moto import mock_s3, mock_s3control, settings
|
2022-08-13 09:49:43 +00:00
|
|
|
from moto.core import DEFAULT_ACCOUNT_ID as ACCOUNT_ID
|
2022-01-18 20:10:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
if not settings.TEST_SERVER_MODE:
|
|
|
|
|
|
|
|
@mock_s3
|
|
|
|
@mock_s3control
|
|
|
|
def test_pab_are_kept_separate():
|
|
|
|
client = boto3.client("s3control", region_name="us-east-1")
|
|
|
|
s3 = boto3.client("s3", region_name="us-east-1")
|
|
|
|
s3.create_bucket(Bucket="bucket")
|
|
|
|
|
|
|
|
client.put_public_access_block(
|
|
|
|
AccountId=ACCOUNT_ID,
|
|
|
|
PublicAccessBlockConfiguration={
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": True,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": True,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
s3.put_public_access_block(
|
|
|
|
Bucket="bucket",
|
|
|
|
PublicAccessBlockConfiguration={
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": False,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": False,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
pab_from_control = client.get_public_access_block(AccountId=ACCOUNT_ID)
|
|
|
|
pab_from_control.should.have.key("PublicAccessBlockConfiguration").equals(
|
|
|
|
{
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": True,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": True,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
pab_from_s3 = s3.get_public_access_block(Bucket="bucket")
|
|
|
|
pab_from_s3.should.have.key("PublicAccessBlockConfiguration").equals(
|
|
|
|
{
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": False,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": False,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
@mock_s3control
|
|
|
|
@mock_s3
|
|
|
|
def test_pab_are_kept_separate_with_inverse_mocks():
|
|
|
|
client = boto3.client("s3control", region_name="us-east-1")
|
|
|
|
s3 = boto3.client("s3", region_name="us-east-1")
|
|
|
|
s3.create_bucket(Bucket="bucket")
|
|
|
|
|
|
|
|
client.put_public_access_block(
|
|
|
|
AccountId=ACCOUNT_ID,
|
|
|
|
PublicAccessBlockConfiguration={
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": True,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": True,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
s3.put_public_access_block(
|
|
|
|
Bucket="bucket",
|
|
|
|
PublicAccessBlockConfiguration={
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": False,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": False,
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
pab_from_control = client.get_public_access_block(AccountId=ACCOUNT_ID)
|
|
|
|
pab_from_control.should.have.key("PublicAccessBlockConfiguration").equals(
|
|
|
|
{
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": True,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": True,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
pab_from_s3 = s3.get_public_access_block(Bucket="bucket")
|
|
|
|
pab_from_s3.should.have.key("PublicAccessBlockConfiguration").equals(
|
|
|
|
{
|
|
|
|
"BlockPublicAcls": True,
|
|
|
|
"IgnorePublicAcls": False,
|
|
|
|
"BlockPublicPolicy": True,
|
|
|
|
"RestrictPublicBuckets": False,
|
|
|
|
}
|
|
|
|
)
|