Add support for KmsKeyId in ec2:RunInstances (#3943)

This commit is contained in:
Brian Pandola 2021-05-19 23:11:50 -07:00 committed by GitHub
commit 752b508738
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 49 additions and 1 deletions

View file

@ -0,0 +1,44 @@
from __future__ import unicode_literals
import boto3
import sure # noqa
from moto import mock_ec2, mock_kms
from tests import EXAMPLE_AMI_ID
@mock_ec2
@mock_kms
def test_run_instance_with_encrypted_ebs():
kms = boto3.client("kms", region_name="us-east-1")
resp = kms.create_key(Description="my key", KeyUsage="ENCRYPT_DECRYPT")
key_id = resp["KeyMetadata"]["Arn"]
ec2 = boto3.client("ec2", region_name="us-east-1")
kwargs = {
"MinCount": 1,
"MaxCount": 1,
"ImageId": EXAMPLE_AMI_ID,
"KeyName": "the_key",
"InstanceType": "t1.micro",
"BlockDeviceMappings": [
{
"DeviceName": "/dev/sda2",
"Ebs": {
"VolumeSize": 50,
"VolumeType": "gp2",
"Encrypted": True,
"KmsKeyId": key_id,
},
}
],
}
ec2.run_instances(**kwargs)
instances = ec2.describe_instances().get("Reservations")[0].get("Instances")
volume = instances[0]["BlockDeviceMappings"][0]["Ebs"]
volumes = ec2.describe_volumes(VolumeIds=[volume["VolumeId"]])
volumes["Volumes"][0]["Size"].should.equal(50)
volumes["Volumes"][0]["Encrypted"].should.equal(True)
volumes["Volumes"][0]["KmsKeyId"].should.equal(key_id)