2023-06-28 13:37:45 +00:00
|
|
|
import boto3
|
|
|
|
import pytest
|
|
|
|
from botocore.exceptions import ClientError
|
2023-11-30 15:55:51 +00:00
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
from moto import mock_aws
|
2023-06-28 13:37:45 +00:00
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2023-06-28 13:37:45 +00:00
|
|
|
def test_create_origin_access_control():
|
|
|
|
cf = boto3.client("cloudfront", "us-east-1")
|
|
|
|
|
|
|
|
oac_list = cf.list_origin_access_controls()["OriginAccessControlList"]
|
|
|
|
assert oac_list["Items"] == []
|
|
|
|
|
|
|
|
oac_input = {
|
|
|
|
"Name": "my_oac",
|
|
|
|
"SigningProtocol": "sigv4",
|
|
|
|
"SigningBehavior": "always",
|
|
|
|
"OriginAccessControlOriginType": "s3",
|
|
|
|
}
|
|
|
|
resp = cf.create_origin_access_control(OriginAccessControlConfig=oac_input)[
|
|
|
|
"OriginAccessControl"
|
|
|
|
]
|
|
|
|
control_id = resp.pop("Id")
|
|
|
|
|
|
|
|
assert control_id is not None
|
|
|
|
assert resp["OriginAccessControlConfig"] == oac_input
|
|
|
|
|
|
|
|
resp = cf.get_origin_access_control(Id=control_id)["OriginAccessControl"]
|
|
|
|
assert resp.pop("Id") is not None
|
|
|
|
assert resp["OriginAccessControlConfig"] == oac_input
|
|
|
|
|
|
|
|
oac_list = cf.list_origin_access_controls()["OriginAccessControlList"]
|
|
|
|
assert oac_list["Items"][0].pop("Id") == control_id
|
|
|
|
assert oac_list["Items"][0] == oac_input
|
|
|
|
|
|
|
|
cf.delete_origin_access_control(Id=control_id)
|
|
|
|
|
|
|
|
oac_list = cf.list_origin_access_controls()["OriginAccessControlList"]
|
|
|
|
assert oac_list["Items"] == []
|
|
|
|
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
cf.get_origin_access_control(Id=control_id)
|
|
|
|
err = exc.value.response["Error"]
|
|
|
|
assert err["Code"] == "NoSuchOriginAccessControl"
|
|
|
|
assert err["Message"] == "The specified origin access control does not exist."
|
|
|
|
|
|
|
|
|
2024-01-07 12:03:33 +00:00
|
|
|
@mock_aws
|
2023-06-28 13:37:45 +00:00
|
|
|
def test_update_origin_access_control():
|
|
|
|
# http://localhost:5000/2020-05-31/origin-access-control/DE53MREVCPIFL/config
|
|
|
|
cf = boto3.client("cloudfront", "us-east-1")
|
|
|
|
oac_input = {
|
|
|
|
"Name": "my_oac",
|
|
|
|
"SigningProtocol": "sigv4",
|
|
|
|
"SigningBehavior": "always",
|
|
|
|
"OriginAccessControlOriginType": "s3",
|
|
|
|
}
|
|
|
|
resp = cf.create_origin_access_control(OriginAccessControlConfig=oac_input)[
|
|
|
|
"OriginAccessControl"
|
|
|
|
]
|
|
|
|
control_id = resp.pop("Id")
|
|
|
|
|
|
|
|
oac_input["Description"] = "updated"
|
|
|
|
control = cf.update_origin_access_control(
|
|
|
|
Id=control_id, OriginAccessControlConfig=oac_input
|
|
|
|
)["OriginAccessControl"]
|
|
|
|
assert control["Id"] == control_id
|
|
|
|
assert control["OriginAccessControlConfig"] == oac_input
|