2022-02-10 09:02:40 +00:00
|
|
|
import boto3
|
|
|
|
import pytest
|
|
|
|
from botocore.exceptions import ClientError
|
2023-11-30 15:55:51 +00:00
|
|
|
|
2022-02-10 09:02:40 +00:00
|
|
|
from moto import mock_iot
|
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_register_ca_certificate_simple():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
|
|
|
|
resp = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
)
|
|
|
|
|
2023-07-31 21:50:24 +00:00
|
|
|
assert "certificateArn" in resp
|
|
|
|
assert "certificateId" in resp
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_describe_ca_certificate_unknown():
|
|
|
|
client = boto3.client("iot", region_name="us-east-2")
|
|
|
|
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
client.describe_ca_certificate(certificateId="a" * 70)
|
|
|
|
err = exc.value.response["Error"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert err["Code"] == "ResourceNotFoundException"
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_describe_ca_certificate_simple():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
|
|
|
|
resp = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
)
|
|
|
|
|
|
|
|
describe = client.describe_ca_certificate(certificateId=resp["certificateId"])
|
|
|
|
|
2023-07-31 21:50:24 +00:00
|
|
|
assert "certificateDescription" in describe
|
2022-02-10 09:02:40 +00:00
|
|
|
description = describe["certificateDescription"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert description["certificateArn"] == resp["certificateArn"]
|
|
|
|
assert description["certificateId"] == resp["certificateId"]
|
|
|
|
assert description["status"] == "INACTIVE"
|
|
|
|
assert description["certificatePem"] == "ca_certificate"
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_describe_ca_certificate_advanced():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
|
|
|
|
resp = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
setAsActive=True,
|
|
|
|
registrationConfig={
|
|
|
|
"templateBody": "template_b0dy",
|
|
|
|
"roleArn": "aws:iot:arn:role/asdfqwerwe",
|
|
|
|
},
|
|
|
|
)
|
|
|
|
|
|
|
|
describe = client.describe_ca_certificate(certificateId=resp["certificateId"])
|
|
|
|
|
|
|
|
description = describe["certificateDescription"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert description["certificateArn"] == resp["certificateArn"]
|
|
|
|
assert description["certificateId"] == resp["certificateId"]
|
|
|
|
assert description["status"] == "ACTIVE"
|
|
|
|
assert description["certificatePem"] == "ca_certificate"
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
config = describe["registrationConfig"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert config["templateBody"] == "template_b0dy"
|
|
|
|
assert config["roleArn"] == "aws:iot:arn:role/asdfqwerwe"
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_list_certificates_by_ca():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
|
|
|
|
# create ca
|
|
|
|
ca_cert = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
)
|
|
|
|
ca_cert_id = ca_cert["certificateId"]
|
|
|
|
|
|
|
|
# list certificates should be empty at first
|
|
|
|
certs = client.list_certificates_by_ca(caCertificateId=ca_cert_id)
|
2023-07-31 21:50:24 +00:00
|
|
|
assert certs["certificates"] == []
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
# create one certificate
|
|
|
|
cert1 = client.register_certificate(
|
|
|
|
certificatePem="pem" * 20, caCertificatePem="ca_certificate", setAsActive=False
|
|
|
|
)
|
|
|
|
|
|
|
|
# list certificates should return this
|
|
|
|
certs = client.list_certificates_by_ca(caCertificateId=ca_cert_id)
|
2023-07-31 21:50:24 +00:00
|
|
|
assert len(certs["certificates"]) == 1
|
|
|
|
assert certs["certificates"][0]["certificateId"] == cert1["certificateId"]
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
# create another certificate, without ca
|
|
|
|
client.register_certificate(
|
|
|
|
certificatePem="pam" * 20,
|
|
|
|
caCertificatePem="unknown_ca_certificate",
|
|
|
|
setAsActive=False,
|
|
|
|
)
|
|
|
|
|
|
|
|
# list certificate should still only return the first certificate
|
|
|
|
certs = client.list_certificates_by_ca(caCertificateId=ca_cert_id)
|
2023-07-31 21:50:24 +00:00
|
|
|
assert len(certs["certificates"]) == 1
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_delete_ca_certificate():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
|
|
|
|
cert_id = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
)["certificateId"]
|
|
|
|
|
|
|
|
client.delete_ca_certificate(certificateId=cert_id)
|
|
|
|
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
|
|
client.describe_ca_certificate(certificateId=cert_id)
|
|
|
|
err = exc.value.response["Error"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert err["Code"] == "ResourceNotFoundException"
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_update_ca_certificate__status():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
cert_id = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
registrationConfig={"templateBody": "tb", "roleArn": "my:old_and_busted:arn"},
|
|
|
|
)["certificateId"]
|
|
|
|
|
|
|
|
client.update_ca_certificate(certificateId=cert_id, newStatus="DISABLE")
|
|
|
|
cert = client.describe_ca_certificate(certificateId=cert_id)
|
|
|
|
cert_desc = cert["certificateDescription"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert cert_desc["status"] == "DISABLE"
|
|
|
|
assert cert["registrationConfig"] == {
|
|
|
|
"roleArn": "my:old_and_busted:arn",
|
|
|
|
"templateBody": "tb",
|
|
|
|
}
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_update_ca_certificate__config():
|
|
|
|
client = boto3.client("iot", region_name="us-east-1")
|
|
|
|
cert_id = client.register_ca_certificate(
|
|
|
|
caCertificate="ca_certificate",
|
|
|
|
verificationCertificate="verification_certificate",
|
|
|
|
)["certificateId"]
|
|
|
|
|
|
|
|
client.update_ca_certificate(
|
|
|
|
certificateId=cert_id,
|
|
|
|
registrationConfig={"templateBody": "tb", "roleArn": "my:new_and_fancy:arn"},
|
|
|
|
)
|
|
|
|
cert = client.describe_ca_certificate(certificateId=cert_id)
|
|
|
|
cert_desc = cert["certificateDescription"]
|
2023-07-31 21:50:24 +00:00
|
|
|
assert cert_desc["status"] == "INACTIVE"
|
|
|
|
assert cert["registrationConfig"] == {
|
|
|
|
"roleArn": "my:new_and_fancy:arn",
|
|
|
|
"templateBody": "tb",
|
|
|
|
}
|
2022-02-10 09:02:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_iot
|
|
|
|
def test_get_registration_code():
|
|
|
|
client = boto3.client("iot", region_name="us-west-1")
|
|
|
|
|
|
|
|
resp = client.get_registration_code()
|
2023-07-31 21:50:24 +00:00
|
|
|
assert "registrationCode" in resp
|