import boto3 import sure # noqa from moto import mock_ec2 from moto.core import ACCOUNT_ID @mock_ec2 def test_describe_transit_gateways(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.describe_transit_gateways() response.should.have.key("TransitGateways").equal([]) @mock_ec2 def test_create_transit_gateway(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.create_transit_gateway( Description="my first gateway", Options={"DnsSupport": "disable"} ) gateway = response["TransitGateway"] gateway.should.have.key("TransitGatewayId").match("tgw-[a-z0-9]+") gateway.should.have.key("State").equal("available") gateway.should.have.key("OwnerId").equal(ACCOUNT_ID) gateway.should.have.key("Description").equal("my first gateway") gateway.should.have.key("Tags").equal([]) options = gateway["Options"] options.should.have.key("AmazonSideAsn").equal(64512) options.should.have.key("TransitGatewayCidrBlocks").equal([]) options.should.have.key("AutoAcceptSharedAttachments").equal("disable") options.should.have.key("DefaultRouteTableAssociation").equal("enable") options.should.have.key("DefaultRouteTablePropagation").equal("enable") options.should.have.key("PropagationDefaultRouteTableId").match("tgw-rtb-[a-z0-9]+") options.should.have.key("VpnEcmpSupport").equal("enable") options.should.have.key("DnsSupport").equal("disable") # # Verify we can retrieve it response = ec2.describe_transit_gateways() gateways = response["TransitGateways"] gateways.should.have.length_of(1) gateways[0].should.have.key("CreationTime") gateways[0].should.have.key("TransitGatewayArn").equal( "arn:aws:ec2:us-east-1:{}:transit-gateway/{}".format( ACCOUNT_ID, gateway["TransitGatewayId"] ) ) gateways[0]["Options"].should.have.key("AssociationDefaultRouteTableId").equal( gateways[0]["Options"]["PropagationDefaultRouteTableId"] ) del gateways[0]["CreationTime"] del gateways[0]["TransitGatewayArn"] del gateways[0]["Options"]["AssociationDefaultRouteTableId"] gateway.should.equal(gateways[0]) @mock_ec2 def test_create_transit_gateway_with_tags(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.create_transit_gateway( Description="my first gateway", TagSpecifications=[ { "ResourceType": "transit-gateway", "Tags": [ {"Key": "tag1", "Value": "val1"}, {"Key": "tag2", "Value": "val2"}, ], } ], ) gateway = response["TransitGateway"] gateway.should.have.key("TransitGatewayId").match("tgw-[a-z0-9]+") tags = gateway.get("Tags", []) tags.should.have.length_of(2) tags.should.contain({"Key": "tag1", "Value": "val1"}) tags.should.contain({"Key": "tag2", "Value": "val2"}) @mock_ec2 def test_delete_transit_gateway(): ec2 = boto3.client("ec2", region_name="us-west-1") g = ec2.create_transit_gateway(Description="my first gateway")["TransitGateway"] ec2.describe_transit_gateways()["TransitGateways"].should.have.length_of(1) ec2.delete_transit_gateway(TransitGatewayId=g["TransitGatewayId"]) ec2.describe_transit_gateways()["TransitGateways"].should.have.length_of(0) @mock_ec2 def test_modify_transit_gateway(): ec2 = boto3.client("ec2", region_name="us-west-1") g = ec2.create_transit_gateway(Description="my first gatway")["TransitGateway"] ec2.describe_transit_gateways()["TransitGateways"].should.have.length_of(1) ec2.describe_transit_gateways()["TransitGateways"][0]["Description"].should.equal( "my first gatway" ) ec2.modify_transit_gateway( TransitGatewayId=g["TransitGatewayId"], Description="my first gateway" ) ec2.describe_transit_gateways()["TransitGateways"].should.have.length_of(1) ec2.describe_transit_gateways()["TransitGateways"][0]["Description"].should.equal( "my first gateway" ) @mock_ec2 def test_describe_transit_gateway_vpc_attachments(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.describe_transit_gateway_vpc_attachments() response.should.have.key("TransitGatewayVpcAttachments").equal([]) @mock_ec2 def test_describe_transit_gateway_attachments(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.describe_transit_gateway_attachments() response.should.have.key("TransitGatewayAttachments").equal([]) @mock_ec2 def test_create_transit_gateway_vpn_attachment(): ec2 = boto3.client("ec2", region_name="us-west-1") vpn_gateway = ec2.create_vpn_gateway(Type="ipsec.1").get("VpnGateway", {}) customer_gateway = ec2.create_customer_gateway( Type="ipsec.1", PublicIp="205.251.242.54", BgpAsn=65534, ).get("CustomerGateway", {}) vpn_connection = ec2.create_vpn_connection( Type="ipsec.1", VpnGatewayId=vpn_gateway["VpnGatewayId"], CustomerGatewayId=customer_gateway["CustomerGatewayId"], TransitGatewayId="gateway_id", ).get("VpnConnection", {}) # # Verify we can retrieve it as a general attachment attachments = ec2.describe_transit_gateway_attachments()[ "TransitGatewayAttachments" ] attachments.should.have.length_of(1) attachments[0].should.have.key("ResourceType").equal("vpn") attachments[0].should.have.key("ResourceId").equal( vpn_connection["VpnConnectionId"] ) @mock_ec2 def test_create_transit_gateway_vpc_attachment(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId="gateway_id", VpcId="some-vpc-id", SubnetIds=["sub1"] ) attachment = response["TransitGatewayVpcAttachment"] attachment.should.have.key("TransitGatewayAttachmentId").match("tgw-attach-*") attachment.should.have.key("TransitGatewayId").equal("gateway_id") attachment.should.have.key("VpcId").equal("some-vpc-id") attachment.should.have.key("VpcOwnerId").equal(ACCOUNT_ID) attachment.should.have.key("State").equal("available") attachment.should.have.key("SubnetIds").equal(["sub1"]) attachment.should.have.key("Options").equal( { "DnsSupport": "enable", "Ipv6Support": "disable", "ApplianceModeSupport": "disable", } ) attachment.should.have.key("Tags").equal([]) # # Verify we can retrieve it as a VPC attachment attachments = ec2.describe_transit_gateway_vpc_attachments()[ "TransitGatewayVpcAttachments" ] attachments.should.have.length_of(1) attachments[0].should.have.key("CreationTime") del attachments[0]["CreationTime"] attachment.should.equal(attachments[0]) # # Verify we can retrieve it as a general attachment attachments = ec2.describe_transit_gateway_attachments()[ "TransitGatewayAttachments" ] attachments.should.have.length_of(1) attachments[0].should.have.key("CreationTime") attachments[0].should.have.key("TransitGatewayOwnerId").equal(ACCOUNT_ID) attachments[0].should.have.key("ResourceOwnerId").equal(ACCOUNT_ID) attachments[0].should.have.key("ResourceType").equal("vpc") attachments[0].should.have.key("ResourceId").equal("some-vpc-id") attachments[0].should.have.key("State").equal("available") attachments[0].should.have.key("Tags").equal([]) attachments[0].should.have.key("TransitGatewayAttachmentId").equal( attachment["TransitGatewayAttachmentId"] ) attachments[0].should.have.key("TransitGatewayId").equal("gateway_id") @mock_ec2 def test_describe_transit_gateway_route_tables(): ec2 = boto3.client("ec2", region_name="us-west-1") response = ec2.describe_transit_gateway_route_tables() response.should.have.key("TransitGatewayRouteTables").equal([]) @mock_ec2 def test_create_transit_gateway_route_table(): ec2 = boto3.client("ec2", region_name="us-west-1") tables = ec2.describe_transit_gateway_route_tables()["TransitGatewayRouteTables"] tables.should.equal([]) gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] table.should.have.key("TransitGatewayRouteTableId").match("tgw-rtb-[0-9a-z]+") table.should.have.key("TransitGatewayId").equals(gateway_id) table.should.have.key("State").equals("available") table.should.have.key("DefaultAssociationRouteTable").equals(False) table.should.have.key("DefaultPropagationRouteTable").equals(False) table.should.have.key("CreationTime") table.should.have.key("Tags").equals([]) tables = ec2.describe_transit_gateway_route_tables()["TransitGatewayRouteTables"] tables.should.have.length_of(2) @mock_ec2 def test_create_transit_gateway_route_table_with_tags(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] response = ec2.create_transit_gateway_route_table( TransitGatewayId=gateway_id, TagSpecifications=[ { "ResourceType": "transit-gateway-route-table", "Tags": [ {"Key": "tag1", "Value": "val1"}, {"Key": "tag2", "Value": "val2"}, ], } ], ) table = response["TransitGatewayRouteTable"] table["Tags"].should.have.length_of(2) table["Tags"].should.contain({"Key": "tag1", "Value": "val1"}) table["Tags"].should.contain({"Key": "tag2", "Value": "val2"}) @mock_ec2 def test_delete_transit_gateway_route_table(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] tables = ec2.describe_transit_gateway_route_tables()["TransitGatewayRouteTables"] tables.should.have.length_of(2) table = ec2.delete_transit_gateway_route_table( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) table["TransitGatewayRouteTable"].should.have.key("State").equals("deleted") tables = ec2.describe_transit_gateway_route_tables()["TransitGatewayRouteTables"] tables.should.have.length_of(2) @mock_ec2 def test_search_transit_gateway_routes_empty(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table_id = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ]["TransitGatewayRouteTableId"] response = ec2.search_transit_gateway_routes( TransitGatewayRouteTableId=table_id, Filters=[{"Name": "state", "Values": ["active"]}], ) response.should.have.key("Routes").equal([]) response.should.have.key("AdditionalRoutesAvailable").equal(False) @mock_ec2 def test_create_transit_gateway_route(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table_id = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ]["TransitGatewayRouteTableId"] route = ec2.create_transit_gateway_route( DestinationCidrBlock="0.0.0.0", TransitGatewayRouteTableId=table_id )["Route"] route.should.have.key("DestinationCidrBlock").equal("0.0.0.0") route.should.have.key("Type").equal("static") route.should.have.key("State").equal("active") @mock_ec2 def test_create_transit_gateway_route_as_blackhole(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table_id = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ]["TransitGatewayRouteTableId"] route = ec2.create_transit_gateway_route( DestinationCidrBlock="192.168.0.1", TransitGatewayRouteTableId=table_id, Blackhole=True, )["Route"] route.should.have.key("DestinationCidrBlock").equal("192.168.0.1") route.should.have.key("Type").equal("static") route.should.have.key("State").equal("blackhole") @mock_ec2 def test_search_transit_gateway_routes_by_state(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table_id = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ]["TransitGatewayRouteTableId"] ec2.create_transit_gateway_route( DestinationCidrBlock="192.168.0.0", TransitGatewayRouteTableId=table_id ) ec2.create_transit_gateway_route( DestinationCidrBlock="192.168.0.1", TransitGatewayRouteTableId=table_id, Blackhole=True, ) routes = ec2.search_transit_gateway_routes( TransitGatewayRouteTableId=table_id, Filters=[{"Name": "state", "Values": ["active"]}], )["Routes"] routes.should.equal( [{"DestinationCidrBlock": "192.168.0.0", "Type": "static", "State": "active"}] ) routes = ec2.search_transit_gateway_routes( TransitGatewayRouteTableId=table_id, Filters=[{"Name": "state", "Values": ["blackhole"]}], )["Routes"] routes.should.equal( [ { "DestinationCidrBlock": "192.168.0.1", "Type": "static", "State": "blackhole", } ] ) routes = ec2.search_transit_gateway_routes( TransitGatewayRouteTableId=table_id, Filters=[{"Name": "state", "Values": ["unknown"]}], )["Routes"] routes.should.equal([]) @mock_ec2 def test_delete_transit_gateway_route(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] table_id = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ]["TransitGatewayRouteTableId"] ec2.create_transit_gateway_route( DestinationCidrBlock="192.168.0.0", TransitGatewayRouteTableId=table_id ) ec2.create_transit_gateway_route( DestinationCidrBlock="192.168.0.1", TransitGatewayRouteTableId=table_id ) response = ec2.delete_transit_gateway_route( DestinationCidrBlock="192.168.0.0", TransitGatewayRouteTableId=table_id ) response["Route"].should.equal( {"DestinationCidrBlock": "192.168.0.0", "Type": "static", "State": "deleted"} ) routes = ec2.search_transit_gateway_routes( TransitGatewayRouteTableId=table_id, Filters=[{"Name": "state", "Values": ["active"]}], )["Routes"] routes.should.equal( [{"DestinationCidrBlock": "192.168.0.1", "Type": "static", "State": "active"}] ) @mock_ec2 def test_create_transit_gateway_vpc_attachment(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] response = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] ) response.should.have.key("TransitGatewayVpcAttachment") attachment = response["TransitGatewayVpcAttachment"] attachment.should.have.key("TransitGatewayAttachmentId").match( "tgw-attach-[0-9a-z]+" ) attachment.should.have.key("TransitGatewayId").equal(gateway_id) attachment.should.have.key("VpcId").equal("vpc-id") attachment.should.have.key("VpcOwnerId").equal(ACCOUNT_ID) attachment.should.have.key("SubnetIds").equal(["sub1"]) attachment.should.have.key("State").equal("available") attachment.should.have.key("Tags").equal([]) @mock_ec2 def test_modify_transit_gateway_vpc_attachment_add_subnets(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] response = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1", "sub3"] ) attchmnt_id = response["TransitGatewayVpcAttachment"]["TransitGatewayAttachmentId"] ec2.modify_transit_gateway_vpc_attachment( TransitGatewayAttachmentId=attchmnt_id, AddSubnetIds=["sub2"] ) attachment = ec2.describe_transit_gateway_vpc_attachments( TransitGatewayAttachmentIds=[attchmnt_id] )["TransitGatewayVpcAttachments"][0] sorted(attachment["SubnetIds"]).should.equal(["sub1", "sub2", "sub3"]) @mock_ec2 def test_modify_transit_gateway_vpc_attachment_remove_subnets(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] response = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1", "sub2", "sub3"] ) attchmnt_id = response["TransitGatewayVpcAttachment"]["TransitGatewayAttachmentId"] ec2.modify_transit_gateway_vpc_attachment( TransitGatewayAttachmentId=attchmnt_id, RemoveSubnetIds=["sub2"] ) attachment = ec2.describe_transit_gateway_vpc_attachments( TransitGatewayAttachmentIds=[attchmnt_id] )["TransitGatewayVpcAttachments"][0] attachment["SubnetIds"].should.equal(["sub1", "sub3"]) @mock_ec2 def test_modify_transit_gateway_vpc_attachment_change_options(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] response = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"], Options={ "DnsSupport": "enable", "Ipv6Support": "enable", "ApplianceModeSupport": "enable", }, ) attchmnt_id = response["TransitGatewayVpcAttachment"]["TransitGatewayAttachmentId"] ec2.modify_transit_gateway_vpc_attachment( TransitGatewayAttachmentId=attchmnt_id, Options={"ApplianceModeSupport": "disabled"}, ) attachment = ec2.describe_transit_gateway_vpc_attachments( TransitGatewayAttachmentIds=[attchmnt_id] )["TransitGatewayVpcAttachments"][0] attachment["Options"]["ApplianceModeSupport"].should.equal("disabled") attachment["Options"]["DnsSupport"].should.equal("enable") attachment["Options"]["Ipv6Support"].should.equal("enable") @mock_ec2 def test_delete_transit_gateway_vpc_attachment(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] a1 = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"]["TransitGatewayAttachmentId"] a2 = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"]["TransitGatewayAttachmentId"] available = ec2.describe_transit_gateway_vpc_attachments( Filters=[{"Name": "state", "Values": ["available"]}] )["TransitGatewayVpcAttachments"] available.should.have.length_of(2) a1_removed = ec2.delete_transit_gateway_vpc_attachment( TransitGatewayAttachmentId=a1 )["TransitGatewayVpcAttachment"] a1_removed.should.have.key("TransitGatewayAttachmentId").equal(a1) a1_removed.should.have.key("State").equal("deleted") all_attchmnts = ec2.describe_transit_gateway_vpc_attachments()[ "TransitGatewayVpcAttachments" ] all_attchmnts.should.have.length_of(1) [a["TransitGatewayAttachmentId"] for a in all_attchmnts].should.equal([a2]) @mock_ec2 def test_associate_transit_gateway_route_table(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] attchmnt = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] initial = ec2.get_transit_gateway_route_table_associations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) initial["Associations"].should.equal( [ { "TransitGatewayAttachmentId": "", "ResourceId": "", "ResourceType": "", "State": "", } ] ) ec2.associate_transit_gateway_route_table( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) updated = ec2.get_transit_gateway_route_table_associations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) updated["Associations"].should.equal( [ { "TransitGatewayAttachmentId": attchmnt["TransitGatewayAttachmentId"], "ResourceId": "vpc-id", "ResourceType": "vpc", "State": "associated", } ] ) @mock_ec2 def test_disassociate_transit_gateway_route_table(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] attchmnt = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] initial = ec2.get_transit_gateway_route_table_associations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] )["Associations"][0] initial["TransitGatewayAttachmentId"].should.equal("") ec2.associate_transit_gateway_route_table( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) updated = ec2.get_transit_gateway_route_table_associations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] )["Associations"][0] updated["TransitGatewayAttachmentId"].should.equal( attchmnt["TransitGatewayAttachmentId"] ) updated["State"].should.equal("associated") dis = ec2.disassociate_transit_gateway_route_table( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], )["Association"] dis["State"].should.equal("disassociated") updated = ec2.get_transit_gateway_route_table_associations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] )["Associations"][0] updated["TransitGatewayAttachmentId"].should.equal("") updated["State"].should.equal("") @mock_ec2 def test_enable_transit_gateway_route_table_propagation(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] attchmnt = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] initial = ec2.get_transit_gateway_route_table_propagations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) initial["TransitGatewayRouteTablePropagations"].should.equal( [ { "TransitGatewayAttachmentId": "", "ResourceId": "", "ResourceType": "", "State": "", } ] ) ec2.associate_transit_gateway_route_table( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) ec2.enable_transit_gateway_route_table_propagation( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) enabled = ec2.get_transit_gateway_route_table_propagations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) enabled["TransitGatewayRouteTablePropagations"].should.equal( [ { "TransitGatewayAttachmentId": attchmnt["TransitGatewayAttachmentId"], "ResourceId": "vpc-id", "ResourceType": "vpc", "State": "enabled", } ] ) @mock_ec2 def test_disable_transit_gateway_route_table_propagation_without_enabling_first(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] attchmnt = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] initial = ec2.get_transit_gateway_route_table_propagations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) initial["TransitGatewayRouteTablePropagations"].should.equal( [ { "TransitGatewayAttachmentId": "", "ResourceId": "", "ResourceType": "", "State": "", } ] ) ec2.associate_transit_gateway_route_table( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) try: ec2.disable_transit_gateway_route_table_propagation( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) assert False, "Should not be able to disable before enabling it" except Exception: pass @mock_ec2 def test_disable_transit_gateway_route_table_propagation(): ec2 = boto3.client("ec2", region_name="us-west-1") gateway_id = ec2.create_transit_gateway(Description="g")["TransitGateway"][ "TransitGatewayId" ] attchmnt = ec2.create_transit_gateway_vpc_attachment( TransitGatewayId=gateway_id, VpcId="vpc-id", SubnetIds=["sub1"] )["TransitGatewayVpcAttachment"] table = ec2.create_transit_gateway_route_table(TransitGatewayId=gateway_id)[ "TransitGatewayRouteTable" ] initial = ec2.get_transit_gateway_route_table_propagations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) initial["TransitGatewayRouteTablePropagations"].should.equal( [ { "TransitGatewayAttachmentId": "", "ResourceId": "", "ResourceType": "", "State": "", } ] ) ec2.associate_transit_gateway_route_table( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) ec2.enable_transit_gateway_route_table_propagation( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) ec2.disable_transit_gateway_route_table_propagation( TransitGatewayAttachmentId=attchmnt["TransitGatewayAttachmentId"], TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"], ) disabled = ec2.get_transit_gateway_route_table_propagations( TransitGatewayRouteTableId=table["TransitGatewayRouteTableId"] ) disabled["TransitGatewayRouteTablePropagations"].should.equal( [ { "ResourceId": "", "ResourceType": "", "State": "", "TransitGatewayAttachmentId": "", } ] )