104 lines
3.4 KiB
Python
104 lines
3.4 KiB
Python
|
"""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
|
||
|
from moto.core import ACCOUNT_ID
|
||
|
|
||
|
|
||
|
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,
|
||
|
}
|
||
|
)
|