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 | |
| 16 | import socket |
| 17 | |
Matthew Treinish | 01472ff | 2015-02-20 17:26:52 -0500 | [diff] [blame] | 18 | import netaddr |
| 19 | from tempest_lib.common.utils import data_utils |
| 20 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 21 | from tempest.api.network import base |
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 |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 24 | from tempest import config |
| 25 | from tempest import test |
| 26 | |
| 27 | CONF = config.CONF |
| 28 | |
| 29 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 30 | class PortsTestJSON(sec_base.BaseSecGroupTest): |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 31 | |
Elena Ezhova | 5c95715 | 2014-03-26 12:01:10 +0400 | [diff] [blame] | 32 | """ |
| 33 | Test the following operations for ports: |
| 34 | |
| 35 | port create |
| 36 | port delete |
| 37 | port list |
| 38 | port show |
| 39 | port update |
| 40 | """ |
| 41 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 42 | @classmethod |
Andrea Frittoli | da4a245 | 2014-09-15 13:12:08 +0100 | [diff] [blame] | 43 | def resource_setup(cls): |
| 44 | super(PortsTestJSON, cls).resource_setup() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 45 | cls.network = cls.create_network() |
| 46 | cls.port = cls.create_port(cls.network) |
| 47 | |
| 48 | def _delete_port(self, port_id): |
Rohan Kanade | eeb2164 | 2014-08-14 12:00:26 +0200 | [diff] [blame] | 49 | self.client.delete_port(port_id) |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 50 | body = self.client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 51 | ports_list = body['ports'] |
| 52 | self.assertFalse(port_id in [n['id'] for n in ports_list]) |
| 53 | |
| 54 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 55 | @test.idempotent_id('c72c1c0c-2193-4aca-aaa4-b1442640f51c') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 56 | def test_create_update_delete_port(self): |
| 57 | # Verify port creation |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 58 | body = self.client.create_port(network_id=self.network['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 59 | port = body['port'] |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 60 | # Schedule port deletion with verification upon test completion |
| 61 | self.addCleanup(self._delete_port, port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 62 | self.assertTrue(port['admin_state_up']) |
| 63 | # Verify port update |
| 64 | new_name = "New_Port" |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 65 | body = self.client.update_port(port['id'], |
| 66 | name=new_name, |
| 67 | admin_state_up=False) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 68 | updated_port = body['port'] |
| 69 | self.assertEqual(updated_port['name'], new_name) |
| 70 | self.assertFalse(updated_port['admin_state_up']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 71 | |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 72 | @test.idempotent_id('67f1b811-f8db-43e2-86bd-72c074d4a42c') |
abhishek60014726 | 0737310 | 2014-11-25 04:39:20 -0800 | [diff] [blame] | 73 | def test_create_bulk_port(self): |
| 74 | network1 = self.network |
| 75 | name = data_utils.rand_name('network-') |
| 76 | network2 = self.create_network(network_name=name) |
| 77 | network_list = [network1['id'], network2['id']] |
| 78 | port_list = [{'network_id': net_id} for net_id in network_list] |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 79 | body = self.client.create_bulk_port(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 | |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 90 | @classmethod |
| 91 | def _get_ipaddress_from_tempest_conf(cls): |
| 92 | """Return first subnet gateway for configured CIDR """ |
| 93 | if cls._ip_version == 4: |
| 94 | cidr = netaddr.IPNetwork(CONF.network.tenant_network_cidr) |
| 95 | |
| 96 | elif cls._ip_version == 6: |
| 97 | cidr = netaddr.IPNetwork(CONF.network.tenant_network_v6_cidr) |
| 98 | |
| 99 | return netaddr.IPAddress(cidr) |
| 100 | |
| 101 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 102 | @test.idempotent_id('0435f278-40ae-48cb-a404-b8a087bc09b1') |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 103 | def test_create_port_in_allowed_allocation_pools(self): |
| 104 | network = self.create_network() |
| 105 | net_id = network['id'] |
| 106 | address = self._get_ipaddress_from_tempest_conf() |
| 107 | allocation_pools = {'allocation_pools': [{'start': str(address + 4), |
| 108 | 'end': str(address + 6)}]} |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 109 | subnet = self.create_subnet(network, **allocation_pools) |
| 110 | self.addCleanup(self.client.delete_subnet, subnet['id']) |
abhishek60014726 | de45a5e | 2014-12-16 03:01:35 -0800 | [diff] [blame] | 111 | body = self.client.create_port(network_id=net_id) |
| 112 | self.addCleanup(self.client.delete_port, body['port']['id']) |
| 113 | port = body['port'] |
| 114 | ip_address = port['fixed_ips'][0]['ip_address'] |
| 115 | start_ip_address = allocation_pools['allocation_pools'][0]['start'] |
| 116 | end_ip_address = allocation_pools['allocation_pools'][0]['end'] |
| 117 | ip_range = netaddr.IPRange(start_ip_address, end_ip_address) |
| 118 | self.assertIn(ip_address, ip_range) |
| 119 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 120 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 121 | @test.idempotent_id('c9a685bd-e83f-499c-939f-9f7863ca259f') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 122 | def test_show_port(self): |
| 123 | # Verify the details of port |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 124 | body = self.client.show_port(self.port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 125 | port = body['port'] |
| 126 | self.assertIn('id', port) |
Santosh Kumar | f0cbf9a | 2014-08-25 07:31:15 -0700 | [diff] [blame] | 127 | # TODO(Santosh)- This is a temporary workaround to compare create_port |
| 128 | # and show_port dict elements.Remove this once extra_dhcp_opts issue |
| 129 | # gets fixed in neutron.( bug - 1365341.) |
| 130 | self.assertThat(self.port, |
| 131 | custom_matchers.MatchesDictExceptForKeys |
| 132 | (port, excluded_keys=['extra_dhcp_opts'])) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 133 | |
| 134 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 135 | @test.idempotent_id('45fcdaf2-dab0-4c13-ac6c-fcddfb579dbd') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 136 | def test_show_port_fields(self): |
| 137 | # Verify specific fields of a port |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 138 | fields = ['id', 'mac_address'] |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 139 | body = self.client.show_port(self.port['id'], |
| 140 | fields=fields) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 141 | port = body['port'] |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 142 | self.assertEqual(sorted(port.keys()), sorted(fields)) |
| 143 | for field_name in fields: |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 144 | self.assertEqual(port[field_name], self.port[field_name]) |
| 145 | |
| 146 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 147 | @test.idempotent_id('cf95b358-3e92-4a29-a148-52445e1ac50e') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 148 | def test_list_ports(self): |
| 149 | # Verify the port exists in the list of all ports |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 150 | body = self.client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 151 | ports = [port['id'] for port in body['ports'] |
| 152 | if port['id'] == self.port['id']] |
| 153 | self.assertNotEmpty(ports, "Created port not found in the list") |
| 154 | |
| 155 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 156 | @test.idempotent_id('5ad01ed0-0e6e-4c5d-8194-232801b15c72') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 157 | def test_port_list_filter_by_router_id(self): |
| 158 | # Create a router |
| 159 | network = self.create_network() |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 160 | self.addCleanup(self.client.delete_network, network['id']) |
| 161 | subnet = self.create_subnet(network) |
| 162 | self.addCleanup(self.client.delete_subnet, subnet['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 163 | router = self.create_router(data_utils.rand_name('router-')) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 164 | self.addCleanup(self.client.delete_router, router['id']) |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 165 | port = self.client.create_port(network_id=network['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 166 | # Add router interface to port created above |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 167 | self.client.add_router_interface_with_port_id( |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 168 | router['id'], port['port']['id']) |
| 169 | self.addCleanup(self.client.remove_router_interface_with_port_id, |
| 170 | router['id'], port['port']['id']) |
| 171 | # List ports filtered by router_id |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 172 | port_list = self.client.list_ports(device_id=router['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 173 | ports = port_list['ports'] |
| 174 | self.assertEqual(len(ports), 1) |
| 175 | self.assertEqual(ports[0]['id'], port['port']['id']) |
| 176 | self.assertEqual(ports[0]['device_id'], router['id']) |
| 177 | |
| 178 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 179 | @test.idempotent_id('ff7f117f-f034-4e0e-abff-ccef05c454b4') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 180 | def test_list_ports_fields(self): |
| 181 | # Verify specific fields of ports |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 182 | fields = ['id', 'mac_address'] |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 183 | body = self.client.list_ports(fields=fields) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 184 | ports = body['ports'] |
| 185 | self.assertNotEmpty(ports, "Port list returned is empty") |
| 186 | # Asserting the fields returned are correct |
| 187 | for port in ports: |
Zhi Kun Liu | 903596c | 2014-04-11 08:55:53 -0500 | [diff] [blame] | 188 | self.assertEqual(sorted(fields), sorted(port.keys())) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 189 | |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 190 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 191 | @test.idempotent_id('63aeadd4-3b49-427f-a3b1-19ca81f06270') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 192 | def test_create_update_port_with_second_ip(self): |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 193 | # Create a network with two subnets |
| 194 | network = self.create_network() |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 195 | self.addCleanup(self.client.delete_network, network['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 196 | subnet_1 = self.create_subnet(network) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 197 | self.addCleanup(self.client.delete_subnet, subnet_1['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 198 | subnet_2 = self.create_subnet(network) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 199 | self.addCleanup(self.client.delete_subnet, subnet_2['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 200 | fixed_ip_1 = [{'subnet_id': subnet_1['id']}] |
| 201 | fixed_ip_2 = [{'subnet_id': subnet_2['id']}] |
| 202 | |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 203 | fixed_ips = fixed_ip_1 + fixed_ip_2 |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 204 | |
| 205 | # Create a port with multiple IP addresses |
| 206 | port = self.create_port(network, |
| 207 | fixed_ips=fixed_ips) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 208 | self.addCleanup(self.client.delete_port, port['id']) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 209 | self.assertEqual(2, len(port['fixed_ips'])) |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 210 | check_fixed_ips = [subnet_1['id'], subnet_2['id']] |
| 211 | for item in port['fixed_ips']: |
| 212 | self.assertIn(item['subnet_id'], check_fixed_ips) |
Dane LeBlanc | cbc4bc5 | 2014-03-19 16:03:23 -0400 | [diff] [blame] | 213 | |
| 214 | # Update the port to return to a single IP address |
| 215 | port = self.update_port(port, fixed_ips=fixed_ip_1) |
| 216 | self.assertEqual(1, len(port['fixed_ips'])) |
| 217 | |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 218 | # Update the port with a second IP address from second subnet |
| 219 | port = self.update_port(port, fixed_ips=fixed_ips) |
| 220 | self.assertEqual(2, len(port['fixed_ips'])) |
| 221 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 222 | def _update_port_with_security_groups(self, security_groups_names): |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 223 | subnet_1 = self.create_subnet(self.network) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 224 | self.addCleanup(self.client.delete_subnet, subnet_1['id']) |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 225 | fixed_ip_1 = [{'subnet_id': subnet_1['id']}] |
| 226 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 227 | security_groups_list = list() |
| 228 | for name in security_groups_names: |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 229 | group_create_body = self.client.create_security_group( |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 230 | name=name) |
| 231 | self.addCleanup(self.client.delete_security_group, |
| 232 | group_create_body['security_group']['id']) |
| 233 | security_groups_list.append(group_create_body['security_group'] |
| 234 | ['id']) |
| 235 | # Create a port |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 236 | sec_grp_name = data_utils.rand_name('secgroup') |
| 237 | security_group = self.client.create_security_group(name=sec_grp_name) |
| 238 | self.addCleanup(self.client.delete_security_group, |
| 239 | security_group['security_group']['id']) |
| 240 | post_body = { |
| 241 | "name": data_utils.rand_name('port-'), |
| 242 | "security_groups": [security_group['security_group']['id']], |
| 243 | "network_id": self.network['id'], |
| 244 | "admin_state_up": True, |
| 245 | "fixed_ips": fixed_ip_1} |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 246 | body = self.client.create_port(**post_body) |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 247 | self.addCleanup(self.client.delete_port, body['port']['id']) |
| 248 | port = body['port'] |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 249 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 250 | # Update the port with security groups |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 251 | subnet_2 = self.create_subnet(self.network) |
| 252 | fixed_ip_2 = [{'subnet_id': subnet_2['id']}] |
| 253 | update_body = {"name": data_utils.rand_name('port-'), |
| 254 | "admin_state_up": False, |
| 255 | "fixed_ips": fixed_ip_2, |
| 256 | "security_groups": security_groups_list} |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 257 | body = self.client.update_port(port['id'], **update_body) |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 258 | port_show = body['port'] |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 259 | # Verify the security groups and other attributes updated to port |
| 260 | exclude_keys = set(port_show).symmetric_difference(update_body) |
| 261 | exclude_keys.add('fixed_ips') |
| 262 | exclude_keys.add('security_groups') |
| 263 | self.assertThat(port_show, custom_matchers.MatchesDictExceptForKeys( |
| 264 | update_body, exclude_keys)) |
| 265 | self.assertEqual(fixed_ip_2[0]['subnet_id'], |
| 266 | port_show['fixed_ips'][0]['subnet_id']) |
| 267 | |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 268 | for security_group in security_groups_list: |
| 269 | self.assertIn(security_group, port_show['security_groups']) |
| 270 | |
| 271 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 272 | @test.idempotent_id('58091b66-4ff4-4cc1-a549-05d60c7acd1a') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 273 | def test_update_port_with_security_group_and_extra_attributes(self): |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 274 | self._update_port_with_security_groups( |
| 275 | [data_utils.rand_name('secgroup')]) |
| 276 | |
| 277 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 278 | @test.idempotent_id('edf6766d-3d40-4621-bc6e-2521a44c257d') |
Neeti Dahiya | de29177 | 2014-09-22 10:43:12 +0530 | [diff] [blame] | 279 | def test_update_port_with_two_security_groups_and_extra_attributes(self): |
Ashish Gupta | dba59f9 | 2014-07-16 02:24:45 -0700 | [diff] [blame] | 280 | self._update_port_with_security_groups( |
| 281 | [data_utils.rand_name('secgroup'), |
| 282 | data_utils.rand_name('secgroup')]) |
| 283 | |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 284 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 285 | @test.idempotent_id('13e95171-6cbd-489c-9d7c-3f9c58215c18') |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 286 | def test_create_show_delete_port_user_defined_mac(self): |
| 287 | # Create a port for a legal mac |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 288 | body = self.client.create_port(network_id=self.network['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 289 | old_port = body['port'] |
| 290 | free_mac_address = old_port['mac_address'] |
| 291 | self.client.delete_port(old_port['id']) |
| 292 | # Create a new port with user defined mac |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 293 | body = self.client.create_port(network_id=self.network['id'], |
| 294 | mac_address=free_mac_address) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 295 | self.addCleanup(self.client.delete_port, body['port']['id']) |
| 296 | port = body['port'] |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 297 | body = self.client.show_port(port['id']) |
Ashish Gupta | d42b6e1 | 2014-11-20 02:06:03 -0800 | [diff] [blame] | 298 | show_port = body['port'] |
| 299 | self.assertEqual(free_mac_address, |
| 300 | show_port['mac_address']) |
| 301 | |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 302 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 303 | @test.idempotent_id('4179dcb9-1382-4ced-84fe-1b91c54f5735') |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 304 | def test_create_port_with_no_securitygroups(self): |
Salvatore | 18dd66e | 2014-12-31 00:13:57 +0100 | [diff] [blame] | 305 | network = self.create_network() |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 306 | self.addCleanup(self.client.delete_network, network['id']) |
| 307 | subnet = self.create_subnet(network) |
| 308 | self.addCleanup(self.client.delete_subnet, subnet['id']) |
Salvatore | 18dd66e | 2014-12-31 00:13:57 +0100 | [diff] [blame] | 309 | port = self.create_port(network, security_groups=[]) |
Adam Gandelman | e865004 | 2015-01-16 11:36:37 -0800 | [diff] [blame] | 310 | self.addCleanup(self.client.delete_port, port['id']) |
Rajkumar Thiyagarajan | 0f562a8 | 2014-08-21 01:59:19 -0700 | [diff] [blame] | 311 | self.assertIsNotNone(port['security_groups']) |
| 312 | self.assertEmpty(port['security_groups']) |
| 313 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 314 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 315 | class PortsAdminExtendedAttrsTestJSON(base.BaseAdminNetworkTest): |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 316 | |
| 317 | @classmethod |
Andrea Frittoli | da4a245 | 2014-09-15 13:12:08 +0100 | [diff] [blame] | 318 | def resource_setup(cls): |
| 319 | super(PortsAdminExtendedAttrsTestJSON, cls).resource_setup() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 320 | cls.identity_client = cls._get_identity_admin_client() |
| 321 | cls.tenant = cls.identity_client.get_tenant_by_name( |
| 322 | CONF.identity.tenant_name) |
| 323 | cls.network = cls.create_network() |
| 324 | cls.host_id = socket.gethostname() |
| 325 | |
| 326 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 327 | @test.idempotent_id('8e8569c1-9ac7-44db-8bc1-f5fb2814f29b') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 328 | def test_create_port_binding_ext_attr(self): |
| 329 | post_body = {"network_id": self.network['id'], |
| 330 | "binding:host_id": self.host_id} |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 331 | body = self.admin_client.create_port(**post_body) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 332 | port = body['port'] |
| 333 | self.addCleanup(self.admin_client.delete_port, port['id']) |
| 334 | host_id = port['binding:host_id'] |
| 335 | self.assertIsNotNone(host_id) |
| 336 | self.assertEqual(self.host_id, host_id) |
| 337 | |
| 338 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 339 | @test.idempotent_id('6f6c412c-711f-444d-8502-0ac30fbf5dd5') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 340 | def test_update_port_binding_ext_attr(self): |
| 341 | post_body = {"network_id": self.network['id']} |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 342 | body = self.admin_client.create_port(**post_body) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 343 | port = body['port'] |
| 344 | self.addCleanup(self.admin_client.delete_port, port['id']) |
| 345 | update_body = {"binding:host_id": self.host_id} |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 346 | body = self.admin_client.update_port(port['id'], **update_body) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 347 | updated_port = body['port'] |
| 348 | host_id = updated_port['binding:host_id'] |
| 349 | self.assertIsNotNone(host_id) |
| 350 | self.assertEqual(self.host_id, host_id) |
| 351 | |
| 352 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 353 | @test.idempotent_id('1c82a44a-6c6e-48ff-89e1-abe7eaf8f9f8') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 354 | def test_list_ports_binding_ext_attr(self): |
Adam Gandelman | 7e80e4e | 2014-04-03 00:38:26 -0700 | [diff] [blame] | 355 | # Create a new port |
| 356 | post_body = {"network_id": self.network['id']} |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 357 | body = self.admin_client.create_port(**post_body) |
Adam Gandelman | 7e80e4e | 2014-04-03 00:38:26 -0700 | [diff] [blame] | 358 | port = body['port'] |
| 359 | self.addCleanup(self.admin_client.delete_port, port['id']) |
| 360 | |
| 361 | # Update the port's binding attributes so that is now 'bound' |
| 362 | # to a host |
| 363 | update_body = {"binding:host_id": self.host_id} |
Rohan Kanade | eeb2164 | 2014-08-14 12:00:26 +0200 | [diff] [blame] | 364 | self.admin_client.update_port(port['id'], **update_body) |
Adam Gandelman | 7e80e4e | 2014-04-03 00:38:26 -0700 | [diff] [blame] | 365 | |
| 366 | # List all ports, ensure new port is part of list and its binding |
| 367 | # attributes are set and accurate |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 368 | body = self.admin_client.list_ports() |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 369 | ports_list = body['ports'] |
Adam Gandelman | 7e80e4e | 2014-04-03 00:38:26 -0700 | [diff] [blame] | 370 | pids_list = [p['id'] for p in ports_list] |
| 371 | self.assertIn(port['id'], pids_list) |
| 372 | listed_port = [p for p in ports_list if p['id'] == port['id']] |
| 373 | self.assertEqual(1, len(listed_port), |
| 374 | 'Multiple ports listed with id %s in ports listing: ' |
| 375 | '%s' % (port['id'], ports_list)) |
| 376 | self.assertEqual(self.host_id, listed_port[0]['binding:host_id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 377 | |
| 378 | @test.attr(type='smoke') |
Chris Hoge | 7579c1a | 2015-02-26 14:12:15 -0800 | [diff] [blame] | 379 | @test.idempotent_id('b54ac0ff-35fc-4c79-9ca3-c7dbd4ea4f13') |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 380 | def test_show_port_binding_ext_attr(self): |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 381 | body = self.admin_client.create_port(network_id=self.network['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 382 | port = body['port'] |
| 383 | self.addCleanup(self.admin_client.delete_port, port['id']) |
David Kranz | 34e8812 | 2014-12-11 15:24:05 -0500 | [diff] [blame] | 384 | body = self.admin_client.show_port(port['id']) |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 385 | show_port = body['port'] |
| 386 | self.assertEqual(port['binding:host_id'], |
| 387 | show_port['binding:host_id']) |
| 388 | self.assertEqual(port['binding:vif_type'], |
| 389 | show_port['binding:vif_type']) |
| 390 | self.assertEqual(port['binding:vif_details'], |
| 391 | show_port['binding:vif_details']) |
| 392 | |
| 393 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 394 | class PortsIpV6TestJSON(PortsTestJSON): |
| 395 | _ip_version = 6 |
| 396 | _tenant_network_cidr = CONF.network.tenant_network_v6_cidr |
| 397 | _tenant_network_mask_bits = CONF.network.tenant_network_v6_mask_bits |
| 398 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 399 | |
Elena Ezhova | 1ec6e18 | 2013-12-24 17:45:59 +0400 | [diff] [blame] | 400 | class PortsAdminExtendedAttrsIpV6TestJSON(PortsAdminExtendedAttrsTestJSON): |
| 401 | _ip_version = 6 |
| 402 | _tenant_network_cidr = CONF.network.tenant_network_v6_cidr |
| 403 | _tenant_network_mask_bits = CONF.network.tenant_network_v6_mask_bits |