blob: 190f7e02922cc0c119947b3e029970989abf8f7b [file] [log] [blame]
Elena Ezhova1ec6e182013-12-24 17:45:59 +04001# Copyright 2014 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
Hongbin Lu0ac946c2017-12-04 20:50:33 +000016import ipaddress
17
Matthew Treinish01472ff2015-02-20 17:26:52 -050018import netaddr
zhuflfffec232016-09-18 17:09:11 +080019import testtools
Matthew Treinish01472ff2015-02-20 17:26:52 -050020
Neeti Dahiyade291772014-09-22 10:43:12 +053021from tempest.api.network import base_security_groups as sec_base
Santosh Kumarf0cbf9a2014-08-25 07:31:15 -070022from tempest.common import custom_matchers
Andrea Frittolicd368412017-08-14 21:37:56 +010023from tempest.common import utils
Ken'ichi Ohmichif50e4df2017-03-10 10:52:53 -080024from tempest.lib.common.utils import data_utils
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +020025from tempest.lib.common.utils import test_utils
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -080026from tempest.lib import decorators
Matthew Treinish4217a702016-10-07 17:27:11 -040027from tempest.lib import exceptions
Elena Ezhova1ec6e182013-12-24 17:45:59 +040028
Elena Ezhova1ec6e182013-12-24 17:45:59 +040029
Neeti Dahiyade291772014-09-22 10:43:12 +053030class PortsTestJSON(sec_base.BaseSecGroupTest):
Ken'ichi Ohmichie03bea92015-11-19 07:45:58 +000031 """Test the following operations for ports:
Elena Ezhova5c957152014-03-26 12:01:10 +040032
33 port create
34 port delete
35 port list
36 port show
37 port update
38 """
39
Elena Ezhova1ec6e182013-12-24 17:45:59 +040040 @classmethod
Andrea Frittolida4a2452014-09-15 13:12:08 +010041 def resource_setup(cls):
42 super(PortsTestJSON, cls).resource_setup()
Elena Ezhova1ec6e182013-12-24 17:45:59 +040043 cls.network = cls.create_network()
44 cls.port = cls.create_port(cls.network)
45
46 def _delete_port(self, port_id):
John Warren49c0fe52015-10-22 12:35:54 -040047 self.ports_client.delete_port(port_id)
48 body = self.ports_client.list_ports()
Elena Ezhova1ec6e182013-12-24 17:45:59 +040049 ports_list = body['ports']
50 self.assertFalse(port_id in [n['id'] for n in ports_list])
51
deepak_mouryab4fb4382018-06-04 10:11:32 +053052 def _create_subnet(self, network, gateway='',
53 cidr=None, mask_bits=None, **kwargs):
likangkang01b87ef292021-09-09 08:54:04 +080054 subnet = self.create_subnet(
55 network, gateway, cidr, mask_bits, **kwargs)
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +020056 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
57 self.subnets_client.delete_subnet, subnet['id'])
deepak_mouryab4fb4382018-06-04 10:11:32 +053058 return subnet
59
60 def _create_network(self, network_name=None, **kwargs):
61 network_name = network_name or data_utils.rand_name(
62 self.__class__.__name__)
63 network = self.networks_client.create_network(
64 name=network_name, **kwargs)['network']
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +020065 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
66 self.networks_client.delete_network,
deepak_mouryab4fb4382018-06-04 10:11:32 +053067 network['id'])
68 return network
69
Jordan Pittier3b46d272017-04-12 16:17:28 +020070 @decorators.attr(type='smoke')
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -080071 @decorators.idempotent_id('c72c1c0c-2193-4aca-aaa4-b1442640f51c')
Elena Ezhova1ec6e182013-12-24 17:45:59 +040072 def test_create_update_delete_port(self):
zhufl4810d882020-04-22 16:14:19 +080073 """Test creating, updating and deleting port"""
Elena Ezhova1ec6e182013-12-24 17:45:59 +040074 # Verify port creation
Doug Schveninger24675aa2019-08-16 22:28:39 -050075 body = self.ports_client.create_port(
76 network_id=self.network['id'],
77 name=data_utils.rand_name(self.__class__.__name__))
Elena Ezhova1ec6e182013-12-24 17:45:59 +040078 port = body['port']
Dane LeBlanccbc4bc52014-03-19 16:03:23 -040079 # Schedule port deletion with verification upon test completion
Hemachandra Reddye866da92020-08-28 21:49:49 +000080 self.addCleanup(self.ports_client.wait_for_resource_deletion,
81 port['id'])
Dane LeBlanccbc4bc52014-03-19 16:03:23 -040082 self.addCleanup(self._delete_port, port['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +040083 self.assertTrue(port['admin_state_up'])
84 # Verify port update
85 new_name = "New_Port"
John Warren49c0fe52015-10-22 12:35:54 -040086 body = self.ports_client.update_port(port['id'],
87 name=new_name,
88 admin_state_up=False)
Elena Ezhova1ec6e182013-12-24 17:45:59 +040089 updated_port = body['port']
90 self.assertEqual(updated_port['name'], new_name)
91 self.assertFalse(updated_port['admin_state_up'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +040092
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -080093 @decorators.idempotent_id('67f1b811-f8db-43e2-86bd-72c074d4a42c')
abhishek6001472607373102014-11-25 04:39:20 -080094 def test_create_bulk_port(self):
zhufl4810d882020-04-22 16:14:19 +080095 """Test creating multiple ports in a single request"""
abhishek6001472607373102014-11-25 04:39:20 -080096 network1 = self.network
deepak_mouryab4fb4382018-06-04 10:11:32 +053097 network2 = self._create_network()
abhishek6001472607373102014-11-25 04:39:20 -080098 network_list = [network1['id'], network2['id']]
99 port_list = [{'network_id': net_id} for net_id in network_list]
Ken'ichi Ohmichi1f52fd92016-03-03 12:24:12 -0800100 body = self.ports_client.create_bulk_ports(ports=port_list)
abhishek6001472607373102014-11-25 04:39:20 -0800101 created_ports = body['ports']
102 port1 = created_ports[0]
103 port2 = created_ports[1]
Hemachandra Reddye866da92020-08-28 21:49:49 +0000104 self.addCleanup(self.ports_client.wait_for_resource_deletion,
105 port1['id'])
106 self.addCleanup(self.ports_client.wait_for_resource_deletion,
107 port2['id'])
abhishek6001472607373102014-11-25 04:39:20 -0800108 self.addCleanup(self._delete_port, port1['id'])
109 self.addCleanup(self._delete_port, port2['id'])
110 self.assertEqual(port1['network_id'], network1['id'])
111 self.assertEqual(port2['network_id'], network2['id'])
112 self.assertTrue(port1['admin_state_up'])
113 self.assertTrue(port2['admin_state_up'])
114
Jordan Pittier3b46d272017-04-12 16:17:28 +0200115 @decorators.attr(type='smoke')
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800116 @decorators.idempotent_id('0435f278-40ae-48cb-a404-b8a087bc09b1')
abhishek60014726de45a5e2014-12-16 03:01:35 -0800117 def test_create_port_in_allowed_allocation_pools(self):
zhufl4810d882020-04-22 16:14:19 +0800118 """Test creating port in allowed allocation pools"""
deepak_mouryab4fb4382018-06-04 10:11:32 +0530119 network = self._create_network()
abhishek60014726de45a5e2014-12-16 03:01:35 -0800120 net_id = network['id']
zhuflec61bac2017-09-01 15:59:50 +0800121 address = self.cidr
122 address.prefixlen = self.mask_bits
Guillaume Chenuetbdf1d8d2015-11-09 16:10:48 +0100123 if ((address.version == 4 and address.prefixlen >= 30) or
afazekas40fcb9b2019-03-08 11:25:11 +0100124 (address.version == 6 and address.prefixlen >= 126)):
Guillaume Chenuetbdf1d8d2015-11-09 16:10:48 +0100125 msg = ("Subnet %s isn't large enough for the test" % address.cidr)
zhuflff30ede2016-12-27 10:29:13 +0800126 raise exceptions.InvalidConfiguration(msg)
Guillaume Chenuetbdf1d8d2015-11-09 16:10:48 +0100127 allocation_pools = {'allocation_pools': [{'start': str(address[2]),
128 'end': str(address[-2])}]}
deepak_mouryab4fb4382018-06-04 10:11:32 +0530129 self._create_subnet(network, cidr=address,
130 mask_bits=address.prefixlen,
131 **allocation_pools)
Doug Schveninger24675aa2019-08-16 22:28:39 -0500132 body = self.ports_client.create_port(
133 network_id=net_id,
134 name=data_utils.rand_name(self.__class__.__name__))
Hemachandra Reddye866da92020-08-28 21:49:49 +0000135 self.addCleanup(self.ports_client.wait_for_resource_deletion,
136 body['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200137 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
138 self.ports_client.delete_port, body['port']['id'])
abhishek60014726de45a5e2014-12-16 03:01:35 -0800139 port = body['port']
140 ip_address = port['fixed_ips'][0]['ip_address']
141 start_ip_address = allocation_pools['allocation_pools'][0]['start']
142 end_ip_address = allocation_pools['allocation_pools'][0]['end']
143 ip_range = netaddr.IPRange(start_ip_address, end_ip_address)
144 self.assertIn(ip_address, ip_range)
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200145 self.ports_client.delete_port(port['id'])
abhishek60014726de45a5e2014-12-16 03:01:35 -0800146
Jordan Pittier3b46d272017-04-12 16:17:28 +0200147 @decorators.attr(type='smoke')
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800148 @decorators.idempotent_id('c9a685bd-e83f-499c-939f-9f7863ca259f')
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400149 def test_show_port(self):
zhufl4810d882020-04-22 16:14:19 +0800150 """Verify the details of port"""
John Warren49c0fe52015-10-22 12:35:54 -0400151 body = self.ports_client.show_port(self.port['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400152 port = body['port']
153 self.assertIn('id', port)
Rafael Folco72788022016-03-24 13:02:09 +0000154 # NOTE(rfolco): created_at and updated_at may get inconsistent values
155 # due to possible delay between POST request and resource creation.
156 # TODO(rfolco): Neutron Bug #1365341 is fixed, can remove the key
157 # extra_dhcp_opts in the O release (K/L gate jobs still need it).
Santosh Kumarf0cbf9a2014-08-25 07:31:15 -0700158 self.assertThat(self.port,
159 custom_matchers.MatchesDictExceptForKeys
Rafael Folco72788022016-03-24 13:02:09 +0000160 (port, excluded_keys=['extra_dhcp_opts',
161 'created_at',
162 'updated_at']))
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400163
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800164 @decorators.idempotent_id('45fcdaf2-dab0-4c13-ac6c-fcddfb579dbd')
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400165 def test_show_port_fields(self):
zhufl4810d882020-04-22 16:14:19 +0800166 """Verify specific fields of a port"""
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500167 fields = ['id', 'mac_address']
John Warren49c0fe52015-10-22 12:35:54 -0400168 body = self.ports_client.show_port(self.port['id'],
169 fields=fields)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400170 port = body['port']
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500171 self.assertEqual(sorted(port.keys()), sorted(fields))
172 for field_name in fields:
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400173 self.assertEqual(port[field_name], self.port[field_name])
174
Jordan Pittier3b46d272017-04-12 16:17:28 +0200175 @decorators.attr(type='smoke')
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800176 @decorators.idempotent_id('cf95b358-3e92-4a29-a148-52445e1ac50e')
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400177 def test_list_ports(self):
zhufl4810d882020-04-22 16:14:19 +0800178 """Verify the port exists in the list of all ports"""
John Warren49c0fe52015-10-22 12:35:54 -0400179 body = self.ports_client.list_ports()
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400180 ports = [port['id'] for port in body['ports']
181 if port['id'] == self.port['id']]
182 self.assertNotEmpty(ports, "Created port not found in the list")
183
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800184 @decorators.idempotent_id('e7fe260b-1e79-4dd3-86d9-bec6a7959fc5')
Arx Cruze8dfad92015-05-29 09:57:14 +0200185 def test_port_list_filter_by_ip(self):
zhufl4810d882020-04-22 16:14:19 +0800186 """Test listing ports filtered by ip"""
Arx Cruze8dfad92015-05-29 09:57:14 +0200187 # Create network and subnet
deepak_mouryab4fb4382018-06-04 10:11:32 +0530188 network = self._create_network()
189 self._create_subnet(network)
Yaroslav Lobankov5d71ac82015-06-16 16:43:43 +0300190 # Create two ports
Doug Schveninger24675aa2019-08-16 22:28:39 -0500191 port_1 = self.ports_client.create_port(
192 network_id=network['id'],
193 name=data_utils.rand_name(self.__class__.__name__))
Hemachandra Reddye866da92020-08-28 21:49:49 +0000194 self.addCleanup(self.ports_client.wait_for_resource_deletion,
195 port_1['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200196 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
197 self.ports_client.delete_port, port_1['port']['id'])
Doug Schveninger24675aa2019-08-16 22:28:39 -0500198 port_2 = self.ports_client.create_port(
199 network_id=network['id'],
200 name=data_utils.rand_name(self.__class__.__name__))
Hemachandra Reddye866da92020-08-28 21:49:49 +0000201 self.addCleanup(self.ports_client.wait_for_resource_deletion,
202 port_2['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200203 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
204 self.ports_client.delete_port, port_2['port']['id'])
Arx Cruze8dfad92015-05-29 09:57:14 +0200205 # List ports filtered by fixed_ips
Yaroslav Lobankov5d71ac82015-06-16 16:43:43 +0300206 port_1_fixed_ip = port_1['port']['fixed_ips'][0]['ip_address']
207 fixed_ips = 'ip_address=' + port_1_fixed_ip
John Warren49c0fe52015-10-22 12:35:54 -0400208 port_list = self.ports_client.list_ports(fixed_ips=fixed_ips)
Yaroslav Lobankov5d71ac82015-06-16 16:43:43 +0300209 # Check that we got the desired port
Arx Cruze8dfad92015-05-29 09:57:14 +0200210 ports = port_list['ports']
Rodolfo Alonso Hernandezc1449d42020-02-15 13:24:28 +0000211 project_ids = set([port['project_id'] for port in ports])
212 self.assertEqual(len(project_ids), 1,
213 'Ports from multiple projects are in the list resp')
Matthew Treinish1d942542015-08-25 18:16:14 -0400214 port_ids = [port['id'] for port in ports]
215 fixed_ips = [port['fixed_ips'] for port in ports]
Matthew Treinish1d942542015-08-25 18:16:14 -0400216 port_net_ids = [port['network_id'] for port in ports]
217 self.assertIn(port_1['port']['id'], port_ids)
Matthew Treinish1d942542015-08-25 18:16:14 -0400218 self.assertIn(network['id'], port_net_ids)
Sphicas, Phil (ps3910)0ff7e3d2019-08-15 20:34:02 -0700219 # Check that every port has a fixed_ip that matches the query
220 for addr in fixed_ips:
221 port_ips = [port['ip_address'] for port in addr]
222 self.assertIn(port_1_fixed_ip, port_ips,
223 'Port not matching IP filter found')
Arx Cruze8dfad92015-05-29 09:57:14 +0200224
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000225 @decorators.idempotent_id('79895408-85d5-460d-94e7-9531c5fd9123')
226 @testtools.skipUnless(
227 utils.is_extension_enabled('ip-substring-filtering', 'network'),
228 'ip-substring-filtering extension not enabled.')
229 def test_port_list_filter_by_ip_substr(self):
zhufl4810d882020-04-22 16:14:19 +0800230 """Test listing ports filtered by part of ip address string"""
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000231 # Create network and subnet
deepak_mouryab4fb4382018-06-04 10:11:32 +0530232 network = self._create_network()
233 subnet = self._create_subnet(network)
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000234 # Get two IP addresses
235 ip_address_1 = None
236 ip_address_2 = None
likui19b70a32020-12-02 13:25:18 +0800237 ip_network = ipaddress.ip_network(str(subnet['cidr']))
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000238 for ip in ip_network:
239 if ip == ip_network.network_address:
240 continue
241 if ip_address_1 is None:
likui19b70a32020-12-02 13:25:18 +0800242 ip_address_1 = str(ip)
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000243 else:
244 ip_address_2 = ip_address_1
likui19b70a32020-12-02 13:25:18 +0800245 ip_address_1 = str(ip)
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000246 # Make sure these two IP addresses have different substring
247 if ip_address_1[:-1] != ip_address_2[:-1]:
248 break
249
250 # Create two ports
251 fixed_ips = [{'subnet_id': subnet['id'], 'ip_address': ip_address_1}]
Doug Schveninger24675aa2019-08-16 22:28:39 -0500252 port_1 = self.ports_client.create_port(
253 network_id=network['id'],
254 name=data_utils.rand_name(self.__class__.__name__),
255 fixed_ips=fixed_ips)
Hemachandra Reddye866da92020-08-28 21:49:49 +0000256 self.addCleanup(self.ports_client.wait_for_resource_deletion,
257 port_1['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200258 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
259 self.ports_client.delete_port, port_1['port']['id'])
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000260 fixed_ips = [{'subnet_id': subnet['id'], 'ip_address': ip_address_2}]
Doug Schveninger24675aa2019-08-16 22:28:39 -0500261 port_2 = self.ports_client.create_port(
262 network_id=network['id'],
263 name=data_utils.rand_name(self.__class__.__name__),
264 fixed_ips=fixed_ips)
Hemachandra Reddye866da92020-08-28 21:49:49 +0000265 self.addCleanup(self.ports_client.wait_for_resource_deletion,
266 port_2['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200267 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
268 self.ports_client.delete_port, port_2['port']['id'])
Hongbin Lu0ac946c2017-12-04 20:50:33 +0000269
270 # Scenario 1: List port1 (port2 is filtered out)
271 if ip_address_1[:-1] != ip_address_2[:-1]:
272 ips_filter = 'ip_address_substr=' + ip_address_1[:-1]
273 else:
274 ips_filter = 'ip_address_substr=' + ip_address_1
275 ports = self.ports_client.list_ports(fixed_ips=ips_filter)['ports']
276 # Check that we got the desired port
277 port_ids = [port['id'] for port in ports]
278 fixed_ips = [port['fixed_ips'] for port in ports]
279 port_ips = []
280 for addr in fixed_ips:
281 port_ips.extend([a['ip_address'] for a in addr])
282
283 port_net_ids = [port['network_id'] for port in ports]
284 self.assertIn(network['id'], port_net_ids)
285 self.assertIn(port_1['port']['id'], port_ids)
286 self.assertIn(port_1['port']['fixed_ips'][0]['ip_address'], port_ips)
287 self.assertNotIn(port_2['port']['id'], port_ids)
288 self.assertNotIn(
289 port_2['port']['fixed_ips'][0]['ip_address'], port_ips)
290
291 # Scenario 2: List both port1 and port2
292 substr = ip_address_1
293 while substr not in ip_address_2:
294 substr = substr[:-1]
295 ips_filter = 'ip_address_substr=' + substr
296 ports = self.ports_client.list_ports(fixed_ips=ips_filter)['ports']
297 # Check that we got both port
298 port_ids = [port['id'] for port in ports]
299 fixed_ips = [port['fixed_ips'] for port in ports]
300 port_ips = []
301 for addr in fixed_ips:
302 port_ips.extend([a['ip_address'] for a in addr])
303
304 port_net_ids = [port['network_id'] for port in ports]
305 self.assertIn(network['id'], port_net_ids)
306 self.assertIn(port_1['port']['id'], port_ids)
307 self.assertIn(port_1['port']['fixed_ips'][0]['ip_address'], port_ips)
308 self.assertIn(port_2['port']['id'], port_ids)
309 self.assertIn(port_2['port']['fixed_ips'][0]['ip_address'], port_ips)
310
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800311 @decorators.idempotent_id('5ad01ed0-0e6e-4c5d-8194-232801b15c72')
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400312 def test_port_list_filter_by_router_id(self):
zhufl4810d882020-04-22 16:14:19 +0800313 """Test listing ports filtered by router id"""
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400314 # Create a router
deepak_mouryab4fb4382018-06-04 10:11:32 +0530315 network = self._create_network()
316 self._create_subnet(network)
zhufl39ac5682016-10-24 17:11:34 +0800317 router = self.create_router()
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200318 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
319 self.routers_client.delete_router, router['id'])
Doug Schveninger24675aa2019-08-16 22:28:39 -0500320 port = self.ports_client.create_port(
321 network_id=network['id'],
322 name=data_utils.rand_name(self.__class__.__name__))
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400323 # Add router interface to port created above
Ken'ichi Ohmichie35f4722015-12-22 04:57:11 +0000324 self.routers_client.add_router_interface(router['id'],
325 port_id=port['port']['id'])
Hemachandra Reddye866da92020-08-28 21:49:49 +0000326 self.addCleanup(self.ports_client.wait_for_resource_deletion,
327 port['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200328 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
329 self.routers_client.remove_router_interface,
Ken'ichi Ohmichie35f4722015-12-22 04:57:11 +0000330 router['id'], port_id=port['port']['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400331 # List ports filtered by router_id
John Warren49c0fe52015-10-22 12:35:54 -0400332 port_list = self.ports_client.list_ports(device_id=router['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400333 ports = port_list['ports']
334 self.assertEqual(len(ports), 1)
335 self.assertEqual(ports[0]['id'], port['port']['id'])
336 self.assertEqual(ports[0]['device_id'], router['id'])
337
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800338 @decorators.idempotent_id('ff7f117f-f034-4e0e-abff-ccef05c454b4')
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400339 def test_list_ports_fields(self):
zhufl4810d882020-04-22 16:14:19 +0800340 """Verify specific fields of ports"""
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500341 fields = ['id', 'mac_address']
John Warren49c0fe52015-10-22 12:35:54 -0400342 body = self.ports_client.list_ports(fields=fields)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400343 ports = body['ports']
344 self.assertNotEmpty(ports, "Port list returned is empty")
345 # Asserting the fields returned are correct
346 for port in ports:
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500347 self.assertEqual(sorted(fields), sorted(port.keys()))
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400348
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800349 @decorators.idempotent_id('63aeadd4-3b49-427f-a3b1-19ca81f06270')
Neeti Dahiyade291772014-09-22 10:43:12 +0530350 def test_create_update_port_with_second_ip(self):
zhufl4810d882020-04-22 16:14:19 +0800351 """Test updating port from 2 fixed ips to 1 fixed ip and vice versa"""
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400352 # Create a network with two subnets
deepak_mouryab4fb4382018-06-04 10:11:32 +0530353 network = self._create_network()
354 subnet_1 = self._create_subnet(network)
355 subnet_2 = self._create_subnet(network)
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400356 fixed_ip_1 = [{'subnet_id': subnet_1['id']}]
357 fixed_ip_2 = [{'subnet_id': subnet_2['id']}]
358
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400359 fixed_ips = fixed_ip_1 + fixed_ip_2
Neeti Dahiyade291772014-09-22 10:43:12 +0530360
361 # Create a port with multiple IP addresses
362 port = self.create_port(network,
363 fixed_ips=fixed_ips)
Hemachandra Reddye866da92020-08-28 21:49:49 +0000364 self.addCleanup(self.ports_client.wait_for_resource_deletion,
365 port['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200366 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
367 self.ports_client.delete_port, port['id'])
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400368 self.assertEqual(2, len(port['fixed_ips']))
Neeti Dahiyade291772014-09-22 10:43:12 +0530369 check_fixed_ips = [subnet_1['id'], subnet_2['id']]
370 for item in port['fixed_ips']:
371 self.assertIn(item['subnet_id'], check_fixed_ips)
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400372
373 # Update the port to return to a single IP address
374 port = self.update_port(port, fixed_ips=fixed_ip_1)
375 self.assertEqual(1, len(port['fixed_ips']))
376
Neeti Dahiyade291772014-09-22 10:43:12 +0530377 # Update the port with a second IP address from second subnet
378 port = self.update_port(port, fixed_ips=fixed_ips)
379 self.assertEqual(2, len(port['fixed_ips']))
380
Ashish Guptadba59f92014-07-16 02:24:45 -0700381 def _update_port_with_security_groups(self, security_groups_names):
deepak_mouryab4fb4382018-06-04 10:11:32 +0530382 subnet_1 = self._create_subnet(self.network)
Neeti Dahiyade291772014-09-22 10:43:12 +0530383 fixed_ip_1 = [{'subnet_id': subnet_1['id']}]
384
Ashish Guptadba59f92014-07-16 02:24:45 -0700385 security_groups_list = list()
John Warrenf9606e92015-12-10 12:12:42 -0500386 sec_grps_client = self.security_groups_client
Ashish Guptadba59f92014-07-16 02:24:45 -0700387 for name in security_groups_names:
John Warrenf9606e92015-12-10 12:12:42 -0500388 group_create_body = sec_grps_client.create_security_group(
Ashish Guptadba59f92014-07-16 02:24:45 -0700389 name=name)
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200390 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
391 self.security_groups_client.delete_security_group,
Ashish Guptadba59f92014-07-16 02:24:45 -0700392 group_create_body['security_group']['id'])
393 security_groups_list.append(group_create_body['security_group']
394 ['id'])
395 # Create a port
Neeti Dahiyade291772014-09-22 10:43:12 +0530396 sec_grp_name = data_utils.rand_name('secgroup')
John Warrenf9606e92015-12-10 12:12:42 -0500397 security_group = sec_grps_client.create_security_group(
398 name=sec_grp_name)
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200399 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
400 self.security_groups_client.delete_security_group,
Neeti Dahiyade291772014-09-22 10:43:12 +0530401 security_group['security_group']['id'])
402 post_body = {
Doug Schveninger24675aa2019-08-16 22:28:39 -0500403 "name": data_utils.rand_name(self.__class__.__name__),
Neeti Dahiyade291772014-09-22 10:43:12 +0530404 "security_groups": [security_group['security_group']['id']],
405 "network_id": self.network['id'],
406 "admin_state_up": True,
407 "fixed_ips": fixed_ip_1}
John Warren49c0fe52015-10-22 12:35:54 -0400408 body = self.ports_client.create_port(**post_body)
Hemachandra Reddye866da92020-08-28 21:49:49 +0000409 self.addCleanup(self.ports_client.wait_for_resource_deletion,
410 body['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200411 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
412 self.ports_client.delete_port, body['port']['id'])
Ashish Guptadba59f92014-07-16 02:24:45 -0700413 port = body['port']
Neeti Dahiyade291772014-09-22 10:43:12 +0530414
Ashish Guptadba59f92014-07-16 02:24:45 -0700415 # Update the port with security groups
Neeti Dahiyade291772014-09-22 10:43:12 +0530416 subnet_2 = self.create_subnet(self.network)
417 fixed_ip_2 = [{'subnet_id': subnet_2['id']}]
Doug Schveninger24675aa2019-08-16 22:28:39 -0500418 update_body = {
419 "name": data_utils.rand_name(self.__class__.__name__),
420 "admin_state_up": False,
421 "fixed_ips": fixed_ip_2,
422 "security_groups": security_groups_list}
John Warren49c0fe52015-10-22 12:35:54 -0400423 body = self.ports_client.update_port(port['id'], **update_body)
Ashish Guptadba59f92014-07-16 02:24:45 -0700424 port_show = body['port']
Neeti Dahiyade291772014-09-22 10:43:12 +0530425 # Verify the security groups and other attributes updated to port
426 exclude_keys = set(port_show).symmetric_difference(update_body)
427 exclude_keys.add('fixed_ips')
428 exclude_keys.add('security_groups')
429 self.assertThat(port_show, custom_matchers.MatchesDictExceptForKeys(
430 update_body, exclude_keys))
431 self.assertEqual(fixed_ip_2[0]['subnet_id'],
432 port_show['fixed_ips'][0]['subnet_id'])
433
Ashish Guptadba59f92014-07-16 02:24:45 -0700434 for security_group in security_groups_list:
435 self.assertIn(security_group, port_show['security_groups'])
436
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800437 @decorators.idempotent_id('58091b66-4ff4-4cc1-a549-05d60c7acd1a')
zhuflfffec232016-09-18 17:09:11 +0800438 @testtools.skipUnless(
Andrea Frittolicd368412017-08-14 21:37:56 +0100439 utils.is_extension_enabled('security-group', 'network'),
zhuflfffec232016-09-18 17:09:11 +0800440 'security-group extension not enabled.')
Neeti Dahiyade291772014-09-22 10:43:12 +0530441 def test_update_port_with_security_group_and_extra_attributes(self):
zhufl4810d882020-04-22 16:14:19 +0800442 """Test updating port's security_group along with extra attributes
443
444 First we create a port with one security group, and then we update the
445 port's security_group, in the same update request we also change
446 the port's fixed ips.
447 """
Ashish Guptadba59f92014-07-16 02:24:45 -0700448 self._update_port_with_security_groups(
449 [data_utils.rand_name('secgroup')])
450
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800451 @decorators.idempotent_id('edf6766d-3d40-4621-bc6e-2521a44c257d')
zhuflfffec232016-09-18 17:09:11 +0800452 @testtools.skipUnless(
Andrea Frittolicd368412017-08-14 21:37:56 +0100453 utils.is_extension_enabled('security-group', 'network'),
zhuflfffec232016-09-18 17:09:11 +0800454 'security-group extension not enabled.')
Neeti Dahiyade291772014-09-22 10:43:12 +0530455 def test_update_port_with_two_security_groups_and_extra_attributes(self):
zhufl4810d882020-04-22 16:14:19 +0800456 """Test updating port with two security_groups and extra attributes
457
458 First we create a port with one security group, and then we update the
459 port to two security_groups, in the same update request we also change
460 the port's fixed ips.
461 """
Ashish Guptadba59f92014-07-16 02:24:45 -0700462 self._update_port_with_security_groups(
463 [data_utils.rand_name('secgroup'),
464 data_utils.rand_name('secgroup')])
465
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800466 @decorators.idempotent_id('13e95171-6cbd-489c-9d7c-3f9c58215c18')
Ashish Guptad42b6e12014-11-20 02:06:03 -0800467 def test_create_show_delete_port_user_defined_mac(self):
zhufl4810d882020-04-22 16:14:19 +0800468 """Test creating port with user defined mac address"""
Ashish Guptad42b6e12014-11-20 02:06:03 -0800469 # Create a port for a legal mac
Doug Schveninger24675aa2019-08-16 22:28:39 -0500470 body = self.ports_client.create_port(
471 network_id=self.network['id'],
472 name=data_utils.rand_name(self.__class__.__name__))
Ashish Guptad42b6e12014-11-20 02:06:03 -0800473 old_port = body['port']
474 free_mac_address = old_port['mac_address']
John Warren49c0fe52015-10-22 12:35:54 -0400475 self.ports_client.delete_port(old_port['id'])
Ashish Guptad42b6e12014-11-20 02:06:03 -0800476 # Create a new port with user defined mac
Doug Schveninger24675aa2019-08-16 22:28:39 -0500477 body = self.ports_client.create_port(
478 network_id=self.network['id'],
479 mac_address=free_mac_address,
480 name=data_utils.rand_name(self.__class__.__name__))
Hemachandra Reddye866da92020-08-28 21:49:49 +0000481 self.addCleanup(self.ports_client.wait_for_resource_deletion,
482 body['port']['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200483 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
484 self.ports_client.delete_port, body['port']['id'])
Ashish Guptad42b6e12014-11-20 02:06:03 -0800485 port = body['port']
John Warren49c0fe52015-10-22 12:35:54 -0400486 body = self.ports_client.show_port(port['id'])
Ashish Guptad42b6e12014-11-20 02:06:03 -0800487 show_port = body['port']
488 self.assertEqual(free_mac_address,
489 show_port['mac_address'])
490
Jordan Pittier3b46d272017-04-12 16:17:28 +0200491 @decorators.attr(type='smoke')
Ken'ichi Ohmichi53b9a632017-01-27 18:04:39 -0800492 @decorators.idempotent_id('4179dcb9-1382-4ced-84fe-1b91c54f5735')
zhuflfffec232016-09-18 17:09:11 +0800493 @testtools.skipUnless(
Andrea Frittolicd368412017-08-14 21:37:56 +0100494 utils.is_extension_enabled('security-group', 'network'),
zhuflfffec232016-09-18 17:09:11 +0800495 'security-group extension not enabled.')
Rajkumar Thiyagarajan0f562a82014-08-21 01:59:19 -0700496 def test_create_port_with_no_securitygroups(self):
zhufl4810d882020-04-22 16:14:19 +0800497 """Test creating port without security groups"""
deepak_mouryab4fb4382018-06-04 10:11:32 +0530498 network = self._create_network()
499 self._create_subnet(network)
Salvatore18dd66e2014-12-31 00:13:57 +0100500 port = self.create_port(network, security_groups=[])
Hemachandra Reddye866da92020-08-28 21:49:49 +0000501 self.addCleanup(self.ports_client.wait_for_resource_deletion,
502 port['id'])
Slawek Kaplonski748dd8d2019-04-16 23:38:35 +0200503 self.addCleanup(test_utils.call_and_ignore_notfound_exc,
504 self.ports_client.delete_port, port['id'])
Rajkumar Thiyagarajan0f562a82014-08-21 01:59:19 -0700505 self.assertIsNotNone(port['security_groups'])
506 self.assertEmpty(port['security_groups'])
507
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400508
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400509class PortsIpV6TestJSON(PortsTestJSON):
510 _ip_version = 6