101 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
import boto3
 | 
						|
import pytest
 | 
						|
import sure  # noqa # pylint: disable=unused-import
 | 
						|
 | 
						|
from botocore.exceptions import ClientError
 | 
						|
from datetime import datetime
 | 
						|
 | 
						|
from moto import mock_iam
 | 
						|
from moto.core import ACCOUNT_ID
 | 
						|
 | 
						|
 | 
						|
@mock_iam
 | 
						|
def test_get_all_server_certs():
 | 
						|
    conn = boto3.client("iam", region_name="us-east-1")
 | 
						|
 | 
						|
    conn.upload_server_certificate(
 | 
						|
        ServerCertificateName="certname",
 | 
						|
        CertificateBody="certbody",
 | 
						|
        PrivateKey="privatekey",
 | 
						|
    )
 | 
						|
    certs = conn.list_server_certificates()["ServerCertificateMetadataList"]
 | 
						|
    certs.should.have.length_of(1)
 | 
						|
    cert1 = certs[0]
 | 
						|
    cert1["ServerCertificateName"].should.equal("certname")
 | 
						|
    cert1["Arn"].should.equal(
 | 
						|
        "arn:aws:iam::{}:server-certificate/certname".format(ACCOUNT_ID)
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
@mock_iam
 | 
						|
def test_get_server_cert_doesnt_exist():
 | 
						|
    conn = boto3.client("iam", region_name="us-east-1")
 | 
						|
 | 
						|
    with pytest.raises(ClientError) as ex:
 | 
						|
        conn.get_server_certificate(ServerCertificateName="NonExistant")
 | 
						|
    err = ex.value.response["Error"]
 | 
						|
    err["Code"].should.equal("NoSuchEntity")
 | 
						|
    err["Message"].should.equal(
 | 
						|
        "The Server Certificate with name NonExistant cannot be found."
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
@mock_iam
 | 
						|
def test_get_server_cert():
 | 
						|
    conn = boto3.client("iam", region_name="us-east-1")
 | 
						|
 | 
						|
    conn.upload_server_certificate(
 | 
						|
        ServerCertificateName="certname",
 | 
						|
        CertificateBody="certbody",
 | 
						|
        PrivateKey="privatekey",
 | 
						|
    )
 | 
						|
    cert = conn.get_server_certificate(ServerCertificateName="certname")[
 | 
						|
        "ServerCertificate"
 | 
						|
    ]
 | 
						|
    cert["CertificateBody"].should.equal("certbody")
 | 
						|
    cert.shouldnt.have.key("CertificateChain")
 | 
						|
    cert.shouldnt.have.key("Tags")
 | 
						|
    metadata = cert["ServerCertificateMetadata"]
 | 
						|
    metadata["Path"].should.equal("/")
 | 
						|
    metadata["ServerCertificateName"].should.equal("certname")
 | 
						|
    metadata["Arn"].should.equal(
 | 
						|
        "arn:aws:iam::{}:server-certificate/certname".format(ACCOUNT_ID)
 | 
						|
    )
 | 
						|
    metadata.should.have.key("ServerCertificateId")
 | 
						|
    metadata["UploadDate"].should.be.a(datetime)
 | 
						|
    metadata["Expiration"].should.be.a(datetime)
 | 
						|
 | 
						|
 | 
						|
@mock_iam
 | 
						|
def test_delete_server_cert():
 | 
						|
    conn = boto3.client("iam", region_name="us-east-1")
 | 
						|
 | 
						|
    conn.upload_server_certificate(
 | 
						|
        ServerCertificateName="certname",
 | 
						|
        CertificateBody="certbody",
 | 
						|
        PrivateKey="privatekey",
 | 
						|
    )
 | 
						|
    conn.get_server_certificate(ServerCertificateName="certname")
 | 
						|
    conn.delete_server_certificate(ServerCertificateName="certname")
 | 
						|
 | 
						|
    with pytest.raises(ClientError) as ex:
 | 
						|
        conn.get_server_certificate(ServerCertificateName="certname")
 | 
						|
    err = ex.value.response["Error"]
 | 
						|
    err["Code"].should.equal("NoSuchEntity")
 | 
						|
    err["Message"].should.equal(
 | 
						|
        "The Server Certificate with name certname cannot be found."
 | 
						|
    )
 | 
						|
 | 
						|
 | 
						|
@mock_iam
 | 
						|
def test_delete_unknown_server_cert():
 | 
						|
    conn = boto3.client("iam", region_name="us-east-1")
 | 
						|
 | 
						|
    with pytest.raises(ClientError) as ex:
 | 
						|
        conn.delete_server_certificate(ServerCertificateName="certname")
 | 
						|
    err = ex.value.response["Error"]
 | 
						|
    err["Code"].should.equal("NoSuchEntity")
 | 
						|
    err["Message"].should.equal(
 | 
						|
        "The Server Certificate with name certname cannot be found."
 | 
						|
    )
 |