| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | from __future__ import unicode_literals | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import os | 
					
						
							|  |  |  | import boto3 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  | from freezegun import freeze_time | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | import sure  # noqa | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  | import uuid | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | from botocore.exceptions import ClientError | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from moto import mock_acm | 
					
						
							| 
									
										
										
										
											2019-12-16 21:05:29 -05:00
										 |  |  | from moto.core import ACCOUNT_ID | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  | RESOURCE_FOLDER = os.path.join(os.path.dirname(__file__), "resources") | 
					
						
							|  |  |  | _GET_RESOURCE = lambda x: open(os.path.join(RESOURCE_FOLDER, x), "rb").read() | 
					
						
							|  |  |  | CA_CRT = _GET_RESOURCE("ca.pem") | 
					
						
							|  |  |  | CA_KEY = _GET_RESOURCE("ca.key") | 
					
						
							|  |  |  | SERVER_CRT = _GET_RESOURCE("star_moto_com.pem") | 
					
						
							|  |  |  | SERVER_COMMON_NAME = "*.moto.com" | 
					
						
							|  |  |  | SERVER_CRT_BAD = _GET_RESOURCE("star_moto_com-bad.pem") | 
					
						
							|  |  |  | SERVER_KEY = _GET_RESOURCE("star_moto_com.key") | 
					
						
							| 
									
										
										
										
											2019-12-16 21:25:20 -05:00
										 |  |  | BAD_ARN = "arn:aws:acm:us-east-2:{}:certificate/_0000000-0000-0000-0000-000000000000".format( | 
					
						
							|  |  |  |     ACCOUNT_ID | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | def _import_cert(client): | 
					
						
							|  |  |  |     response = client.import_certificate( | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         Certificate=SERVER_CRT, PrivateKey=SERVER_KEY, CertificateChain=CA_CRT | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     return response["CertificateArn"] | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Also tests GetCertificate | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | @mock_acm | 
					
						
							|  |  |  | def test_import_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     resp = client.import_certificate( | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         Certificate=SERVER_CRT, PrivateKey=SERVER_KEY, CertificateChain=CA_CRT | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp = client.get_certificate(CertificateArn=resp["CertificateArn"]) | 
					
						
							| 
									
										
										
										
											2017-09-22 00:20:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp["Certificate"].should.equal(SERVER_CRT.decode()) | 
					
						
							|  |  |  |     resp.should.contain("CertificateChain") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_import_bad_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         client.import_certificate(Certificate=SERVER_CRT_BAD, PrivateKey=SERVER_KEY) | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ValidationException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ValidationException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_list_certificates(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp = client.list_certificates() | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     len(resp["CertificateSummaryList"]).should.equal(1) | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp["CertificateSummaryList"][0]["CertificateArn"].should.equal(arn) | 
					
						
							|  |  |  |     resp["CertificateSummaryList"][0]["DomainName"].should.equal(SERVER_COMMON_NAME) | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-19 17:29:14 -07:00
										 |  |  | @mock_acm | 
					
						
							|  |  |  | def test_list_certificates_by_status(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2019-08-19 17:29:14 -07:00
										 |  |  |     issued_arn = _import_cert(client) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     pending_arn = client.request_certificate(DomainName="google.com")["CertificateArn"] | 
					
						
							| 
									
										
										
										
											2019-08-19 17:29:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     resp = client.list_certificates() | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     len(resp["CertificateSummaryList"]).should.equal(2) | 
					
						
							|  |  |  |     resp = client.list_certificates(CertificateStatuses=["EXPIRED", "INACTIVE"]) | 
					
						
							|  |  |  |     len(resp["CertificateSummaryList"]).should.equal(0) | 
					
						
							|  |  |  |     resp = client.list_certificates(CertificateStatuses=["PENDING_VALIDATION"]) | 
					
						
							|  |  |  |     len(resp["CertificateSummaryList"]).should.equal(1) | 
					
						
							|  |  |  |     resp["CertificateSummaryList"][0]["CertificateArn"].should.equal(pending_arn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp = client.list_certificates(CertificateStatuses=["ISSUED"]) | 
					
						
							|  |  |  |     len(resp["CertificateSummaryList"]).should.equal(1) | 
					
						
							|  |  |  |     resp["CertificateSummaryList"][0]["CertificateArn"].should.equal(issued_arn) | 
					
						
							|  |  |  |     resp = client.list_certificates( | 
					
						
							|  |  |  |         CertificateStatuses=["ISSUED", "PENDING_VALIDATION"] | 
					
						
							|  |  |  |     ) | 
					
						
							|  |  |  |     len(resp["CertificateSummaryList"]).should.equal(2) | 
					
						
							|  |  |  |     arns = {cert["CertificateArn"] for cert in resp["CertificateSummaryList"]} | 
					
						
							| 
									
										
										
										
											2019-08-19 17:29:14 -07:00
										 |  |  |     arns.should.contain(issued_arn) | 
					
						
							|  |  |  |     arns.should.contain(pending_arn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | @mock_acm | 
					
						
							|  |  |  | def test_get_invalid_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.get_certificate(CertificateArn=BAD_ARN) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Also tests deleting invalid certificate | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_delete_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # If it does not raise an error and the next call does, all is fine | 
					
						
							|  |  |  |     client.delete_certificate(CertificateArn=arn) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.delete_certificate(CertificateArn=arn) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_describe_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp = client.describe_certificate(CertificateArn=arn) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp["Certificate"]["CertificateArn"].should.equal(arn) | 
					
						
							|  |  |  |     resp["Certificate"]["DomainName"].should.equal(SERVER_COMMON_NAME) | 
					
						
							|  |  |  |     resp["Certificate"]["Issuer"].should.equal("Moto") | 
					
						
							|  |  |  |     resp["Certificate"]["KeyAlgorithm"].should.equal("RSA_2048") | 
					
						
							|  |  |  |     resp["Certificate"]["Status"].should.equal("ISSUED") | 
					
						
							|  |  |  |     resp["Certificate"]["Type"].should.equal("IMPORTED") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_describe_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.describe_certificate(CertificateArn=BAD_ARN) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Also tests ListTagsForCertificate | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_add_tags_to_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.add_tags_to_certificate( | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         CertificateArn=arn, Tags=[{"Key": "key1", "Value": "value1"}, {"Key": "key2"}] | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp = client.list_tags_for_certificate(CertificateArn=arn) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     tags = {item["Key"]: item.get("Value", "__NONE__") for item in resp["Tags"]} | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     tags.should.contain("key1") | 
					
						
							|  |  |  |     tags.should.contain("key2") | 
					
						
							|  |  |  |     tags["key1"].should.equal("value1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # This way, it ensures that we can detect if None is passed back when it shouldnt, | 
					
						
							|  |  |  |     # as we store keys without values with a value of None, but it shouldnt be passed back | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     tags["key2"].should.equal("__NONE__") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_add_tags_to_invalid_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.add_tags_to_certificate( | 
					
						
							|  |  |  |             CertificateArn=BAD_ARN, | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |             Tags=[{"Key": "key1", "Value": "value1"}, {"Key": "key2"}], | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |         ) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_list_tags_for_invalid_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.list_tags_for_certificate(CertificateArn=BAD_ARN) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_remove_tags_from_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.add_tags_to_certificate( | 
					
						
							|  |  |  |         CertificateArn=arn, | 
					
						
							|  |  |  |         Tags=[ | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |             {"Key": "key1", "Value": "value1"}, | 
					
						
							|  |  |  |             {"Key": "key2"}, | 
					
						
							|  |  |  |             {"Key": "key3", "Value": "value3"}, | 
					
						
							|  |  |  |             {"Key": "key4", "Value": "value4"}, | 
					
						
							|  |  |  |         ], | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.remove_tags_from_certificate( | 
					
						
							|  |  |  |         CertificateArn=arn, | 
					
						
							|  |  |  |         Tags=[ | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |             {"Key": "key1", "Value": "value2"},  # Should not remove as doesnt match | 
					
						
							|  |  |  |             {"Key": "key2"},  # Single key removal | 
					
						
							|  |  |  |             {"Key": "key3", "Value": "value3"},  # Exact match removal | 
					
						
							|  |  |  |             {"Key": "key4"},  # Partial match removal | 
					
						
							|  |  |  |         ], | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp = client.list_tags_for_certificate(CertificateArn=arn) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     tags = {item["Key"]: item.get("Value", "__NONE__") for item in resp["Tags"]} | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     for key in ("key2", "key3", "key4"): | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |         tags.should_not.contain(key) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     tags.should.contain("key1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_remove_tags_from_invalid_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.remove_tags_from_certificate( | 
					
						
							|  |  |  |             CertificateArn=BAD_ARN, | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |             Tags=[{"Key": "key1", "Value": "value1"}, {"Key": "key2"}], | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |         ) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  | @mock_acm | 
					
						
							|  |  |  | def test_resend_validation_email(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     client.resend_validation_email( | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         CertificateArn=arn, Domain="*.moto.com", ValidationDomain="NOTUSEDYET" | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  |     # Returns nothing, boto would raise Exceptions otherwise | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @mock_acm | 
					
						
							|  |  |  | def test_resend_validation_email_invalid(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     arn = _import_cert(client) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         client.resend_validation_email( | 
					
						
							|  |  |  |             CertificateArn=arn, | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |             Domain="no-match.moto.com", | 
					
						
							|  |  |  |             ValidationDomain="NOTUSEDYET", | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |         ) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal( | 
					
						
							|  |  |  |             "InvalidDomainValidationOptionsException" | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised InvalidDomainValidationOptionsException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     try: | 
					
						
							|  |  |  |         client.resend_validation_email( | 
					
						
							|  |  |  |             CertificateArn=BAD_ARN, | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |             Domain="no-match.moto.com", | 
					
						
							|  |  |  |             ValidationDomain="NOTUSEDYET", | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |         ) | 
					
						
							|  |  |  |     except ClientError as err: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         err.response["Error"]["Code"].should.equal("ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         raise RuntimeError("Should of raised ResourceNotFoundException") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  | @mock_acm | 
					
						
							|  |  |  | def test_request_certificate(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-09-22 11:21:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  |     token = str(uuid.uuid4()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     resp = client.request_certificate( | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         DomainName="google.com", | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  |         IdempotencyToken=token, | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         SubjectAlternativeNames=["google.com", "www.google.com", "mail.google.com"], | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp.should.contain("CertificateArn") | 
					
						
							|  |  |  |     arn = resp["CertificateArn"] | 
					
						
							| 
									
										
										
										
											2019-08-19 14:56:34 -07:00
										 |  |  |     arn.should.match(r"arn:aws:acm:eu-central-1:\d{12}:certificate/") | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     resp = client.request_certificate( | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         DomainName="google.com", | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  |         IdempotencyToken=token, | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |         SubjectAlternativeNames=["google.com", "www.google.com", "mail.google.com"], | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp["CertificateArn"].should.equal(arn) | 
					
						
							| 
									
										
										
										
											2017-10-28 17:07:34 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-19 17:47:21 -07:00
										 |  |  | @mock_acm | 
					
						
							|  |  |  | def test_request_certificate_no_san(): | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     client = boto3.client("acm", region_name="eu-central-1") | 
					
						
							| 
									
										
										
										
											2017-10-19 17:47:21 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 08:44:26 -07:00
										 |  |  |     resp = client.request_certificate(DomainName="google.com") | 
					
						
							|  |  |  |     resp.should.contain("CertificateArn") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resp2 = client.describe_certificate(CertificateArn=resp["CertificateArn"]) | 
					
						
							|  |  |  |     resp2.should.contain("Certificate") | 
					
						
							| 
									
										
										
										
											2017-10-19 17:47:21 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 14:26:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-13 10:37:06 -04:00
										 |  |  | # # Also tests the SAN code | 
					
						
							|  |  |  | # # requires Pull: https://github.com/spulec/freezegun/pull/210 | 
					
						
							|  |  |  | # @freeze_time("2012-01-01 12:00:00", as_arg=True) | 
					
						
							|  |  |  | # @mock_acm | 
					
						
							|  |  |  | # def test_request_certificate(frozen_time): | 
					
						
							|  |  |  | #     # After requesting a certificate, it should then auto-validate after 1 minute | 
					
						
							|  |  |  | #     # Some sneaky programming for that ;-) | 
					
						
							|  |  |  | #     client = boto3.client('acm', region_name='eu-central-1') | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #     resp = client.request_certificate( | 
					
						
							|  |  |  | #         DomainName='google.com', | 
					
						
							|  |  |  | #         SubjectAlternativeNames=['google.com', 'www.google.com', 'mail.google.com'], | 
					
						
							|  |  |  | #     ) | 
					
						
							|  |  |  | #     arn = resp['CertificateArn'] | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #     resp = client.describe_certificate(CertificateArn=arn) | 
					
						
							|  |  |  | #     resp['Certificate']['CertificateArn'].should.equal(arn) | 
					
						
							|  |  |  | #     resp['Certificate']['DomainName'].should.equal('google.com') | 
					
						
							|  |  |  | #     resp['Certificate']['Issuer'].should.equal('Amazon') | 
					
						
							|  |  |  | #     resp['Certificate']['KeyAlgorithm'].should.equal('RSA_2048') | 
					
						
							|  |  |  | #     resp['Certificate']['Status'].should.equal('PENDING_VALIDATION') | 
					
						
							|  |  |  | #     resp['Certificate']['Type'].should.equal('AMAZON_ISSUED') | 
					
						
							|  |  |  | #     len(resp['Certificate']['SubjectAlternativeNames']).should.equal(3) | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #     # Move time | 
					
						
							|  |  |  | #     frozen_time.move_to('2012-01-01 12:02:00') | 
					
						
							|  |  |  | #     resp = client.describe_certificate(CertificateArn=arn) | 
					
						
							|  |  |  | #     resp['Certificate']['CertificateArn'].should.equal(arn) | 
					
						
							|  |  |  | #     resp['Certificate']['Status'].should.equal('ISSUED') | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # # requires Pull: https://github.com/spulec/freezegun/pull/210 | 
					
						
							|  |  |  | # @freeze_time("2012-01-01 12:00:00", as_arg=True) | 
					
						
							|  |  |  | # @mock_acm | 
					
						
							|  |  |  | # def test_request_certificate(frozen_time): | 
					
						
							|  |  |  | #     # After requesting a certificate, it should then auto-validate after 1 minute | 
					
						
							|  |  |  | #     # Some sneaky programming for that ;-) | 
					
						
							|  |  |  | #     client = boto3.client('acm', region_name='eu-central-1') | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #     resp = client.request_certificate( | 
					
						
							|  |  |  | #         IdempotencyToken='test_token', | 
					
						
							|  |  |  | #         DomainName='google.com', | 
					
						
							|  |  |  | #         SubjectAlternativeNames=['google.com', 'www.google.com', 'mail.google.com'], | 
					
						
							|  |  |  | #     ) | 
					
						
							|  |  |  | #     original_arn = resp['CertificateArn'] | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #     # Should be able to request a certificate multiple times in an hour | 
					
						
							|  |  |  | #     # after that it makes a new one | 
					
						
							|  |  |  | #     for time_intervals in ('2012-01-01 12:15:00', '2012-01-01 12:30:00', '2012-01-01 12:45:00'): | 
					
						
							|  |  |  | #         frozen_time.move_to(time_intervals) | 
					
						
							|  |  |  | #         resp = client.request_certificate( | 
					
						
							|  |  |  | #             IdempotencyToken='test_token', | 
					
						
							|  |  |  | #             DomainName='google.com', | 
					
						
							|  |  |  | #             SubjectAlternativeNames=['google.com', 'www.google.com', 'mail.google.com'], | 
					
						
							|  |  |  | #         ) | 
					
						
							|  |  |  | #         arn = resp['CertificateArn'] | 
					
						
							|  |  |  | #         arn.should.equal(original_arn) | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #     # Move time | 
					
						
							|  |  |  | #     frozen_time.move_to('2012-01-01 13:01:00') | 
					
						
							|  |  |  | #     resp = client.request_certificate( | 
					
						
							|  |  |  | #         IdempotencyToken='test_token', | 
					
						
							|  |  |  | #         DomainName='google.com', | 
					
						
							|  |  |  | #         SubjectAlternativeNames=['google.com', 'www.google.com', 'mail.google.com'], | 
					
						
							|  |  |  | #     ) | 
					
						
							|  |  |  | #     arn = resp['CertificateArn'] | 
					
						
							|  |  |  | #     arn.should_not.equal(original_arn) |