2014-08-27 15:17:06 +00:00
|
|
|
from __future__ import unicode_literals
|
2019-10-31 15:44:26 +00:00
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
import pytest
|
2014-09-04 23:23:59 +00:00
|
|
|
|
2013-02-22 04:13:01 +00:00
|
|
|
import boto
|
2016-03-02 11:15:47 +00:00
|
|
|
import boto3
|
2014-09-04 23:23:59 +00:00
|
|
|
from boto.exception import EC2ResponseError
|
2019-05-25 17:35:07 +00:00
|
|
|
from botocore.exceptions import ClientError
|
2013-08-03 21:21:25 +00:00
|
|
|
import sure # noqa
|
2013-02-22 04:13:01 +00:00
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
from moto import mock_ec2, mock_ec2_deprecated
|
2021-01-13 09:02:11 +00:00
|
|
|
from tests import EXAMPLE_AMI_ID
|
2014-09-04 23:23:59 +00:00
|
|
|
from tests.helpers import requires_boto_gte
|
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-09-04 23:23:59 +00:00
|
|
|
def test_route_tables_defaults():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
all_route_tables = conn.get_all_route_tables(filters={"vpc-id": vpc.id})
|
2014-09-04 23:23:59 +00:00
|
|
|
all_route_tables.should.have.length_of(1)
|
|
|
|
|
|
|
|
main_route_table = all_route_tables[0]
|
|
|
|
main_route_table.vpc_id.should.equal(vpc.id)
|
|
|
|
|
|
|
|
routes = main_route_table.routes
|
|
|
|
routes.should.have.length_of(1)
|
|
|
|
|
|
|
|
local_route = routes[0]
|
2019-10-31 15:44:26 +00:00
|
|
|
local_route.gateway_id.should.equal("local")
|
|
|
|
local_route.state.should.equal("active")
|
2014-09-04 23:23:59 +00:00
|
|
|
local_route.destination_cidr_block.should.equal(vpc.cidr_block)
|
|
|
|
|
|
|
|
vpc.delete()
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
all_route_tables = conn.get_all_route_tables(filters={"vpc-id": vpc.id})
|
2014-09-04 23:23:59 +00:00
|
|
|
all_route_tables.should.have.length_of(0)
|
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-09-04 23:23:59 +00:00
|
|
|
def test_route_tables_additional():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
|
|
|
route_table = conn.create_route_table(vpc.id)
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
all_route_tables = conn.get_all_route_tables(filters={"vpc-id": vpc.id})
|
2014-09-04 23:23:59 +00:00
|
|
|
all_route_tables.should.have.length_of(2)
|
|
|
|
all_route_tables[0].vpc_id.should.equal(vpc.id)
|
|
|
|
all_route_tables[1].vpc_id.should.equal(vpc.id)
|
|
|
|
|
|
|
|
all_route_table_ids = [route_table.id for route_table in all_route_tables]
|
|
|
|
all_route_table_ids.should.contain(route_table.id)
|
|
|
|
|
|
|
|
routes = route_table.routes
|
|
|
|
routes.should.have.length_of(1)
|
|
|
|
|
|
|
|
local_route = routes[0]
|
2019-10-31 15:44:26 +00:00
|
|
|
local_route.gateway_id.should.equal("local")
|
|
|
|
local_route.state.should.equal("active")
|
2014-09-04 23:23:59 +00:00
|
|
|
local_route.destination_cidr_block.should.equal(vpc.cidr_block)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-09-05 15:45:36 +00:00
|
|
|
conn.delete_vpc(vpc.id)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("DependencyViolation")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-09-05 15:45:36 +00:00
|
|
|
|
2014-09-04 23:23:59 +00:00
|
|
|
conn.delete_route_table(route_table.id)
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
all_route_tables = conn.get_all_route_tables(filters={"vpc-id": vpc.id})
|
2014-09-04 23:23:59 +00:00
|
|
|
all_route_tables.should.have.length_of(1)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-09-04 23:23:59 +00:00
|
|
|
conn.delete_route_table("rtb-1234abcd")
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidRouteTableID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-10-13 23:19:54 +00:00
|
|
|
def test_route_tables_filters_standard():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
vpc1 = conn.create_vpc("10.0.0.0/16")
|
|
|
|
route_table1 = conn.create_route_table(vpc1.id)
|
|
|
|
|
|
|
|
vpc2 = conn.create_vpc("10.0.0.0/16")
|
|
|
|
route_table2 = conn.create_route_table(vpc2.id)
|
|
|
|
|
|
|
|
all_route_tables = conn.get_all_route_tables()
|
2017-01-12 01:37:57 +00:00
|
|
|
all_route_tables.should.have.length_of(5)
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
# Filter by main route table
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_tables = conn.get_all_route_tables(filters={"association.main": "true"})
|
2017-01-12 01:37:57 +00:00
|
|
|
main_route_tables.should.have.length_of(3)
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_table_ids = [route_table.id for route_table in main_route_tables]
|
2014-09-04 23:23:59 +00:00
|
|
|
main_route_table_ids.should_not.contain(route_table1.id)
|
|
|
|
main_route_table_ids.should_not.contain(route_table2.id)
|
|
|
|
|
|
|
|
# Filter by VPC
|
2019-10-31 15:44:26 +00:00
|
|
|
vpc1_route_tables = conn.get_all_route_tables(filters={"vpc-id": vpc1.id})
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc1_route_tables.should.have.length_of(2)
|
2019-10-31 15:44:26 +00:00
|
|
|
vpc1_route_table_ids = [route_table.id for route_table in vpc1_route_tables]
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc1_route_table_ids.should.contain(route_table1.id)
|
|
|
|
vpc1_route_table_ids.should_not.contain(route_table2.id)
|
|
|
|
|
|
|
|
# Filter by VPC and main route table
|
2017-02-24 02:37:43 +00:00
|
|
|
vpc2_main_route_tables = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.main": "true", "vpc-id": vpc2.id}
|
|
|
|
)
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc2_main_route_tables.should.have.length_of(1)
|
2017-02-24 02:37:43 +00:00
|
|
|
vpc2_main_route_table_ids = [
|
2019-10-31 15:44:26 +00:00
|
|
|
route_table.id for route_table in vpc2_main_route_tables
|
|
|
|
]
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc2_main_route_table_ids.should_not.contain(route_table1.id)
|
|
|
|
vpc2_main_route_table_ids.should_not.contain(route_table2.id)
|
|
|
|
|
|
|
|
# Unsupported filter
|
2017-02-24 02:37:43 +00:00
|
|
|
conn.get_all_route_tables.when.called_with(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"not-implemented-filter": "foobar"}
|
|
|
|
).should.throw(NotImplementedError)
|
2013-02-22 04:13:01 +00:00
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-10-13 23:19:54 +00:00
|
|
|
def test_route_tables_filters_associations():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
2017-10-25 18:29:56 +00:00
|
|
|
subnet1 = conn.create_subnet(vpc.id, "10.0.0.0/24")
|
|
|
|
subnet2 = conn.create_subnet(vpc.id, "10.0.1.0/24")
|
|
|
|
subnet3 = conn.create_subnet(vpc.id, "10.0.2.0/24")
|
2014-10-13 23:19:54 +00:00
|
|
|
route_table1 = conn.create_route_table(vpc.id)
|
|
|
|
route_table2 = conn.create_route_table(vpc.id)
|
|
|
|
|
|
|
|
association_id1 = conn.associate_route_table(route_table1.id, subnet1.id)
|
|
|
|
association_id2 = conn.associate_route_table(route_table1.id, subnet2.id)
|
|
|
|
association_id3 = conn.associate_route_table(route_table2.id, subnet3.id)
|
|
|
|
|
|
|
|
all_route_tables = conn.get_all_route_tables()
|
2017-01-12 01:37:57 +00:00
|
|
|
all_route_tables.should.have.length_of(4)
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
# Filter by association ID
|
2017-02-24 02:37:43 +00:00
|
|
|
association1_route_tables = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.route-table-association-id": association_id1}
|
|
|
|
)
|
2014-10-13 23:19:54 +00:00
|
|
|
association1_route_tables.should.have.length_of(1)
|
|
|
|
association1_route_tables[0].id.should.equal(route_table1.id)
|
|
|
|
association1_route_tables[0].associations.should.have.length_of(2)
|
|
|
|
|
|
|
|
# Filter by route table ID
|
2017-02-24 02:37:43 +00:00
|
|
|
route_table2_route_tables = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.route-table-id": route_table2.id}
|
|
|
|
)
|
2014-10-13 23:19:54 +00:00
|
|
|
route_table2_route_tables.should.have.length_of(1)
|
|
|
|
route_table2_route_tables[0].id.should.equal(route_table2.id)
|
|
|
|
route_table2_route_tables[0].associations.should.have.length_of(1)
|
|
|
|
|
|
|
|
# Filter by subnet ID
|
2017-02-24 02:37:43 +00:00
|
|
|
subnet_route_tables = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.subnet-id": subnet1.id}
|
|
|
|
)
|
2014-10-13 23:19:54 +00:00
|
|
|
subnet_route_tables.should.have.length_of(1)
|
|
|
|
subnet_route_tables[0].id.should.equal(route_table1.id)
|
|
|
|
association1_route_tables[0].associations.should.have.length_of(2)
|
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-10-13 23:19:54 +00:00
|
|
|
def test_route_table_associations():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-10-13 23:19:54 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
|
|
|
subnet = conn.create_subnet(vpc.id, "10.0.0.0/18")
|
|
|
|
route_table = conn.create_route_table(vpc.id)
|
|
|
|
|
|
|
|
all_route_tables = conn.get_all_route_tables()
|
2017-01-12 01:37:57 +00:00
|
|
|
all_route_tables.should.have.length_of(3)
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
# Refresh
|
|
|
|
route_table = conn.get_all_route_tables(route_table.id)[0]
|
|
|
|
route_table.associations.should.have.length_of(0)
|
|
|
|
|
|
|
|
# Associate
|
|
|
|
association_id = conn.associate_route_table(route_table.id, subnet.id)
|
|
|
|
|
|
|
|
# Refresh
|
|
|
|
route_table = conn.get_all_route_tables(route_table.id)[0]
|
|
|
|
route_table.associations.should.have.length_of(1)
|
|
|
|
|
|
|
|
route_table.associations[0].id.should.equal(association_id)
|
2021-03-16 14:15:58 +00:00
|
|
|
route_table.associations[0].main.should.equal(True)
|
2014-10-13 23:19:54 +00:00
|
|
|
route_table.associations[0].route_table_id.should.equal(route_table.id)
|
|
|
|
route_table.associations[0].subnet_id.should.equal(subnet.id)
|
|
|
|
|
2014-10-14 21:23:14 +00:00
|
|
|
# Associate is idempotent
|
2019-10-31 15:44:26 +00:00
|
|
|
association_id_idempotent = conn.associate_route_table(route_table.id, subnet.id)
|
2014-10-14 21:23:14 +00:00
|
|
|
association_id_idempotent.should.equal(association_id)
|
|
|
|
|
2014-10-13 23:19:54 +00:00
|
|
|
# Error: Attempt delete associated route table.
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-10-13 23:19:54 +00:00
|
|
|
conn.delete_route_table(route_table.id)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("DependencyViolation")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
# Disassociate
|
|
|
|
conn.disassociate_route_table(association_id)
|
|
|
|
|
|
|
|
# Refresh
|
|
|
|
route_table = conn.get_all_route_tables(route_table.id)[0]
|
|
|
|
route_table.associations.should.have.length_of(0)
|
|
|
|
|
|
|
|
# Error: Disassociate with invalid association ID
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-10-13 23:19:54 +00:00
|
|
|
conn.disassociate_route_table(association_id)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidAssociationID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
# Error: Associate with invalid subnet ID
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-10-13 23:19:54 +00:00
|
|
|
conn.associate_route_table(route_table.id, "subnet-1234abcd")
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidSubnetID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
# Error: Associate with invalid route table ID
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-10-13 23:19:54 +00:00
|
|
|
conn.associate_route_table("rtb-1234abcd", subnet.id)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidRouteTableID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-10-14 18:23:42 +00:00
|
|
|
|
|
|
|
|
2014-10-14 18:34:58 +00:00
|
|
|
@requires_boto_gte("2.16.0")
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-10-14 18:23:42 +00:00
|
|
|
def test_route_table_replace_route_table_association():
|
|
|
|
"""
|
2020-10-06 06:46:05 +00:00
|
|
|
Note: Boto has deprecated replace_route_table_association (which returns status)
|
|
|
|
and now uses replace_route_table_association_with_assoc (which returns association ID).
|
2014-10-14 18:23:42 +00:00
|
|
|
"""
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-10-14 18:23:42 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
|
|
|
subnet = conn.create_subnet(vpc.id, "10.0.0.0/18")
|
|
|
|
route_table1 = conn.create_route_table(vpc.id)
|
|
|
|
route_table2 = conn.create_route_table(vpc.id)
|
|
|
|
|
|
|
|
all_route_tables = conn.get_all_route_tables()
|
2017-01-12 01:37:57 +00:00
|
|
|
all_route_tables.should.have.length_of(4)
|
2014-10-14 18:23:42 +00:00
|
|
|
|
|
|
|
# Refresh
|
|
|
|
route_table1 = conn.get_all_route_tables(route_table1.id)[0]
|
|
|
|
route_table1.associations.should.have.length_of(0)
|
|
|
|
|
|
|
|
# Associate
|
|
|
|
association_id1 = conn.associate_route_table(route_table1.id, subnet.id)
|
|
|
|
|
|
|
|
# Refresh
|
|
|
|
route_table1 = conn.get_all_route_tables(route_table1.id)[0]
|
|
|
|
route_table2 = conn.get_all_route_tables(route_table2.id)[0]
|
|
|
|
|
|
|
|
# Validate
|
|
|
|
route_table1.associations.should.have.length_of(1)
|
|
|
|
route_table2.associations.should.have.length_of(0)
|
|
|
|
|
|
|
|
route_table1.associations[0].id.should.equal(association_id1)
|
2021-03-16 14:15:58 +00:00
|
|
|
route_table1.associations[0].main.should.equal(True)
|
2014-10-14 18:23:42 +00:00
|
|
|
route_table1.associations[0].route_table_id.should.equal(route_table1.id)
|
|
|
|
route_table1.associations[0].subnet_id.should.equal(subnet.id)
|
|
|
|
|
|
|
|
# Replace Association
|
2017-02-24 02:37:43 +00:00
|
|
|
association_id2 = conn.replace_route_table_association_with_assoc(
|
2019-10-31 15:44:26 +00:00
|
|
|
association_id1, route_table2.id
|
|
|
|
)
|
2014-10-14 18:23:42 +00:00
|
|
|
|
|
|
|
# Refresh
|
|
|
|
route_table1 = conn.get_all_route_tables(route_table1.id)[0]
|
|
|
|
route_table2 = conn.get_all_route_tables(route_table2.id)[0]
|
|
|
|
|
|
|
|
# Validate
|
|
|
|
route_table1.associations.should.have.length_of(0)
|
|
|
|
route_table2.associations.should.have.length_of(1)
|
|
|
|
|
|
|
|
route_table2.associations[0].id.should.equal(association_id2)
|
2021-03-16 14:15:58 +00:00
|
|
|
route_table2.associations[0].main.should.equal(True)
|
2014-10-14 18:23:42 +00:00
|
|
|
route_table2.associations[0].route_table_id.should.equal(route_table2.id)
|
|
|
|
route_table2.associations[0].subnet_id.should.equal(subnet.id)
|
|
|
|
|
2014-10-14 21:23:14 +00:00
|
|
|
# Replace Association is idempotent
|
2017-02-24 02:37:43 +00:00
|
|
|
association_id_idempotent = conn.replace_route_table_association_with_assoc(
|
2019-10-31 15:44:26 +00:00
|
|
|
association_id2, route_table2.id
|
|
|
|
)
|
2014-10-14 21:23:14 +00:00
|
|
|
association_id_idempotent.should.equal(association_id2)
|
|
|
|
|
2014-10-14 18:23:42 +00:00
|
|
|
# Error: Replace association with invalid association ID
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2017-02-24 02:37:43 +00:00
|
|
|
conn.replace_route_table_association_with_assoc(
|
2019-10-31 15:44:26 +00:00
|
|
|
"rtbassoc-1234abcd", route_table1.id
|
|
|
|
)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidAssociationID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-10-14 18:23:42 +00:00
|
|
|
|
|
|
|
# Error: Replace association with invalid route table ID
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2019-10-31 15:44:26 +00:00
|
|
|
conn.replace_route_table_association_with_assoc(association_id2, "rtb-1234abcd")
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidRouteTableID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-10-13 23:19:54 +00:00
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2016-03-02 11:15:47 +00:00
|
|
|
def test_route_table_get_by_tag():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2016-03-02 11:15:47 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
2016-03-02 11:15:47 +00:00
|
|
|
|
|
|
|
route_table = conn.create_route_table(vpc.id)
|
2019-10-31 15:44:26 +00:00
|
|
|
route_table.add_tag("Name", "TestRouteTable")
|
2016-03-02 11:15:47 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
route_tables = conn.get_all_route_tables(filters={"tag:Name": "TestRouteTable"})
|
2016-03-02 11:15:47 +00:00
|
|
|
|
|
|
|
route_tables.should.have.length_of(1)
|
|
|
|
route_tables[0].vpc_id.should.equal(vpc.id)
|
|
|
|
route_tables[0].id.should.equal(route_table.id)
|
|
|
|
route_tables[0].tags.should.have.length_of(1)
|
2019-10-31 15:44:26 +00:00
|
|
|
route_tables[0].tags["Name"].should.equal("TestRouteTable")
|
2016-03-02 11:15:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
def test_route_table_get_by_tag_boto3():
|
2019-10-31 15:44:26 +00:00
|
|
|
ec2 = boto3.resource("ec2", region_name="eu-central-1")
|
2016-03-02 11:15:47 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
2016-03-02 11:15:47 +00:00
|
|
|
|
|
|
|
route_table = ec2.create_route_table(VpcId=vpc.id)
|
2019-10-31 15:44:26 +00:00
|
|
|
route_table.create_tags(Tags=[{"Key": "Name", "Value": "TestRouteTable"}])
|
2016-03-02 11:15:47 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
filters = [{"Name": "tag:Name", "Values": ["TestRouteTable"]}]
|
2016-03-02 11:15:47 +00:00
|
|
|
route_tables = list(ec2.route_tables.filter(Filters=filters))
|
|
|
|
|
|
|
|
route_tables.should.have.length_of(1)
|
|
|
|
route_tables[0].vpc_id.should.equal(vpc.id)
|
|
|
|
route_tables[0].id.should.equal(route_table.id)
|
|
|
|
route_tables[0].tags.should.have.length_of(1)
|
2019-10-31 15:44:26 +00:00
|
|
|
route_tables[0].tags[0].should.equal({"Key": "Name", "Value": "TestRouteTable"})
|
2016-03-02 11:15:47 +00:00
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-09-04 23:23:59 +00:00
|
|
|
def test_routes_additional():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_table = conn.get_all_route_tables(filters={"vpc-id": vpc.id})[0]
|
2014-09-04 23:23:59 +00:00
|
|
|
local_route = main_route_table.routes[0]
|
|
|
|
igw = conn.create_internet_gateway()
|
|
|
|
ROUTE_CIDR = "10.0.0.4/24"
|
|
|
|
|
|
|
|
conn.create_route(main_route_table.id, ROUTE_CIDR, gateway_id=igw.id)
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_table = conn.get_all_route_tables(filters={"vpc-id": vpc.id})[
|
|
|
|
0
|
|
|
|
] # Refresh route table
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
main_route_table.routes.should.have.length_of(2)
|
2017-02-24 02:37:43 +00:00
|
|
|
new_routes = [
|
2019-10-31 15:44:26 +00:00
|
|
|
route
|
|
|
|
for route in main_route_table.routes
|
|
|
|
if route.destination_cidr_block != vpc.cidr_block
|
|
|
|
]
|
2014-09-04 23:23:59 +00:00
|
|
|
new_routes.should.have.length_of(1)
|
|
|
|
|
|
|
|
new_route = new_routes[0]
|
|
|
|
new_route.gateway_id.should.equal(igw.id)
|
|
|
|
new_route.instance_id.should.be.none
|
2019-10-31 15:44:26 +00:00
|
|
|
new_route.state.should.equal("active")
|
2014-09-04 23:23:59 +00:00
|
|
|
new_route.destination_cidr_block.should.equal(ROUTE_CIDR)
|
|
|
|
|
|
|
|
conn.delete_route(main_route_table.id, ROUTE_CIDR)
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_table = conn.get_all_route_tables(filters={"vpc-id": vpc.id})[
|
|
|
|
0
|
|
|
|
] # Refresh route table
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
main_route_table.routes.should.have.length_of(1)
|
2017-02-24 02:37:43 +00:00
|
|
|
new_routes = [
|
2019-10-31 15:44:26 +00:00
|
|
|
route
|
|
|
|
for route in main_route_table.routes
|
|
|
|
if route.destination_cidr_block != vpc.cidr_block
|
|
|
|
]
|
2014-09-04 23:23:59 +00:00
|
|
|
new_routes.should.have.length_of(0)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2014-09-04 23:23:59 +00:00
|
|
|
conn.delete_route(main_route_table.id, ROUTE_CIDR)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidRoute.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-09-04 23:23:59 +00:00
|
|
|
def test_routes_replace():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-09-04 23:23:59 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
2017-02-24 02:37:43 +00:00
|
|
|
main_route_table = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.main": "true", "vpc-id": vpc.id}
|
|
|
|
)[0]
|
2014-09-04 23:23:59 +00:00
|
|
|
local_route = main_route_table.routes[0]
|
|
|
|
ROUTE_CIDR = "10.0.0.4/24"
|
|
|
|
|
|
|
|
# Various route targets
|
|
|
|
igw = conn.create_internet_gateway()
|
|
|
|
|
2021-01-13 09:02:11 +00:00
|
|
|
reservation = conn.run_instances(EXAMPLE_AMI_ID)
|
2014-09-04 23:23:59 +00:00
|
|
|
instance = reservation.instances[0]
|
|
|
|
|
|
|
|
# Create initial route
|
|
|
|
conn.create_route(main_route_table.id, ROUTE_CIDR, gateway_id=igw.id)
|
|
|
|
|
|
|
|
# Replace...
|
|
|
|
def get_target_route():
|
|
|
|
route_table = conn.get_all_route_tables(main_route_table.id)[0]
|
2017-02-24 02:37:43 +00:00
|
|
|
routes = [
|
2019-10-31 15:44:26 +00:00
|
|
|
route
|
|
|
|
for route in route_table.routes
|
|
|
|
if route.destination_cidr_block != vpc.cidr_block
|
|
|
|
]
|
2014-09-04 23:23:59 +00:00
|
|
|
routes.should.have.length_of(1)
|
|
|
|
return routes[0]
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
conn.replace_route(main_route_table.id, ROUTE_CIDR, instance_id=instance.id)
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
target_route = get_target_route()
|
|
|
|
target_route.gateway_id.should.be.none
|
|
|
|
target_route.instance_id.should.equal(instance.id)
|
2019-10-31 15:44:26 +00:00
|
|
|
target_route.state.should.equal("active")
|
2014-09-04 23:23:59 +00:00
|
|
|
target_route.destination_cidr_block.should.equal(ROUTE_CIDR)
|
|
|
|
|
|
|
|
conn.replace_route(main_route_table.id, ROUTE_CIDR, gateway_id=igw.id)
|
|
|
|
|
|
|
|
target_route = get_target_route()
|
|
|
|
target_route.gateway_id.should.equal(igw.id)
|
|
|
|
target_route.instance_id.should.be.none
|
2019-10-31 15:44:26 +00:00
|
|
|
target_route.state.should.equal("active")
|
2014-09-04 23:23:59 +00:00
|
|
|
target_route.destination_cidr_block.should.equal(ROUTE_CIDR)
|
|
|
|
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(EC2ResponseError) as cm:
|
2019-10-31 15:44:26 +00:00
|
|
|
conn.replace_route("rtb-1234abcd", ROUTE_CIDR, gateway_id=igw.id)
|
2020-10-06 06:04:09 +00:00
|
|
|
cm.value.code.should.equal("InvalidRouteTableID.NotFound")
|
|
|
|
cm.value.status.should.equal(400)
|
|
|
|
cm.value.request_id.should_not.be.none
|
2014-09-04 23:23:59 +00:00
|
|
|
|
2014-09-05 00:13:25 +00:00
|
|
|
|
|
|
|
@requires_boto_gte("2.19.0")
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-09-05 00:13:25 +00:00
|
|
|
def test_routes_not_supported():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-09-05 00:13:25 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
|
|
|
main_route_table = conn.get_all_route_tables()[0]
|
|
|
|
local_route = main_route_table.routes[0]
|
|
|
|
igw = conn.create_internet_gateway()
|
|
|
|
ROUTE_CIDR = "10.0.0.4/24"
|
|
|
|
|
|
|
|
# Create
|
2017-02-24 02:37:43 +00:00
|
|
|
conn.create_route.when.called_with(
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_table.id, ROUTE_CIDR, interface_id="eni-1234abcd"
|
2020-06-12 15:16:55 +00:00
|
|
|
).should.throw("InvalidNetworkInterfaceID.NotFound")
|
2014-09-05 00:13:25 +00:00
|
|
|
|
|
|
|
# Replace
|
|
|
|
igw = conn.create_internet_gateway()
|
|
|
|
conn.create_route(main_route_table.id, ROUTE_CIDR, gateway_id=igw.id)
|
2017-02-24 02:37:43 +00:00
|
|
|
conn.replace_route.when.called_with(
|
2019-10-31 15:44:26 +00:00
|
|
|
main_route_table.id, ROUTE_CIDR, interface_id="eni-1234abcd"
|
|
|
|
).should.throw(NotImplementedError)
|
2014-09-04 23:23:59 +00:00
|
|
|
|
|
|
|
|
2014-10-23 18:54:20 +00:00
|
|
|
@requires_boto_gte("2.34.0")
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-10-23 18:54:20 +00:00
|
|
|
def test_routes_vpc_peering_connection():
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-10-23 18:54:20 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
2017-02-24 02:37:43 +00:00
|
|
|
main_route_table = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.main": "true", "vpc-id": vpc.id}
|
|
|
|
)[0]
|
2014-10-23 18:54:20 +00:00
|
|
|
local_route = main_route_table.routes[0]
|
|
|
|
ROUTE_CIDR = "10.0.0.4/24"
|
|
|
|
|
|
|
|
peer_vpc = conn.create_vpc("11.0.0.0/16")
|
|
|
|
vpc_pcx = conn.create_vpc_peering_connection(vpc.id, peer_vpc.id)
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
conn.create_route(
|
|
|
|
main_route_table.id, ROUTE_CIDR, vpc_peering_connection_id=vpc_pcx.id
|
|
|
|
)
|
2014-10-23 18:54:20 +00:00
|
|
|
|
|
|
|
# Refresh route table
|
|
|
|
main_route_table = conn.get_all_route_tables(main_route_table.id)[0]
|
2017-02-24 02:37:43 +00:00
|
|
|
new_routes = [
|
2019-10-31 15:44:26 +00:00
|
|
|
route
|
|
|
|
for route in main_route_table.routes
|
|
|
|
if route.destination_cidr_block != vpc.cidr_block
|
|
|
|
]
|
2014-10-23 18:54:20 +00:00
|
|
|
new_routes.should.have.length_of(1)
|
|
|
|
|
|
|
|
new_route = new_routes[0]
|
|
|
|
new_route.gateway_id.should.be.none
|
|
|
|
new_route.instance_id.should.be.none
|
|
|
|
new_route.vpc_peering_connection_id.should.equal(vpc_pcx.id)
|
2021-09-16 21:49:49 +00:00
|
|
|
new_route.state.should.equal("active")
|
2014-10-23 18:54:20 +00:00
|
|
|
new_route.destination_cidr_block.should.equal(ROUTE_CIDR)
|
2014-09-04 23:23:59 +00:00
|
|
|
|
2014-11-20 20:02:36 +00:00
|
|
|
|
2014-12-09 18:07:14 +00:00
|
|
|
@requires_boto_gte("2.34.0")
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-12-09 18:07:14 +00:00
|
|
|
def test_routes_vpn_gateway():
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the_secret")
|
2014-12-09 18:07:14 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
2017-02-24 02:37:43 +00:00
|
|
|
main_route_table = conn.get_all_route_tables(
|
2019-10-31 15:44:26 +00:00
|
|
|
filters={"association.main": "true", "vpc-id": vpc.id}
|
|
|
|
)[0]
|
2014-12-09 18:07:14 +00:00
|
|
|
ROUTE_CIDR = "10.0.0.4/24"
|
|
|
|
|
|
|
|
vpn_gw = conn.create_vpn_gateway(type="ipsec.1")
|
|
|
|
|
|
|
|
conn.create_route(main_route_table.id, ROUTE_CIDR, gateway_id=vpn_gw.id)
|
|
|
|
|
|
|
|
main_route_table = conn.get_all_route_tables(main_route_table.id)[0]
|
2017-02-24 02:37:43 +00:00
|
|
|
new_routes = [
|
2019-10-31 15:44:26 +00:00
|
|
|
route
|
|
|
|
for route in main_route_table.routes
|
|
|
|
if route.destination_cidr_block != vpc.cidr_block
|
|
|
|
]
|
2014-12-09 18:07:14 +00:00
|
|
|
new_routes.should.have.length_of(1)
|
|
|
|
|
|
|
|
new_route = new_routes[0]
|
|
|
|
new_route.gateway_id.should.equal(vpn_gw.id)
|
|
|
|
new_route.instance_id.should.be.none
|
|
|
|
new_route.vpc_peering_connection_id.should.be.none
|
|
|
|
|
|
|
|
|
2017-02-16 03:35:45 +00:00
|
|
|
@mock_ec2_deprecated
|
2014-11-20 20:02:36 +00:00
|
|
|
def test_network_acl_tagging():
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
conn = boto.connect_vpc("the_key", "the secret")
|
2014-11-20 20:02:36 +00:00
|
|
|
vpc = conn.create_vpc("10.0.0.0/16")
|
|
|
|
|
|
|
|
route_table = conn.create_route_table(vpc.id)
|
|
|
|
route_table.add_tag("a key", "some value")
|
|
|
|
|
|
|
|
tag = conn.get_all_tags()[0]
|
|
|
|
tag.name.should.equal("a key")
|
|
|
|
tag.value.should.equal("some value")
|
|
|
|
|
|
|
|
all_route_tables = conn.get_all_route_tables()
|
2019-10-31 15:44:26 +00:00
|
|
|
test_route_table = next(na for na in all_route_tables if na.id == route_table.id)
|
2014-11-20 20:02:36 +00:00
|
|
|
test_route_table.tags.should.have.length_of(1)
|
2016-03-02 11:15:47 +00:00
|
|
|
test_route_table.tags["a key"].should.equal("some value")
|
2019-05-25 17:35:07 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
def test_create_route_with_invalid_destination_cidr_block_parameter():
|
2019-10-31 15:44:26 +00:00
|
|
|
ec2 = boto3.resource("ec2", region_name="us-west-1")
|
2019-05-25 17:35:07 +00:00
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
2019-05-25 17:35:07 +00:00
|
|
|
vpc.reload()
|
|
|
|
vpc.is_default.shouldnt.be.ok
|
|
|
|
|
|
|
|
route_table = ec2.create_route_table(VpcId=vpc.id)
|
|
|
|
route_table.reload()
|
|
|
|
|
|
|
|
internet_gateway = ec2.create_internet_gateway()
|
|
|
|
vpc.attach_internet_gateway(InternetGatewayId=internet_gateway.id)
|
|
|
|
internet_gateway.reload()
|
|
|
|
|
2019-10-31 15:44:26 +00:00
|
|
|
destination_cidr_block = "1000.1.0.0/20"
|
2020-10-06 05:54:49 +00:00
|
|
|
with pytest.raises(ClientError) as ex:
|
2019-10-31 15:44:26 +00:00
|
|
|
route = route_table.create_route(
|
|
|
|
DestinationCidrBlock=destination_cidr_block, GatewayId=internet_gateway.id
|
|
|
|
)
|
2020-10-06 06:04:09 +00:00
|
|
|
str(ex.value).should.equal(
|
2019-05-25 17:35:07 +00:00
|
|
|
"An error occurred (InvalidParameterValue) when calling the CreateRoute "
|
2019-10-31 15:44:26 +00:00
|
|
|
"operation: Value ({}) for parameter destinationCidrBlock is invalid. This is not a valid CIDR block.".format(
|
|
|
|
destination_cidr_block
|
|
|
|
)
|
|
|
|
)
|
2019-12-02 18:20:00 +00:00
|
|
|
|
2020-07-07 13:32:55 +00:00
|
|
|
route_table.create_route(
|
|
|
|
DestinationIpv6CidrBlock="2001:db8::/125", GatewayId=internet_gateway.id
|
|
|
|
)
|
|
|
|
new_routes = [
|
|
|
|
route
|
|
|
|
for route in route_table.routes
|
|
|
|
if route.destination_cidr_block != vpc.cidr_block
|
2021-08-11 20:23:04 +00:00
|
|
|
or route.destination_ipv6_cidr_block != vpc.cidr_block
|
2020-07-07 13:32:55 +00:00
|
|
|
]
|
|
|
|
new_routes.should.have.length_of(1)
|
|
|
|
new_routes[0].route_table_id.shouldnt.be.equal(None)
|
|
|
|
|
2019-12-02 18:20:00 +00:00
|
|
|
|
2020-06-12 15:16:55 +00:00
|
|
|
@mock_ec2
|
|
|
|
def test_create_route_with_network_interface_id():
|
|
|
|
ec2 = boto3.resource("ec2", region_name="us-west-2")
|
|
|
|
ec2_client = boto3.client("ec2", region_name="us-west-2")
|
|
|
|
|
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
|
|
|
subnet = ec2.create_subnet(
|
|
|
|
VpcId=vpc.id, CidrBlock="10.0.0.0/24", AvailabilityZone="us-west-2a"
|
|
|
|
)
|
|
|
|
|
|
|
|
route_table = ec2_client.create_route_table(VpcId=vpc.id)
|
|
|
|
|
|
|
|
route_table_id = route_table["RouteTable"]["RouteTableId"]
|
|
|
|
|
|
|
|
eni1 = ec2_client.create_network_interface(
|
|
|
|
SubnetId=subnet.id, PrivateIpAddress="10.0.10.5"
|
|
|
|
)
|
|
|
|
|
|
|
|
route = ec2_client.create_route(
|
|
|
|
NetworkInterfaceId=eni1["NetworkInterface"]["NetworkInterfaceId"],
|
|
|
|
RouteTableId=route_table_id,
|
|
|
|
)
|
|
|
|
|
|
|
|
route["ResponseMetadata"]["HTTPStatusCode"].should.equal(200)
|
|
|
|
|
|
|
|
|
2019-12-02 18:20:00 +00:00
|
|
|
@mock_ec2
|
|
|
|
def test_describe_route_tables_with_nat_gateway():
|
|
|
|
ec2 = boto3.client("ec2", region_name="us-west-1")
|
|
|
|
vpc_id = ec2.create_vpc(CidrBlock="192.168.0.0/23")["Vpc"]["VpcId"]
|
|
|
|
igw_id = ec2.create_internet_gateway()["InternetGateway"]["InternetGatewayId"]
|
|
|
|
ec2.attach_internet_gateway(VpcId=vpc_id, InternetGatewayId=igw_id)
|
|
|
|
az = ec2.describe_availability_zones()["AvailabilityZones"][0]["ZoneName"]
|
|
|
|
sn_id = ec2.create_subnet(
|
|
|
|
AvailabilityZone=az, CidrBlock="192.168.0.0/24", VpcId=vpc_id
|
|
|
|
)["Subnet"]["SubnetId"]
|
|
|
|
route_table_id = ec2.create_route_table(VpcId=vpc_id)["RouteTable"]["RouteTableId"]
|
|
|
|
ec2.associate_route_table(SubnetId=sn_id, RouteTableId=route_table_id)
|
|
|
|
alloc_id = ec2.allocate_address(Domain="vpc")["AllocationId"]
|
|
|
|
nat_gw_id = ec2.create_nat_gateway(SubnetId=sn_id, AllocationId=alloc_id)[
|
|
|
|
"NatGateway"
|
|
|
|
]["NatGatewayId"]
|
|
|
|
ec2.create_route(
|
|
|
|
DestinationCidrBlock="0.0.0.0/0",
|
|
|
|
NatGatewayId=nat_gw_id,
|
|
|
|
RouteTableId=route_table_id,
|
|
|
|
)
|
|
|
|
|
|
|
|
route_table = ec2.describe_route_tables(
|
|
|
|
Filters=[{"Name": "route-table-id", "Values": [route_table_id]}]
|
|
|
|
)["RouteTables"][0]
|
|
|
|
nat_gw_routes = [
|
|
|
|
route
|
|
|
|
for route in route_table["Routes"]
|
|
|
|
if route["DestinationCidrBlock"] == "0.0.0.0/0"
|
|
|
|
]
|
|
|
|
|
|
|
|
nat_gw_routes.should.have.length_of(1)
|
|
|
|
nat_gw_routes[0]["DestinationCidrBlock"].should.equal("0.0.0.0/0")
|
|
|
|
nat_gw_routes[0]["NatGatewayId"].should.equal(nat_gw_id)
|
|
|
|
nat_gw_routes[0]["State"].should.equal("active")
|
2020-04-28 18:58:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
def test_create_vpc_end_point():
|
|
|
|
|
|
|
|
ec2 = boto3.client("ec2", region_name="us-west-1")
|
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
2020-04-29 15:29:25 +00:00
|
|
|
subnet = ec2.create_subnet(VpcId=vpc["Vpc"]["VpcId"], CidrBlock="10.0.0.0/24")
|
2020-04-28 18:58:19 +00:00
|
|
|
|
|
|
|
route_table = ec2.create_route_table(VpcId=vpc["Vpc"]["VpcId"])
|
|
|
|
|
2020-04-29 12:32:02 +00:00
|
|
|
# test without any end point type specified
|
2020-04-28 18:58:19 +00:00
|
|
|
vpc_end_point = ec2.create_vpc_endpoint(
|
|
|
|
VpcId=vpc["Vpc"]["VpcId"],
|
|
|
|
ServiceName="com.amazonaws.us-east-1.s3",
|
2020-04-29 15:29:25 +00:00
|
|
|
RouteTableIds=[route_table["RouteTable"]["RouteTableId"]],
|
|
|
|
)
|
2020-04-28 18:58:19 +00:00
|
|
|
|
2020-04-29 15:29:25 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["ServiceName"].should.equal(
|
|
|
|
"com.amazonaws.us-east-1.s3"
|
|
|
|
)
|
|
|
|
vpc_end_point["VpcEndpoint"]["RouteTableIds"][0].should.equal(
|
|
|
|
route_table["RouteTable"]["RouteTableId"]
|
|
|
|
)
|
2020-04-28 18:58:19 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["VpcId"].should.equal(vpc["Vpc"]["VpcId"])
|
2020-04-29 12:32:02 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["DnsEntries"].should.have.length_of(0)
|
2020-04-28 18:58:19 +00:00
|
|
|
|
2020-04-29 12:32:02 +00:00
|
|
|
# test with any end point type as gateway
|
|
|
|
vpc_end_point = ec2.create_vpc_endpoint(
|
|
|
|
VpcId=vpc["Vpc"]["VpcId"],
|
|
|
|
ServiceName="com.amazonaws.us-east-1.s3",
|
|
|
|
RouteTableIds=[route_table["RouteTable"]["RouteTableId"]],
|
2020-04-29 15:29:25 +00:00
|
|
|
VpcEndpointType="gateway",
|
2020-04-29 12:32:02 +00:00
|
|
|
)
|
|
|
|
|
2020-04-29 15:29:25 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["ServiceName"].should.equal(
|
|
|
|
"com.amazonaws.us-east-1.s3"
|
|
|
|
)
|
|
|
|
vpc_end_point["VpcEndpoint"]["RouteTableIds"][0].should.equal(
|
|
|
|
route_table["RouteTable"]["RouteTableId"]
|
|
|
|
)
|
2020-04-29 12:32:02 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["VpcId"].should.equal(vpc["Vpc"]["VpcId"])
|
|
|
|
vpc_end_point["VpcEndpoint"]["DnsEntries"].should.have.length_of(0)
|
|
|
|
|
|
|
|
# test with end point type as interface
|
2020-04-28 18:58:19 +00:00
|
|
|
vpc_end_point = ec2.create_vpc_endpoint(
|
|
|
|
VpcId=vpc["Vpc"]["VpcId"],
|
|
|
|
ServiceName="com.amazonaws.us-east-1.s3",
|
|
|
|
SubnetIds=[subnet["Subnet"]["SubnetId"]],
|
2020-04-29 15:29:25 +00:00
|
|
|
VpcEndpointType="interface",
|
2020-04-28 18:58:19 +00:00
|
|
|
)
|
|
|
|
|
2020-04-29 15:29:25 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["ServiceName"].should.equal(
|
|
|
|
"com.amazonaws.us-east-1.s3"
|
|
|
|
)
|
|
|
|
vpc_end_point["VpcEndpoint"]["SubnetIds"][0].should.equal(
|
|
|
|
subnet["Subnet"]["SubnetId"]
|
|
|
|
)
|
2020-04-28 18:58:19 +00:00
|
|
|
vpc_end_point["VpcEndpoint"]["VpcId"].should.equal(vpc["Vpc"]["VpcId"])
|
2020-04-29 15:29:25 +00:00
|
|
|
len(vpc_end_point["VpcEndpoint"]["DnsEntries"]).should.be.greater_than(0)
|
2020-11-02 13:30:02 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
def test_create_route_tables_with_tags():
|
|
|
|
ec2 = boto3.resource("ec2", region_name="eu-central-1")
|
|
|
|
|
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
|
|
|
|
|
|
|
route_table = ec2.create_route_table(
|
|
|
|
VpcId=vpc.id,
|
|
|
|
TagSpecifications=[
|
|
|
|
{
|
|
|
|
"ResourceType": "route-table",
|
|
|
|
"Tags": [{"Key": "test", "Value": "TestRouteTable"}],
|
|
|
|
}
|
|
|
|
],
|
|
|
|
)
|
|
|
|
|
|
|
|
route_table.tags.should.have.length_of(1)
|
2021-03-16 14:15:58 +00:00
|
|
|
|
|
|
|
|
2021-08-27 10:28:10 +00:00
|
|
|
@mock_ec2
|
|
|
|
def test_create_route_with_egress_only_igw():
|
|
|
|
ec2 = boto3.resource("ec2", region_name="eu-central-1")
|
|
|
|
ec2_client = boto3.client("ec2", region_name="eu-central-1")
|
|
|
|
|
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
|
|
|
eigw = ec2_client.create_egress_only_internet_gateway(VpcId=vpc.id)
|
|
|
|
eigw_id = eigw["EgressOnlyInternetGateway"]["EgressOnlyInternetGatewayId"]
|
|
|
|
|
|
|
|
route_table = ec2.create_route_table(VpcId=vpc.id)
|
|
|
|
|
|
|
|
ec2_client.create_route(
|
2021-09-16 21:49:49 +00:00
|
|
|
RouteTableId=route_table.id,
|
|
|
|
EgressOnlyInternetGatewayId=eigw_id,
|
|
|
|
DestinationIpv6CidrBlock="::/0",
|
2021-08-27 10:28:10 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
route_table.reload()
|
2021-09-16 21:49:49 +00:00
|
|
|
eigw_route = [
|
|
|
|
r
|
|
|
|
for r in route_table.routes_attribute
|
|
|
|
if r.get("DestinationIpv6CidrBlock") == "::/0"
|
|
|
|
][0]
|
|
|
|
eigw_route.get("EgressOnlyInternetGatewayId").should.equal(eigw_id)
|
|
|
|
eigw_route.get("State").should.equal("active")
|
2021-08-27 10:28:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
def test_create_route_with_unknown_egress_only_igw():
|
|
|
|
ec2 = boto3.resource("ec2", region_name="eu-central-1")
|
|
|
|
ec2_client = boto3.client("ec2", region_name="eu-central-1")
|
|
|
|
|
|
|
|
vpc = ec2.create_vpc(CidrBlock="10.0.0.0/16")
|
|
|
|
subnet = ec2.create_subnet(
|
|
|
|
VpcId=vpc.id, CidrBlock="10.0.0.0/24", AvailabilityZone="us-west-2a"
|
|
|
|
)
|
|
|
|
|
|
|
|
route_table = ec2.create_route_table(VpcId=vpc.id)
|
|
|
|
|
|
|
|
with pytest.raises(ClientError) as ex:
|
|
|
|
ec2_client.create_route(
|
|
|
|
RouteTableId=route_table.id, EgressOnlyInternetGatewayId="eoigw"
|
|
|
|
)
|
|
|
|
err = ex.value.response["Error"]
|
|
|
|
err["Code"].should.equal("InvalidGatewayID.NotFound")
|
|
|
|
err["Message"].should.equal("The eigw ID 'eoigw' does not exist")
|
|
|
|
|
|
|
|
|
2021-03-16 14:15:58 +00:00
|
|
|
@mock_ec2
|
|
|
|
def test_associate_route_table_by_gateway():
|
|
|
|
ec2 = boto3.client("ec2", region_name="us-west-1")
|
|
|
|
vpc_id = ec2.create_vpc(CidrBlock="10.0.0.0/16")["Vpc"]["VpcId"]
|
|
|
|
route_table_id = ec2.create_route_table(VpcId=vpc_id)["RouteTable"]["RouteTableId"]
|
|
|
|
igw_id = ec2.create_internet_gateway()["InternetGateway"]["InternetGatewayId"]
|
|
|
|
assoc_id = ec2.associate_route_table(
|
|
|
|
RouteTableId=route_table_id, GatewayId=igw_id,
|
|
|
|
)["AssociationId"]
|
|
|
|
verify = ec2.describe_route_tables(
|
|
|
|
Filters=[
|
|
|
|
{"Name": "association.route-table-association-id", "Values": [assoc_id]}
|
|
|
|
]
|
|
|
|
)["RouteTables"]
|
|
|
|
verify[0]["Associations"][0]["RouteTableAssociationId"].should.equal(assoc_id)
|
|
|
|
|
|
|
|
|
|
|
|
@mock_ec2
|
|
|
|
def test_associate_route_table_by_subnet():
|
|
|
|
ec2 = boto3.client("ec2", region_name="us-west-1")
|
|
|
|
vpc_id = ec2.create_vpc(CidrBlock="10.0.0.0/16")["Vpc"]["VpcId"]
|
|
|
|
route_table_id = ec2.create_route_table(VpcId=vpc_id)["RouteTable"]["RouteTableId"]
|
|
|
|
subnet_id = ec2.create_subnet(VpcId=vpc_id, CidrBlock="10.0.0.0/24")["Subnet"][
|
|
|
|
"SubnetId"
|
|
|
|
]
|
|
|
|
assoc_id = ec2.associate_route_table(
|
|
|
|
RouteTableId=route_table_id, SubnetId=subnet_id,
|
|
|
|
)["AssociationId"]
|
|
|
|
verify = ec2.describe_route_tables(
|
|
|
|
Filters=[
|
|
|
|
{"Name": "association.route-table-association-id", "Values": [assoc_id]}
|
|
|
|
]
|
|
|
|
)["RouteTables"]
|
|
|
|
verify[0]["Associations"][0]["RouteTableAssociationId"].should.equal(assoc_id)
|