2023-08-24 07:54:32 +00:00
|
|
|
import boto3
|
|
|
|
import json
|
|
|
|
|
|
|
|
from moto import mock_iam
|
|
|
|
|
|
|
|
|
|
|
|
# Test IAM User Inline Policy
|
|
|
|
def test_policies_are_not_kept_after_mock_ends():
|
|
|
|
with mock_iam():
|
2023-09-14 08:49:53 +00:00
|
|
|
iam_client = boto3.client("iam", "us-east-1")
|
2023-08-24 07:54:32 +00:00
|
|
|
role_name = "test"
|
|
|
|
assume_role_policy_document = {
|
|
|
|
"Version": "2012-10-17",
|
|
|
|
"Statement": {
|
|
|
|
"Effect": "Allow",
|
|
|
|
"Principal": {"AWS": "*"},
|
|
|
|
"Action": "sts:AssumeRole",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
iam_client.create_role(
|
|
|
|
RoleName=role_name,
|
|
|
|
AssumeRolePolicyDocument=json.dumps(assume_role_policy_document),
|
|
|
|
)
|
|
|
|
iam_client.attach_role_policy(
|
|
|
|
RoleName=role_name,
|
|
|
|
PolicyArn="arn:aws:iam::aws:policy/ReadOnlyAccess",
|
|
|
|
)
|
|
|
|
|
|
|
|
iam_policies = iam_client.list_policies(Scope="AWS", OnlyAttached=True)[
|
|
|
|
"Policies"
|
|
|
|
]
|
|
|
|
assert len(iam_policies) == 1
|
|
|
|
assert iam_policies[0]["Arn"] == "arn:aws:iam::aws:policy/ReadOnlyAccess"
|
|
|
|
assert iam_client.list_roles()["Roles"][0]["RoleName"] == "test"
|
|
|
|
|
|
|
|
with mock_iam():
|
|
|
|
resp = iam_client.list_policies(Scope="AWS", OnlyAttached=True)
|
|
|
|
assert len(resp["Policies"]) == 0
|