Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 1 | # 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 Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 16 | import ipaddress |
| 17 | |
Matthew Treinish | 01472ff | 2015-02-20 17:26:52 -0500 | [diff] [blame] | 18 | import netaddr |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 19 | import testtools |
Matthew Treinish | 01472ff | 2015-02-20 17:26:52 -0500 | [diff] [blame] | 20 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 21 | from tempest.api.network import base_security_groups as sec_base |
Santosh Kumar | f0cbf9a | 2014-08-25 07:31:15 -0700 | [diff] [blame] | 22 | from tempest.common import custom_matchers |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 23 | from tempest.common import utils |
Ken'ichi Ohmichi | f50e4df | 2017-03-10 10:52:53 -0800 | [diff] [blame] | 24 | from tempest.lib.common.utils import data_utils |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 25 | from tempest.lib.common.utils import test_utils |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 26 | from tempest.lib import decorators |
Matthew Treinish | 4217a70 | 2016-10-07 17:27:11 -0400 | [diff] [blame] | 27 | from tempest.lib import exceptions |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 28 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 29 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 30 | class PortsTestJSON(sec_base.BaseSecGroupTest): |
Ken'ichi Ohmichi | e03bea9 | 2015-11-19 07:45:58 +0000 | [diff] [blame] | 31 | """Test the following operations for ports: |
Elena Ezhova | 5c95715 | 2014-03-26 12:01:10 +0400 | [diff] [blame] | 32 | |
| 33 | port create |
| 34 | port delete |
| 35 | port list |
| 36 | port show |
| 37 | port update |
| 38 | """ |
| 39 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 40 | @classmethod |
Andrea Frittoli | da4a245 | 2014-09-15 13:12:08 +0100 | [diff] [blame] | 41 | def resource_setup(cls): |
| 42 | super(PortsTestJSON, cls).resource_setup() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 43 | cls.network = cls.create_network() |
| 44 | cls.port = cls.create_port(cls.network) |
| 45 | |
| 46 | def _delete_port(self, port_id): |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 47 | self.ports_client.delete_port(port_id) |
| 48 | body = self.ports_client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 49 | ports_list = body['ports'] |
| 50 | self.assertFalse(port_id in [n['id'] for n in ports_list]) |
| 51 | |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 52 | def _create_subnet(self, network, gateway='', |
| 53 | cidr=None, mask_bits=None, **kwargs): |
likangkang01 | b87ef29 | 2021-09-09 08:54:04 +0800 | [diff] [blame] | 54 | subnet = self.create_subnet( |
| 55 | network, gateway, cidr, mask_bits, **kwargs) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 56 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 57 | self.subnets_client.delete_subnet, subnet['id']) |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 58 | 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 Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 65 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 66 | self.networks_client.delete_network, |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 67 | network['id']) |
| 68 | return network |
| 69 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 70 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 71 | @decorators.idempotent_id('c72c1c0c-2193-4aca-aaa4-b1442640f51c') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 72 | def test_create_update_delete_port(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 73 | """Test creating, updating and deleting port""" |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 74 | # Verify port creation |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 75 | body = self.ports_client.create_port( |
| 76 | network_id=self.network['id'], |
| 77 | name=data_utils.rand_name(self.__class__.__name__)) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 78 | port = body['port'] |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 79 | # Schedule port deletion with verification upon test completion |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 80 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 81 | port['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 82 | self.addCleanup(self._delete_port, port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 83 | self.assertTrue(port['admin_state_up']) |
| 84 | # Verify port update |
| 85 | new_name = "New_Port" |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 86 | body = self.ports_client.update_port(port['id'], |
| 87 | name=new_name, |
| 88 | admin_state_up=False) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 89 | updated_port = body['port'] |
| 90 | self.assertEqual(updated_port['name'], new_name) |
| 91 | self.assertFalse(updated_port['admin_state_up']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 92 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 93 | @decorators.idempotent_id('67f1b811-f8db-43e2-86bd-72c074d4a42c') |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 94 | def test_create_bulk_port(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 95 | """Test creating multiple ports in a single request""" |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 96 | network1 = self.network |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 97 | network2 = self._create_network() |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 98 | network_list = [network1['id'], network2['id']] |
| 99 | port_list = [{'network_id': net_id} for net_id in network_list] |
Ken'ichi Ohmichi | 1f52fd9 | 2016-03-03 12:24:12 -0800 | [diff] [blame] | 100 | body = self.ports_client.create_bulk_ports(ports=port_list) |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 101 | created_ports = body['ports'] |
| 102 | port1 = created_ports[0] |
| 103 | port2 = created_ports[1] |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 104 | 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']) |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 108 | 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 Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 115 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 116 | @decorators.idempotent_id('0435f278-40ae-48cb-a404-b8a087bc09b1') |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 117 | def test_create_port_in_allowed_allocation_pools(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 118 | """Test creating port in allowed allocation pools""" |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 119 | network = self._create_network() |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 120 | net_id = network['id'] |
zhufl | ec61bac | 2017-09-01 15:59:50 +0800 | [diff] [blame] | 121 | address = self.cidr |
| 122 | address.prefixlen = self.mask_bits |
Guillaume Chenuet | bdf1d8d | 2015-11-09 16:10:48 +0100 | [diff] [blame] | 123 | if ((address.version == 4 and address.prefixlen >= 30) or |
afazekas | 40fcb9b | 2019-03-08 11:25:11 +0100 | [diff] [blame] | 124 | (address.version == 6 and address.prefixlen >= 126)): |
Guillaume Chenuet | bdf1d8d | 2015-11-09 16:10:48 +0100 | [diff] [blame] | 125 | msg = ("Subnet %s isn't large enough for the test" % address.cidr) |
zhufl | ff30ede | 2016-12-27 10:29:13 +0800 | [diff] [blame] | 126 | raise exceptions.InvalidConfiguration(msg) |
Guillaume Chenuet | bdf1d8d | 2015-11-09 16:10:48 +0100 | [diff] [blame] | 127 | allocation_pools = {'allocation_pools': [{'start': str(address[2]), |
| 128 | 'end': str(address[-2])}]} |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 129 | self._create_subnet(network, cidr=address, |
| 130 | mask_bits=address.prefixlen, |
| 131 | **allocation_pools) |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 132 | body = self.ports_client.create_port( |
| 133 | network_id=net_id, |
| 134 | name=data_utils.rand_name(self.__class__.__name__)) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 135 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 136 | body['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 137 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 138 | self.ports_client.delete_port, body['port']['id']) |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 139 | 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 Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 145 | self.ports_client.delete_port(port['id']) |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 146 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 147 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 148 | @decorators.idempotent_id('c9a685bd-e83f-499c-939f-9f7863ca259f') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 149 | def test_show_port(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 150 | """Verify the details of port""" |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 151 | body = self.ports_client.show_port(self.port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 152 | port = body['port'] |
| 153 | self.assertIn('id', port) |
Rafael Folco | 7278802 | 2016-03-24 13:02:09 +0000 | [diff] [blame] | 154 | # 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 Kumar | f0cbf9a | 2014-08-25 07:31:15 -0700 | [diff] [blame] | 158 | self.assertThat(self.port, |
| 159 | custom_matchers.MatchesDictExceptForKeys |
Rafael Folco | 7278802 | 2016-03-24 13:02:09 +0000 | [diff] [blame] | 160 | (port, excluded_keys=['extra_dhcp_opts', |
| 161 | 'created_at', |
| 162 | 'updated_at'])) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 163 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 164 | @decorators.idempotent_id('45fcdaf2-dab0-4c13-ac6c-fcddfb579dbd') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 165 | def test_show_port_fields(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 166 | """Verify specific fields of a port""" |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 167 | fields = ['id', 'mac_address'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 168 | body = self.ports_client.show_port(self.port['id'], |
| 169 | fields=fields) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 170 | port = body['port'] |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 171 | self.assertEqual(sorted(port.keys()), sorted(fields)) |
| 172 | for field_name in fields: |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 173 | self.assertEqual(port[field_name], self.port[field_name]) |
| 174 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 175 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 176 | @decorators.idempotent_id('cf95b358-3e92-4a29-a148-52445e1ac50e') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 177 | def test_list_ports(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 178 | """Verify the port exists in the list of all ports""" |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 179 | body = self.ports_client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 180 | 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 Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 184 | @decorators.idempotent_id('e7fe260b-1e79-4dd3-86d9-bec6a7959fc5') |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 185 | def test_port_list_filter_by_ip(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 186 | """Test listing ports filtered by ip""" |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 187 | # Create network and subnet |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 188 | network = self._create_network() |
| 189 | self._create_subnet(network) |
Yaroslav Lobankov | 5d71ac8 | 2015-06-16 16:43:43 +0300 | [diff] [blame] | 190 | # Create two ports |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 191 | port_1 = self.ports_client.create_port( |
| 192 | network_id=network['id'], |
| 193 | name=data_utils.rand_name(self.__class__.__name__)) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 194 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 195 | port_1['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 196 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 197 | self.ports_client.delete_port, port_1['port']['id']) |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 198 | port_2 = self.ports_client.create_port( |
| 199 | network_id=network['id'], |
| 200 | name=data_utils.rand_name(self.__class__.__name__)) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 201 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 202 | port_2['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 203 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 204 | self.ports_client.delete_port, port_2['port']['id']) |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 205 | # List ports filtered by fixed_ips |
Yaroslav Lobankov | 5d71ac8 | 2015-06-16 16:43:43 +0300 | [diff] [blame] | 206 | port_1_fixed_ip = port_1['port']['fixed_ips'][0]['ip_address'] |
| 207 | fixed_ips = 'ip_address=' + port_1_fixed_ip |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 208 | port_list = self.ports_client.list_ports(fixed_ips=fixed_ips) |
Yaroslav Lobankov | 5d71ac8 | 2015-06-16 16:43:43 +0300 | [diff] [blame] | 209 | # Check that we got the desired port |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 210 | ports = port_list['ports'] |
Rodolfo Alonso Hernandez | c1449d4 | 2020-02-15 13:24:28 +0000 | [diff] [blame] | 211 | 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 Treinish | 1d94254 | 2015-08-25 18:16:14 -0400 | [diff] [blame] | 214 | port_ids = [port['id'] for port in ports] |
| 215 | fixed_ips = [port['fixed_ips'] for port in ports] |
Matthew Treinish | 1d94254 | 2015-08-25 18:16:14 -0400 | [diff] [blame] | 216 | port_net_ids = [port['network_id'] for port in ports] |
| 217 | self.assertIn(port_1['port']['id'], port_ids) |
Matthew Treinish | 1d94254 | 2015-08-25 18:16:14 -0400 | [diff] [blame] | 218 | self.assertIn(network['id'], port_net_ids) |
Sphicas, Phil (ps3910) | 0ff7e3d | 2019-08-15 20:34:02 -0700 | [diff] [blame] | 219 | # 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 Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 224 | |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 225 | @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): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 230 | """Test listing ports filtered by part of ip address string""" |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 231 | # Create network and subnet |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 232 | network = self._create_network() |
| 233 | subnet = self._create_subnet(network) |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 234 | # Get two IP addresses |
| 235 | ip_address_1 = None |
| 236 | ip_address_2 = None |
likui | 19b70a3 | 2020-12-02 13:25:18 +0800 | [diff] [blame] | 237 | ip_network = ipaddress.ip_network(str(subnet['cidr'])) |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 238 | for ip in ip_network: |
| 239 | if ip == ip_network.network_address: |
| 240 | continue |
| 241 | if ip_address_1 is None: |
likui | 19b70a3 | 2020-12-02 13:25:18 +0800 | [diff] [blame] | 242 | ip_address_1 = str(ip) |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 243 | else: |
| 244 | ip_address_2 = ip_address_1 |
likui | 19b70a3 | 2020-12-02 13:25:18 +0800 | [diff] [blame] | 245 | ip_address_1 = str(ip) |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 246 | # 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 Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 252 | 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 Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 256 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 257 | port_1['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 258 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 259 | self.ports_client.delete_port, port_1['port']['id']) |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 260 | fixed_ips = [{'subnet_id': subnet['id'], 'ip_address': ip_address_2}] |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 261 | 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 Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 265 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 266 | port_2['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 267 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 268 | self.ports_client.delete_port, port_2['port']['id']) |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 269 | |
| 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 Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 311 | @decorators.idempotent_id('5ad01ed0-0e6e-4c5d-8194-232801b15c72') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 312 | def test_port_list_filter_by_router_id(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 313 | """Test listing ports filtered by router id""" |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 314 | # Create a router |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 315 | network = self._create_network() |
| 316 | self._create_subnet(network) |
zhufl | 39ac568 | 2016-10-24 17:11:34 +0800 | [diff] [blame] | 317 | router = self.create_router() |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 318 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 319 | self.routers_client.delete_router, router['id']) |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 320 | port = self.ports_client.create_port( |
| 321 | network_id=network['id'], |
| 322 | name=data_utils.rand_name(self.__class__.__name__)) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 323 | # Add router interface to port created above |
Ken'ichi Ohmichi | e35f472 | 2015-12-22 04:57:11 +0000 | [diff] [blame] | 324 | self.routers_client.add_router_interface(router['id'], |
| 325 | port_id=port['port']['id']) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 326 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 327 | port['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 328 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 329 | self.routers_client.remove_router_interface, |
Ken'ichi Ohmichi | e35f472 | 2015-12-22 04:57:11 +0000 | [diff] [blame] | 330 | router['id'], port_id=port['port']['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 331 | # List ports filtered by router_id |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 332 | port_list = self.ports_client.list_ports(device_id=router['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 333 | 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 Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 338 | @decorators.idempotent_id('ff7f117f-f034-4e0e-abff-ccef05c454b4') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 339 | def test_list_ports_fields(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 340 | """Verify specific fields of ports""" |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 341 | fields = ['id', 'mac_address'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 342 | body = self.ports_client.list_ports(fields=fields) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 343 | 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 Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 347 | self.assertEqual(sorted(fields), sorted(port.keys())) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 348 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 349 | @decorators.idempotent_id('63aeadd4-3b49-427f-a3b1-19ca81f06270') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 350 | def test_create_update_port_with_second_ip(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 351 | """Test updating port from 2 fixed ips to 1 fixed ip and vice versa""" |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 352 | # Create a network with two subnets |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 353 | network = self._create_network() |
| 354 | subnet_1 = self._create_subnet(network) |
| 355 | subnet_2 = self._create_subnet(network) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 356 | fixed_ip_1 = [{'subnet_id': subnet_1['id']}] |
| 357 | fixed_ip_2 = [{'subnet_id': subnet_2['id']}] |
| 358 | |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 359 | fixed_ips = fixed_ip_1 + fixed_ip_2 |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 360 | |
| 361 | # Create a port with multiple IP addresses |
| 362 | port = self.create_port(network, |
| 363 | fixed_ips=fixed_ips) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 364 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 365 | port['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 366 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 367 | self.ports_client.delete_port, port['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 368 | self.assertEqual(2, len(port['fixed_ips'])) |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 369 | 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 LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 372 | |
| 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 Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 377 | # 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 Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 381 | def _update_port_with_security_groups(self, security_groups_names): |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 382 | subnet_1 = self._create_subnet(self.network) |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 383 | fixed_ip_1 = [{'subnet_id': subnet_1['id']}] |
| 384 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 385 | security_groups_list = list() |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 386 | sec_grps_client = self.security_groups_client |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 387 | for name in security_groups_names: |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 388 | group_create_body = sec_grps_client.create_security_group( |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 389 | name=name) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 390 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 391 | self.security_groups_client.delete_security_group, |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 392 | group_create_body['security_group']['id']) |
| 393 | security_groups_list.append(group_create_body['security_group'] |
| 394 | ['id']) |
| 395 | # Create a port |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 396 | sec_grp_name = data_utils.rand_name('secgroup') |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 397 | security_group = sec_grps_client.create_security_group( |
| 398 | name=sec_grp_name) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 399 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 400 | self.security_groups_client.delete_security_group, |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 401 | security_group['security_group']['id']) |
| 402 | post_body = { |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 403 | "name": data_utils.rand_name(self.__class__.__name__), |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 404 | "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 Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 408 | body = self.ports_client.create_port(**post_body) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 409 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 410 | body['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 411 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 412 | self.ports_client.delete_port, body['port']['id']) |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 413 | port = body['port'] |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 414 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 415 | # Update the port with security groups |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 416 | subnet_2 = self.create_subnet(self.network) |
| 417 | fixed_ip_2 = [{'subnet_id': subnet_2['id']}] |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 418 | 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 Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 423 | body = self.ports_client.update_port(port['id'], **update_body) |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 424 | port_show = body['port'] |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 425 | # 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 Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 434 | for security_group in security_groups_list: |
| 435 | self.assertIn(security_group, port_show['security_groups']) |
| 436 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 437 | @decorators.idempotent_id('58091b66-4ff4-4cc1-a549-05d60c7acd1a') |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 438 | @testtools.skipUnless( |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 439 | utils.is_extension_enabled('security-group', 'network'), |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 440 | 'security-group extension not enabled.') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 441 | def test_update_port_with_security_group_and_extra_attributes(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 442 | """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 Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 448 | self._update_port_with_security_groups( |
| 449 | [data_utils.rand_name('secgroup')]) |
| 450 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 451 | @decorators.idempotent_id('edf6766d-3d40-4621-bc6e-2521a44c257d') |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 452 | @testtools.skipUnless( |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 453 | utils.is_extension_enabled('security-group', 'network'), |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 454 | 'security-group extension not enabled.') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 455 | def test_update_port_with_two_security_groups_and_extra_attributes(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 456 | """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 Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 462 | self._update_port_with_security_groups( |
| 463 | [data_utils.rand_name('secgroup'), |
| 464 | data_utils.rand_name('secgroup')]) |
| 465 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 466 | @decorators.idempotent_id('13e95171-6cbd-489c-9d7c-3f9c58215c18') |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 467 | def test_create_show_delete_port_user_defined_mac(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 468 | """Test creating port with user defined mac address""" |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 469 | # Create a port for a legal mac |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 470 | body = self.ports_client.create_port( |
| 471 | network_id=self.network['id'], |
| 472 | name=data_utils.rand_name(self.__class__.__name__)) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 473 | old_port = body['port'] |
| 474 | free_mac_address = old_port['mac_address'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 475 | self.ports_client.delete_port(old_port['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 476 | # Create a new port with user defined mac |
Doug Schveninger | 24675aa | 2019-08-16 22:28:39 -0500 | [diff] [blame] | 477 | 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 Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 481 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 482 | body['port']['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 483 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 484 | self.ports_client.delete_port, body['port']['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 485 | port = body['port'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 486 | body = self.ports_client.show_port(port['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 487 | show_port = body['port'] |
| 488 | self.assertEqual(free_mac_address, |
| 489 | show_port['mac_address']) |
| 490 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 491 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 492 | @decorators.idempotent_id('4179dcb9-1382-4ced-84fe-1b91c54f5735') |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 493 | @testtools.skipUnless( |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 494 | utils.is_extension_enabled('security-group', 'network'), |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 495 | 'security-group extension not enabled.') |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 496 | def test_create_port_with_no_securitygroups(self): |
zhufl | 4810d88 | 2020-04-22 16:14:19 +0800 | [diff] [blame] | 497 | """Test creating port without security groups""" |
deepak_mourya | b4fb438 | 2018-06-04 10:11:32 +0530 | [diff] [blame] | 498 | network = self._create_network() |
| 499 | self._create_subnet(network) |
Salvatore | 18dd66e | 2014-12-31 00:13:57 +0100 | [diff] [blame] | 500 | port = self.create_port(network, security_groups=[]) |
Hemachandra Reddy | e866da9 | 2020-08-28 21:49:49 +0000 | [diff] [blame] | 501 | self.addCleanup(self.ports_client.wait_for_resource_deletion, |
| 502 | port['id']) |
Slawek Kaplonski | 748dd8d | 2019-04-16 23:38:35 +0200 | [diff] [blame] | 503 | self.addCleanup(test_utils.call_and_ignore_notfound_exc, |
| 504 | self.ports_client.delete_port, port['id']) |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 505 | self.assertIsNotNone(port['security_groups']) |
| 506 | self.assertEmpty(port['security_groups']) |
| 507 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 508 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 509 | class PortsIpV6TestJSON(PortsTestJSON): |
| 510 | _ip_version = 6 |