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 |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 19 | import six |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 20 | import testtools |
Matthew Treinish | 01472ff | 2015-02-20 17:26:52 -0500 | [diff] [blame] | 21 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 22 | from tempest.api.network import base_security_groups as sec_base |
Santosh Kumar | f0cbf9a | 2014-08-25 07:31:15 -0700 | [diff] [blame] | 23 | from tempest.common import custom_matchers |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 24 | from tempest.common import utils |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 25 | from tempest import config |
Ken'ichi Ohmichi | f50e4df | 2017-03-10 10:52:53 -0800 | [diff] [blame] | 26 | from tempest.lib.common.utils import data_utils |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 27 | from tempest.lib import decorators |
Matthew Treinish | 4217a70 | 2016-10-07 17:27:11 -0400 | [diff] [blame] | 28 | from tempest.lib import exceptions |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 29 | |
| 30 | CONF = config.CONF |
| 31 | |
| 32 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 33 | class PortsTestJSON(sec_base.BaseSecGroupTest): |
Ken'ichi Ohmichi | e03bea9 | 2015-11-19 07:45:58 +0000 | [diff] [blame] | 34 | """Test the following operations for ports: |
Elena Ezhova | 5c95715 | 2014-03-26 12:01:10 +0400 | [diff] [blame] | 35 | |
| 36 | port create |
| 37 | port delete |
| 38 | port list |
| 39 | port show |
| 40 | port update |
| 41 | """ |
| 42 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 43 | @classmethod |
Andrea Frittoli | da4a245 | 2014-09-15 13:12:08 +0100 | [diff] [blame] | 44 | def resource_setup(cls): |
| 45 | super(PortsTestJSON, cls).resource_setup() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 46 | cls.network = cls.create_network() |
| 47 | cls.port = cls.create_port(cls.network) |
| 48 | |
| 49 | def _delete_port(self, port_id): |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 50 | self.ports_client.delete_port(port_id) |
| 51 | body = self.ports_client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 52 | ports_list = body['ports'] |
| 53 | self.assertFalse(port_id in [n['id'] for n in ports_list]) |
| 54 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 55 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 56 | @decorators.idempotent_id('c72c1c0c-2193-4aca-aaa4-b1442640f51c') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 57 | def test_create_update_delete_port(self): |
| 58 | # Verify port creation |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 59 | body = self.ports_client.create_port(network_id=self.network['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 60 | port = body['port'] |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 61 | # Schedule port deletion with verification upon test completion |
| 62 | self.addCleanup(self._delete_port, port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 63 | self.assertTrue(port['admin_state_up']) |
| 64 | # Verify port update |
| 65 | new_name = "New_Port" |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 66 | body = self.ports_client.update_port(port['id'], |
| 67 | name=new_name, |
| 68 | admin_state_up=False) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 69 | updated_port = body['port'] |
| 70 | self.assertEqual(updated_port['name'], new_name) |
| 71 | self.assertFalse(updated_port['admin_state_up']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 72 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 73 | @decorators.idempotent_id('67f1b811-f8db-43e2-86bd-72c074d4a42c') |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 74 | def test_create_bulk_port(self): |
| 75 | network1 = self.network |
zhufl | d2c40ca | 2016-10-18 17:03:07 +0800 | [diff] [blame] | 76 | network2 = self.create_network() |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 77 | network_list = [network1['id'], network2['id']] |
| 78 | 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] | 79 | body = self.ports_client.create_bulk_ports(ports=port_list) |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 80 | created_ports = body['ports'] |
| 81 | port1 = created_ports[0] |
| 82 | port2 = created_ports[1] |
| 83 | self.addCleanup(self._delete_port, port1['id']) |
| 84 | self.addCleanup(self._delete_port, port2['id']) |
| 85 | self.assertEqual(port1['network_id'], network1['id']) |
| 86 | self.assertEqual(port2['network_id'], network2['id']) |
| 87 | self.assertTrue(port1['admin_state_up']) |
| 88 | self.assertTrue(port2['admin_state_up']) |
| 89 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 90 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 91 | @decorators.idempotent_id('0435f278-40ae-48cb-a404-b8a087bc09b1') |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 92 | def test_create_port_in_allowed_allocation_pools(self): |
| 93 | network = self.create_network() |
| 94 | net_id = network['id'] |
zhufl | ec61bac | 2017-09-01 15:59:50 +0800 | [diff] [blame] | 95 | address = self.cidr |
| 96 | address.prefixlen = self.mask_bits |
Guillaume Chenuet | bdf1d8d | 2015-11-09 16:10:48 +0100 | [diff] [blame] | 97 | if ((address.version == 4 and address.prefixlen >= 30) or |
| 98 | (address.version == 6 and address.prefixlen >= 126)): |
| 99 | msg = ("Subnet %s isn't large enough for the test" % address.cidr) |
zhufl | ff30ede | 2016-12-27 10:29:13 +0800 | [diff] [blame] | 100 | raise exceptions.InvalidConfiguration(msg) |
Guillaume Chenuet | bdf1d8d | 2015-11-09 16:10:48 +0100 | [diff] [blame] | 101 | allocation_pools = {'allocation_pools': [{'start': str(address[2]), |
| 102 | 'end': str(address[-2])}]} |
| 103 | subnet = self.create_subnet(network, cidr=address, |
| 104 | mask_bits=address.prefixlen, |
| 105 | **allocation_pools) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 106 | self.addCleanup(self.subnets_client.delete_subnet, subnet['id']) |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 107 | body = self.ports_client.create_port(network_id=net_id) |
| 108 | self.addCleanup(self.ports_client.delete_port, body['port']['id']) |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 109 | port = body['port'] |
| 110 | ip_address = port['fixed_ips'][0]['ip_address'] |
| 111 | start_ip_address = allocation_pools['allocation_pools'][0]['start'] |
| 112 | end_ip_address = allocation_pools['allocation_pools'][0]['end'] |
| 113 | ip_range = netaddr.IPRange(start_ip_address, end_ip_address) |
| 114 | self.assertIn(ip_address, ip_range) |
| 115 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 116 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 117 | @decorators.idempotent_id('c9a685bd-e83f-499c-939f-9f7863ca259f') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 118 | def test_show_port(self): |
| 119 | # Verify the details of port |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 120 | body = self.ports_client.show_port(self.port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 121 | port = body['port'] |
| 122 | self.assertIn('id', port) |
Rafael Folco | 7278802 | 2016-03-24 13:02:09 +0000 | [diff] [blame] | 123 | # NOTE(rfolco): created_at and updated_at may get inconsistent values |
| 124 | # due to possible delay between POST request and resource creation. |
| 125 | # TODO(rfolco): Neutron Bug #1365341 is fixed, can remove the key |
| 126 | # 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] | 127 | self.assertThat(self.port, |
| 128 | custom_matchers.MatchesDictExceptForKeys |
Rafael Folco | 7278802 | 2016-03-24 13:02:09 +0000 | [diff] [blame] | 129 | (port, excluded_keys=['extra_dhcp_opts', |
| 130 | 'created_at', |
| 131 | 'updated_at'])) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 132 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 133 | @decorators.idempotent_id('45fcdaf2-dab0-4c13-ac6c-fcddfb579dbd') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 134 | def test_show_port_fields(self): |
| 135 | # Verify specific fields of a port |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 136 | fields = ['id', 'mac_address'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 137 | body = self.ports_client.show_port(self.port['id'], |
| 138 | fields=fields) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 139 | port = body['port'] |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 140 | self.assertEqual(sorted(port.keys()), sorted(fields)) |
| 141 | for field_name in fields: |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 142 | self.assertEqual(port[field_name], self.port[field_name]) |
| 143 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 144 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 145 | @decorators.idempotent_id('cf95b358-3e92-4a29-a148-52445e1ac50e') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 146 | def test_list_ports(self): |
| 147 | # Verify the port exists in the list of all ports |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 148 | body = self.ports_client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 149 | ports = [port['id'] for port in body['ports'] |
| 150 | if port['id'] == self.port['id']] |
| 151 | self.assertNotEmpty(ports, "Created port not found in the list") |
| 152 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 153 | @decorators.idempotent_id('e7fe260b-1e79-4dd3-86d9-bec6a7959fc5') |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 154 | def test_port_list_filter_by_ip(self): |
| 155 | # Create network and subnet |
| 156 | network = self.create_network() |
| 157 | subnet = self.create_subnet(network) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 158 | self.addCleanup(self.subnets_client.delete_subnet, subnet['id']) |
Yaroslav Lobankov | 5d71ac8 | 2015-06-16 16:43:43 +0300 | [diff] [blame] | 159 | # Create two ports |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 160 | port_1 = self.ports_client.create_port(network_id=network['id']) |
| 161 | self.addCleanup(self.ports_client.delete_port, port_1['port']['id']) |
| 162 | port_2 = self.ports_client.create_port(network_id=network['id']) |
| 163 | self.addCleanup(self.ports_client.delete_port, port_2['port']['id']) |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 164 | # List ports filtered by fixed_ips |
Yaroslav Lobankov | 5d71ac8 | 2015-06-16 16:43:43 +0300 | [diff] [blame] | 165 | port_1_fixed_ip = port_1['port']['fixed_ips'][0]['ip_address'] |
| 166 | fixed_ips = 'ip_address=' + port_1_fixed_ip |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 167 | port_list = self.ports_client.list_ports(fixed_ips=fixed_ips) |
Yaroslav Lobankov | 5d71ac8 | 2015-06-16 16:43:43 +0300 | [diff] [blame] | 168 | # Check that we got the desired port |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 169 | ports = port_list['ports'] |
Matthew Treinish | 1d94254 | 2015-08-25 18:16:14 -0400 | [diff] [blame] | 170 | tenant_ids = set([port['tenant_id'] for port in ports]) |
| 171 | self.assertEqual(len(tenant_ids), 1, |
| 172 | 'Ports from multiple tenants are in the list resp') |
| 173 | port_ids = [port['id'] for port in ports] |
| 174 | fixed_ips = [port['fixed_ips'] for port in ports] |
| 175 | port_ips = [] |
| 176 | for addr in fixed_ips: |
| 177 | port_ips.extend([port['ip_address'] for port in addr]) |
| 178 | |
| 179 | port_net_ids = [port['network_id'] for port in ports] |
| 180 | self.assertIn(port_1['port']['id'], port_ids) |
| 181 | self.assertIn(port_1_fixed_ip, port_ips) |
| 182 | self.assertIn(network['id'], port_net_ids) |
Arx Cruz | e8dfad9 | 2015-05-29 09:57:14 +0200 | [diff] [blame] | 183 | |
Hongbin Lu | 0ac946c | 2017-12-04 20:50:33 +0000 | [diff] [blame] | 184 | @decorators.idempotent_id('79895408-85d5-460d-94e7-9531c5fd9123') |
| 185 | @testtools.skipUnless( |
| 186 | utils.is_extension_enabled('ip-substring-filtering', 'network'), |
| 187 | 'ip-substring-filtering extension not enabled.') |
| 188 | def test_port_list_filter_by_ip_substr(self): |
| 189 | # Create network and subnet |
| 190 | network = self.create_network() |
| 191 | subnet = self.create_subnet(network) |
| 192 | self.addCleanup(self.subnets_client.delete_subnet, subnet['id']) |
| 193 | |
| 194 | # Get two IP addresses |
| 195 | ip_address_1 = None |
| 196 | ip_address_2 = None |
| 197 | ip_network = ipaddress.ip_network(six.text_type(subnet['cidr'])) |
| 198 | for ip in ip_network: |
| 199 | if ip == ip_network.network_address: |
| 200 | continue |
| 201 | if ip_address_1 is None: |
| 202 | ip_address_1 = six.text_type(ip) |
| 203 | else: |
| 204 | ip_address_2 = ip_address_1 |
| 205 | ip_address_1 = six.text_type(ip) |
| 206 | # Make sure these two IP addresses have different substring |
| 207 | if ip_address_1[:-1] != ip_address_2[:-1]: |
| 208 | break |
| 209 | |
| 210 | # Create two ports |
| 211 | fixed_ips = [{'subnet_id': subnet['id'], 'ip_address': ip_address_1}] |
| 212 | port_1 = self.ports_client.create_port(network_id=network['id'], |
| 213 | fixed_ips=fixed_ips) |
| 214 | self.addCleanup(self.ports_client.delete_port, port_1['port']['id']) |
| 215 | fixed_ips = [{'subnet_id': subnet['id'], 'ip_address': ip_address_2}] |
| 216 | port_2 = self.ports_client.create_port(network_id=network['id'], |
| 217 | fixed_ips=fixed_ips) |
| 218 | self.addCleanup(self.ports_client.delete_port, port_2['port']['id']) |
| 219 | |
| 220 | # Scenario 1: List port1 (port2 is filtered out) |
| 221 | if ip_address_1[:-1] != ip_address_2[:-1]: |
| 222 | ips_filter = 'ip_address_substr=' + ip_address_1[:-1] |
| 223 | else: |
| 224 | ips_filter = 'ip_address_substr=' + ip_address_1 |
| 225 | ports = self.ports_client.list_ports(fixed_ips=ips_filter)['ports'] |
| 226 | # Check that we got the desired port |
| 227 | port_ids = [port['id'] for port in ports] |
| 228 | fixed_ips = [port['fixed_ips'] for port in ports] |
| 229 | port_ips = [] |
| 230 | for addr in fixed_ips: |
| 231 | port_ips.extend([a['ip_address'] for a in addr]) |
| 232 | |
| 233 | port_net_ids = [port['network_id'] for port in ports] |
| 234 | self.assertIn(network['id'], port_net_ids) |
| 235 | self.assertIn(port_1['port']['id'], port_ids) |
| 236 | self.assertIn(port_1['port']['fixed_ips'][0]['ip_address'], port_ips) |
| 237 | self.assertNotIn(port_2['port']['id'], port_ids) |
| 238 | self.assertNotIn( |
| 239 | port_2['port']['fixed_ips'][0]['ip_address'], port_ips) |
| 240 | |
| 241 | # Scenario 2: List both port1 and port2 |
| 242 | substr = ip_address_1 |
| 243 | while substr not in ip_address_2: |
| 244 | substr = substr[:-1] |
| 245 | ips_filter = 'ip_address_substr=' + substr |
| 246 | ports = self.ports_client.list_ports(fixed_ips=ips_filter)['ports'] |
| 247 | # Check that we got both port |
| 248 | port_ids = [port['id'] for port in ports] |
| 249 | fixed_ips = [port['fixed_ips'] for port in ports] |
| 250 | port_ips = [] |
| 251 | for addr in fixed_ips: |
| 252 | port_ips.extend([a['ip_address'] for a in addr]) |
| 253 | |
| 254 | port_net_ids = [port['network_id'] for port in ports] |
| 255 | self.assertIn(network['id'], port_net_ids) |
| 256 | self.assertIn(port_1['port']['id'], port_ids) |
| 257 | self.assertIn(port_1['port']['fixed_ips'][0]['ip_address'], port_ips) |
| 258 | self.assertIn(port_2['port']['id'], port_ids) |
| 259 | self.assertIn(port_2['port']['fixed_ips'][0]['ip_address'], port_ips) |
| 260 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 261 | @decorators.idempotent_id('5ad01ed0-0e6e-4c5d-8194-232801b15c72') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 262 | def test_port_list_filter_by_router_id(self): |
| 263 | # Create a router |
| 264 | network = self.create_network() |
John Warren | 94d8faf | 2015-09-15 12:22:24 -0400 | [diff] [blame] | 265 | self.addCleanup(self.networks_client.delete_network, network['id']) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 266 | subnet = self.create_subnet(network) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 267 | self.addCleanup(self.subnets_client.delete_subnet, subnet['id']) |
zhufl | 39ac568 | 2016-10-24 17:11:34 +0800 | [diff] [blame] | 268 | router = self.create_router() |
Ken'ichi Ohmichi | e35f472 | 2015-12-22 04:57:11 +0000 | [diff] [blame] | 269 | self.addCleanup(self.routers_client.delete_router, router['id']) |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 270 | port = self.ports_client.create_port(network_id=network['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 271 | # Add router interface to port created above |
Ken'ichi Ohmichi | e35f472 | 2015-12-22 04:57:11 +0000 | [diff] [blame] | 272 | self.routers_client.add_router_interface(router['id'], |
| 273 | port_id=port['port']['id']) |
| 274 | self.addCleanup(self.routers_client.remove_router_interface, |
| 275 | router['id'], port_id=port['port']['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 276 | # List ports filtered by router_id |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 277 | port_list = self.ports_client.list_ports(device_id=router['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 278 | ports = port_list['ports'] |
| 279 | self.assertEqual(len(ports), 1) |
| 280 | self.assertEqual(ports[0]['id'], port['port']['id']) |
| 281 | self.assertEqual(ports[0]['device_id'], router['id']) |
| 282 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 283 | @decorators.idempotent_id('ff7f117f-f034-4e0e-abff-ccef05c454b4') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 284 | def test_list_ports_fields(self): |
| 285 | # Verify specific fields of ports |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 286 | fields = ['id', 'mac_address'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 287 | body = self.ports_client.list_ports(fields=fields) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 288 | ports = body['ports'] |
| 289 | self.assertNotEmpty(ports, "Port list returned is empty") |
| 290 | # Asserting the fields returned are correct |
| 291 | for port in ports: |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 292 | self.assertEqual(sorted(fields), sorted(port.keys())) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 293 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 294 | @decorators.idempotent_id('63aeadd4-3b49-427f-a3b1-19ca81f06270') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 295 | def test_create_update_port_with_second_ip(self): |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 296 | # Create a network with two subnets |
| 297 | network = self.create_network() |
John Warren | 94d8faf | 2015-09-15 12:22:24 -0400 | [diff] [blame] | 298 | self.addCleanup(self.networks_client.delete_network, network['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 299 | subnet_1 = self.create_subnet(network) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 300 | self.addCleanup(self.subnets_client.delete_subnet, subnet_1['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 301 | subnet_2 = self.create_subnet(network) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 302 | self.addCleanup(self.subnets_client.delete_subnet, subnet_2['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 303 | fixed_ip_1 = [{'subnet_id': subnet_1['id']}] |
| 304 | fixed_ip_2 = [{'subnet_id': subnet_2['id']}] |
| 305 | |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 306 | fixed_ips = fixed_ip_1 + fixed_ip_2 |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 307 | |
| 308 | # Create a port with multiple IP addresses |
| 309 | port = self.create_port(network, |
| 310 | fixed_ips=fixed_ips) |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 311 | self.addCleanup(self.ports_client.delete_port, port['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 312 | self.assertEqual(2, len(port['fixed_ips'])) |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 313 | check_fixed_ips = [subnet_1['id'], subnet_2['id']] |
| 314 | for item in port['fixed_ips']: |
| 315 | self.assertIn(item['subnet_id'], check_fixed_ips) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 316 | |
| 317 | # Update the port to return to a single IP address |
| 318 | port = self.update_port(port, fixed_ips=fixed_ip_1) |
| 319 | self.assertEqual(1, len(port['fixed_ips'])) |
| 320 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 321 | # Update the port with a second IP address from second subnet |
| 322 | port = self.update_port(port, fixed_ips=fixed_ips) |
| 323 | self.assertEqual(2, len(port['fixed_ips'])) |
| 324 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 325 | def _update_port_with_security_groups(self, security_groups_names): |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 326 | subnet_1 = self.create_subnet(self.network) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 327 | self.addCleanup(self.subnets_client.delete_subnet, subnet_1['id']) |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 328 | fixed_ip_1 = [{'subnet_id': subnet_1['id']}] |
| 329 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 330 | security_groups_list = list() |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 331 | sec_grps_client = self.security_groups_client |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 332 | for name in security_groups_names: |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 333 | group_create_body = sec_grps_client.create_security_group( |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 334 | name=name) |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 335 | self.addCleanup(self.security_groups_client.delete_security_group, |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 336 | group_create_body['security_group']['id']) |
| 337 | security_groups_list.append(group_create_body['security_group'] |
| 338 | ['id']) |
| 339 | # Create a port |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 340 | sec_grp_name = data_utils.rand_name('secgroup') |
John Warren | f9606e9 | 2015-12-10 12:12:42 -0500 | [diff] [blame] | 341 | security_group = sec_grps_client.create_security_group( |
| 342 | name=sec_grp_name) |
| 343 | self.addCleanup(self.security_groups_client.delete_security_group, |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 344 | security_group['security_group']['id']) |
| 345 | post_body = { |
| 346 | "name": data_utils.rand_name('port-'), |
| 347 | "security_groups": [security_group['security_group']['id']], |
| 348 | "network_id": self.network['id'], |
| 349 | "admin_state_up": True, |
| 350 | "fixed_ips": fixed_ip_1} |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 351 | body = self.ports_client.create_port(**post_body) |
| 352 | self.addCleanup(self.ports_client.delete_port, body['port']['id']) |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 353 | port = body['port'] |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 354 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 355 | # Update the port with security groups |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 356 | subnet_2 = self.create_subnet(self.network) |
| 357 | fixed_ip_2 = [{'subnet_id': subnet_2['id']}] |
| 358 | update_body = {"name": data_utils.rand_name('port-'), |
| 359 | "admin_state_up": False, |
| 360 | "fixed_ips": fixed_ip_2, |
| 361 | "security_groups": security_groups_list} |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 362 | body = self.ports_client.update_port(port['id'], **update_body) |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 363 | port_show = body['port'] |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 364 | # Verify the security groups and other attributes updated to port |
| 365 | exclude_keys = set(port_show).symmetric_difference(update_body) |
| 366 | exclude_keys.add('fixed_ips') |
| 367 | exclude_keys.add('security_groups') |
| 368 | self.assertThat(port_show, custom_matchers.MatchesDictExceptForKeys( |
| 369 | update_body, exclude_keys)) |
| 370 | self.assertEqual(fixed_ip_2[0]['subnet_id'], |
| 371 | port_show['fixed_ips'][0]['subnet_id']) |
| 372 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 373 | for security_group in security_groups_list: |
| 374 | self.assertIn(security_group, port_show['security_groups']) |
| 375 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 376 | @decorators.idempotent_id('58091b66-4ff4-4cc1-a549-05d60c7acd1a') |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 377 | @testtools.skipUnless( |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 378 | utils.is_extension_enabled('security-group', 'network'), |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 379 | 'security-group extension not enabled.') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 380 | def test_update_port_with_security_group_and_extra_attributes(self): |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 381 | self._update_port_with_security_groups( |
| 382 | [data_utils.rand_name('secgroup')]) |
| 383 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 384 | @decorators.idempotent_id('edf6766d-3d40-4621-bc6e-2521a44c257d') |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 385 | @testtools.skipUnless( |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 386 | utils.is_extension_enabled('security-group', 'network'), |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 387 | 'security-group extension not enabled.') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 388 | def test_update_port_with_two_security_groups_and_extra_attributes(self): |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 389 | self._update_port_with_security_groups( |
| 390 | [data_utils.rand_name('secgroup'), |
| 391 | data_utils.rand_name('secgroup')]) |
| 392 | |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 393 | @decorators.idempotent_id('13e95171-6cbd-489c-9d7c-3f9c58215c18') |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 394 | def test_create_show_delete_port_user_defined_mac(self): |
| 395 | # Create a port for a legal mac |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 396 | body = self.ports_client.create_port(network_id=self.network['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 397 | old_port = body['port'] |
| 398 | free_mac_address = old_port['mac_address'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 399 | self.ports_client.delete_port(old_port['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 400 | # Create a new port with user defined mac |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 401 | body = self.ports_client.create_port(network_id=self.network['id'], |
| 402 | mac_address=free_mac_address) |
| 403 | self.addCleanup(self.ports_client.delete_port, body['port']['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 404 | port = body['port'] |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 405 | body = self.ports_client.show_port(port['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 406 | show_port = body['port'] |
| 407 | self.assertEqual(free_mac_address, |
| 408 | show_port['mac_address']) |
| 409 | |
Jordan Pittier | 3b46d27 | 2017-04-12 16:17:28 +0200 | [diff] [blame] | 410 | @decorators.attr(type='smoke') |
Ken'ichi Ohmichi | 53b9a63 | 2017-01-27 18:04:39 -0800 | [diff] [blame] | 411 | @decorators.idempotent_id('4179dcb9-1382-4ced-84fe-1b91c54f5735') |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 412 | @testtools.skipUnless( |
Andrea Frittoli | cd36841 | 2017-08-14 21:37:56 +0100 | [diff] [blame] | 413 | utils.is_extension_enabled('security-group', 'network'), |
zhufl | fffec23 | 2016-09-18 17:09:11 +0800 | [diff] [blame] | 414 | 'security-group extension not enabled.') |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 415 | def test_create_port_with_no_securitygroups(self): |
Salvatore | 18dd66e | 2014-12-31 00:13:57 +0100 | [diff] [blame] | 416 | network = self.create_network() |
John Warren | 94d8faf | 2015-09-15 12:22:24 -0400 | [diff] [blame] | 417 | self.addCleanup(self.networks_client.delete_network, network['id']) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 418 | subnet = self.create_subnet(network) |
John Warren | 3961acd | 2015-10-02 14:38:53 -0400 | [diff] [blame] | 419 | self.addCleanup(self.subnets_client.delete_subnet, subnet['id']) |
Salvatore | 18dd66e | 2014-12-31 00:13:57 +0100 | [diff] [blame] | 420 | port = self.create_port(network, security_groups=[]) |
John Warren | 49c0fe5 | 2015-10-22 12:35:54 -0400 | [diff] [blame] | 421 | self.addCleanup(self.ports_client.delete_port, port['id']) |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 422 | self.assertIsNotNone(port['security_groups']) |
| 423 | self.assertEmpty(port['security_groups']) |
| 424 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 425 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 426 | class PortsIpV6TestJSON(PortsTestJSON): |
| 427 | _ip_version = 6 |