blob: c97efe9f82fc9846494f7da6ebf2651021b81203 [file] [log] [blame]
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -07001# Copyright 2013 OpenStack Foundation
2# All Rights Reserved.
3#
4# Licensed under the Apache License, Version 2.0 (the "License"); you may
5# not use this file except in compliance with the License. You may obtain
6# a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13# License for the specific language governing permissions and limitations
14# under the License.
15
16import testtools
17
18from tempest.api.network import base
Andrea Frittolicd368412017-08-14 21:37:56 +010019from tempest.common import utils
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -070020from tempest import config
21from tempest.lib.common.utils import data_utils
22from tempest.lib import decorators
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -070023
24CONF = config.CONF
25
26
27class RoutersAdminTest(base.BaseAdminNetworkTest):
28 # NOTE(salv-orlando): This class inherits from BaseAdminNetworkTest
29 # as some router operations, such as enabling or disabling SNAT
30 # require admin credentials by default
31
32 def _cleanup_router(self, router):
33 self.delete_router(router)
34 self.routers.remove(router)
35
36 def _create_router(self, name=None, admin_state_up=False,
37 external_network_id=None, enable_snat=None):
38 # associate a cleanup with created routers to avoid quota limits
39 router = self.create_router(name, admin_state_up,
40 external_network_id, enable_snat)
41 self.addCleanup(self._cleanup_router, router)
42 return router
43
44 def _add_router_interface_with_subnet_id(self, router_id, subnet_id):
45 interface = self.routers_client.add_router_interface(
46 router_id, subnet_id=subnet_id)
47 self.addCleanup(self._remove_router_interface_with_subnet_id,
48 router_id, subnet_id)
49 self.assertEqual(subnet_id, interface['subnet_id'])
50 return interface
51
52 def _remove_router_interface_with_subnet_id(self, router_id, subnet_id):
53 body = self.routers_client.remove_router_interface(router_id,
54 subnet_id=subnet_id)
55 self.assertEqual(subnet_id, body['subnet_id'])
56
57 @classmethod
58 def skip_checks(cls):
59 super(RoutersAdminTest, cls).skip_checks()
Andrea Frittolicd368412017-08-14 21:37:56 +010060 if not utils.is_extension_enabled('router', 'network'):
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -070061 msg = "router extension not enabled."
62 raise cls.skipException(msg)
63
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -070064 @decorators.idempotent_id('e54dd3a3-4352-4921-b09d-44369ae17397')
65 def test_create_router_setting_project_id(self):
66 # Test creating router from admin user setting project_id.
67 project = data_utils.rand_name('test_tenant_')
68 description = data_utils.rand_name('desc_')
69 project = self.identity_utils.create_project(name=project,
70 description=description)
71 project_id = project['id']
72 self.addCleanup(self.identity_utils.delete_project, project_id)
73
74 name = data_utils.rand_name('router-')
75 create_body = self.admin_routers_client.create_router(
76 name=name, tenant_id=project_id)
77 self.addCleanup(self.admin_routers_client.delete_router,
78 create_body['router']['id'])
79 self.assertEqual(project_id, create_body['router']['tenant_id'])
80
81 @decorators.idempotent_id('847257cc-6afd-4154-b8fb-af49f5670ce8')
Andrea Frittolicd368412017-08-14 21:37:56 +010082 @utils.requires_ext(extension='ext-gw-mode', service='network')
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -070083 @testtools.skipUnless(CONF.network.public_network_id,
84 'The public_network_id option must be specified.')
85 def test_create_router_with_default_snat_value(self):
86 # Create a router with default snat rule
87 router = self._create_router(
88 external_network_id=CONF.network.public_network_id)
89 self._verify_router_gateway(
90 router['id'], {'network_id': CONF.network.public_network_id,
91 'enable_snat': True})
92
93 @decorators.idempotent_id('ea74068d-09e9-4fd7-8995-9b6a1ace920f')
Andrea Frittolicd368412017-08-14 21:37:56 +010094 @utils.requires_ext(extension='ext-gw-mode', service='network')
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -070095 @testtools.skipUnless(CONF.network.public_network_id,
96 'The public_network_id option must be specified.')
97 def test_create_router_with_snat_explicit(self):
98 name = data_utils.rand_name('snat-router')
99 # Create a router enabling snat attributes
100 enable_snat_states = [False, True]
101 for enable_snat in enable_snat_states:
102 external_gateway_info = {
103 'network_id': CONF.network.public_network_id,
104 'enable_snat': enable_snat}
105 create_body = self.admin_routers_client.create_router(
106 name=name, external_gateway_info=external_gateway_info)
107 self.addCleanup(self.admin_routers_client.delete_router,
108 create_body['router']['id'])
109 # Verify snat attributes after router creation
110 self._verify_router_gateway(create_body['router']['id'],
111 exp_ext_gw_info=external_gateway_info)
112
113 def _verify_router_gateway(self, router_id, exp_ext_gw_info=None):
114 show_body = self.admin_routers_client.show_router(router_id)
115 actual_ext_gw_info = show_body['router']['external_gateway_info']
116 if exp_ext_gw_info is None:
117 self.assertIsNone(actual_ext_gw_info)
118 return
119 # Verify only keys passed in exp_ext_gw_info
120 for k, v in exp_ext_gw_info.items():
121 self.assertEqual(v, actual_ext_gw_info[k])
122
123 def _verify_gateway_port(self, router_id):
124 list_body = self.admin_ports_client.list_ports(
125 network_id=CONF.network.public_network_id,
126 device_id=router_id)
127 self.assertEqual(len(list_body['ports']), 1)
128 gw_port = list_body['ports'][0]
129 fixed_ips = gw_port['fixed_ips']
Ferenc Horváth268ccce2017-06-08 12:39:02 +0200130 self.assertNotEmpty(fixed_ips)
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -0700131 # Assert that all of the IPs from the router gateway port
132 # are allocated from a valid public subnet.
133 public_net_body = self.admin_networks_client.show_network(
134 CONF.network.public_network_id)
135 public_subnet_ids = public_net_body['network']['subnets']
136 for fixed_ip in fixed_ips:
137 subnet_id = fixed_ip['subnet_id']
138 self.assertIn(subnet_id, public_subnet_ids)
139
140 @decorators.idempotent_id('6cc285d8-46bf-4f36-9b1a-783e3008ba79')
141 @testtools.skipUnless(CONF.network.public_network_id,
142 'The public_network_id option must be specified.')
143 def test_update_router_set_gateway(self):
144 router = self._create_router()
145 self.routers_client.update_router(
146 router['id'],
147 external_gateway_info={
148 'network_id': CONF.network.public_network_id})
149 # Verify operation - router
150 self._verify_router_gateway(
151 router['id'],
152 {'network_id': CONF.network.public_network_id})
153 self._verify_gateway_port(router['id'])
154
155 @decorators.idempotent_id('b386c111-3b21-466d-880c-5e72b01e1a33')
Andrea Frittolicd368412017-08-14 21:37:56 +0100156 @utils.requires_ext(extension='ext-gw-mode', service='network')
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -0700157 @testtools.skipUnless(CONF.network.public_network_id,
158 'The public_network_id option must be specified.')
159 def test_update_router_set_gateway_with_snat_explicit(self):
160 router = self._create_router()
161 self.admin_routers_client.update_router(
162 router['id'],
163 external_gateway_info={
164 'network_id': CONF.network.public_network_id,
165 'enable_snat': True})
166 self._verify_router_gateway(
167 router['id'],
168 {'network_id': CONF.network.public_network_id,
169 'enable_snat': True})
170 self._verify_gateway_port(router['id'])
171
172 @decorators.idempotent_id('96536bc7-8262-4fb2-9967-5c46940fa279')
Andrea Frittolicd368412017-08-14 21:37:56 +0100173 @utils.requires_ext(extension='ext-gw-mode', service='network')
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -0700174 @testtools.skipUnless(CONF.network.public_network_id,
175 'The public_network_id option must be specified.')
176 def test_update_router_set_gateway_without_snat(self):
177 router = self._create_router()
178 self.admin_routers_client.update_router(
179 router['id'],
180 external_gateway_info={
181 'network_id': CONF.network.public_network_id,
182 'enable_snat': False})
183 self._verify_router_gateway(
184 router['id'],
185 {'network_id': CONF.network.public_network_id,
186 'enable_snat': False})
187 self._verify_gateway_port(router['id'])
188
189 @decorators.idempotent_id('ad81b7ee-4f81-407b-a19c-17e623f763e8')
190 @testtools.skipUnless(CONF.network.public_network_id,
191 'The public_network_id option must be specified.')
192 def test_update_router_unset_gateway(self):
193 router = self._create_router(
194 external_network_id=CONF.network.public_network_id)
195 self.routers_client.update_router(router['id'],
196 external_gateway_info={})
197 self._verify_router_gateway(router['id'])
198 # No gateway port expected
199 list_body = self.admin_ports_client.list_ports(
200 network_id=CONF.network.public_network_id,
201 device_id=router['id'])
202 self.assertFalse(list_body['ports'])
203
204 @decorators.idempotent_id('f2faf994-97f4-410b-a831-9bc977b64374')
Andrea Frittolicd368412017-08-14 21:37:56 +0100205 @utils.requires_ext(extension='ext-gw-mode', service='network')
Ken'ichi Ohmichi3204a0e2017-05-04 18:44:28 -0700206 @testtools.skipUnless(CONF.network.public_network_id,
207 'The public_network_id option must be specified.')
208 def test_update_router_reset_gateway_without_snat(self):
209 router = self._create_router(
210 external_network_id=CONF.network.public_network_id)
211 self.admin_routers_client.update_router(
212 router['id'],
213 external_gateway_info={
214 'network_id': CONF.network.public_network_id,
215 'enable_snat': False})
216 self._verify_router_gateway(
217 router['id'],
218 {'network_id': CONF.network.public_network_id,
219 'enable_snat': False})
220 self._verify_gateway_port(router['id'])
221
222
223class RoutersIpV6AdminTest(RoutersAdminTest):
224 _ip_version = 6