blob: 1b1e284d93a8e49e68658b6c2f57477859dcb867 [file] [log] [blame]
Elena Ezhova1ec6e182013-12-24 17:45:59 +04001# Copyright 2014 OpenStack Foundation
2# All Rights Reserved.
3#
4# Licensed under the Apache License, Version 2.0 (the "License"); you may
5# not use this file except in compliance with the License. You may obtain
6# a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13# License for the specific language governing permissions and limitations
14# under the License.
15
16import socket
17
18from tempest.api.network import base
Neeti Dahiyade291772014-09-22 10:43:12 +053019from tempest.api.network import base_security_groups as sec_base
Santosh Kumarf0cbf9a2014-08-25 07:31:15 -070020from tempest.common import custom_matchers
Elena Ezhova1ec6e182013-12-24 17:45:59 +040021from tempest.common.utils import data_utils
22from tempest import config
23from tempest import test
24
25CONF = config.CONF
26
27
Neeti Dahiyade291772014-09-22 10:43:12 +053028class PortsTestJSON(sec_base.BaseSecGroupTest):
Elena Ezhova1ec6e182013-12-24 17:45:59 +040029 _interface = 'json'
30
Elena Ezhova5c957152014-03-26 12:01:10 +040031 """
32 Test the following operations for ports:
33
34 port create
35 port delete
36 port list
37 port show
38 port update
39 """
40
Elena Ezhova1ec6e182013-12-24 17:45:59 +040041 @classmethod
Andrea Frittolida4a2452014-09-15 13:12:08 +010042 def resource_setup(cls):
43 super(PortsTestJSON, cls).resource_setup()
Elena Ezhova1ec6e182013-12-24 17:45:59 +040044 cls.network = cls.create_network()
45 cls.port = cls.create_port(cls.network)
46
47 def _delete_port(self, port_id):
Rohan Kanadeeeb21642014-08-14 12:00:26 +020048 self.client.delete_port(port_id)
David Kranz34e88122014-12-11 15:24:05 -050049 body = self.client.list_ports()
Elena Ezhova1ec6e182013-12-24 17:45:59 +040050 ports_list = body['ports']
51 self.assertFalse(port_id in [n['id'] for n in ports_list])
52
53 @test.attr(type='smoke')
54 def test_create_update_delete_port(self):
55 # Verify port creation
David Kranz34e88122014-12-11 15:24:05 -050056 body = self.client.create_port(network_id=self.network['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +040057 port = body['port']
Dane LeBlanccbc4bc52014-03-19 16:03:23 -040058 # Schedule port deletion with verification upon test completion
59 self.addCleanup(self._delete_port, port['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +040060 self.assertTrue(port['admin_state_up'])
61 # Verify port update
62 new_name = "New_Port"
David Kranz34e88122014-12-11 15:24:05 -050063 body = self.client.update_port(port['id'],
64 name=new_name,
65 admin_state_up=False)
Elena Ezhova1ec6e182013-12-24 17:45:59 +040066 updated_port = body['port']
67 self.assertEqual(updated_port['name'], new_name)
68 self.assertFalse(updated_port['admin_state_up'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +040069
abhishek6001472607373102014-11-25 04:39:20 -080070 def test_create_bulk_port(self):
71 network1 = self.network
72 name = data_utils.rand_name('network-')
73 network2 = self.create_network(network_name=name)
74 network_list = [network1['id'], network2['id']]
75 port_list = [{'network_id': net_id} for net_id in network_list]
David Kranz34e88122014-12-11 15:24:05 -050076 body = self.client.create_bulk_port(port_list)
abhishek6001472607373102014-11-25 04:39:20 -080077 created_ports = body['ports']
78 port1 = created_ports[0]
79 port2 = created_ports[1]
80 self.addCleanup(self._delete_port, port1['id'])
81 self.addCleanup(self._delete_port, port2['id'])
82 self.assertEqual(port1['network_id'], network1['id'])
83 self.assertEqual(port2['network_id'], network2['id'])
84 self.assertTrue(port1['admin_state_up'])
85 self.assertTrue(port2['admin_state_up'])
86
Elena Ezhova1ec6e182013-12-24 17:45:59 +040087 @test.attr(type='smoke')
88 def test_show_port(self):
89 # Verify the details of port
David Kranz34e88122014-12-11 15:24:05 -050090 body = self.client.show_port(self.port['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +040091 port = body['port']
92 self.assertIn('id', port)
Santosh Kumarf0cbf9a2014-08-25 07:31:15 -070093 # TODO(Santosh)- This is a temporary workaround to compare create_port
94 # and show_port dict elements.Remove this once extra_dhcp_opts issue
95 # gets fixed in neutron.( bug - 1365341.)
96 self.assertThat(self.port,
97 custom_matchers.MatchesDictExceptForKeys
98 (port, excluded_keys=['extra_dhcp_opts']))
Elena Ezhova1ec6e182013-12-24 17:45:59 +040099
100 @test.attr(type='smoke')
101 def test_show_port_fields(self):
102 # Verify specific fields of a port
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500103 fields = ['id', 'mac_address']
David Kranz34e88122014-12-11 15:24:05 -0500104 body = self.client.show_port(self.port['id'],
105 fields=fields)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400106 port = body['port']
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500107 self.assertEqual(sorted(port.keys()), sorted(fields))
108 for field_name in fields:
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400109 self.assertEqual(port[field_name], self.port[field_name])
110
111 @test.attr(type='smoke')
112 def test_list_ports(self):
113 # Verify the port exists in the list of all ports
David Kranz34e88122014-12-11 15:24:05 -0500114 body = self.client.list_ports()
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400115 ports = [port['id'] for port in body['ports']
116 if port['id'] == self.port['id']]
117 self.assertNotEmpty(ports, "Created port not found in the list")
118
119 @test.attr(type='smoke')
120 def test_port_list_filter_by_router_id(self):
121 # Create a router
122 network = self.create_network()
123 self.create_subnet(network)
124 router = self.create_router(data_utils.rand_name('router-'))
David Kranz34e88122014-12-11 15:24:05 -0500125 port = self.client.create_port(network_id=network['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400126 # Add router interface to port created above
David Kranz34e88122014-12-11 15:24:05 -0500127 self.client.add_router_interface_with_port_id(
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400128 router['id'], port['port']['id'])
129 self.addCleanup(self.client.remove_router_interface_with_port_id,
130 router['id'], port['port']['id'])
131 # List ports filtered by router_id
David Kranz34e88122014-12-11 15:24:05 -0500132 port_list = self.client.list_ports(device_id=router['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400133 ports = port_list['ports']
134 self.assertEqual(len(ports), 1)
135 self.assertEqual(ports[0]['id'], port['port']['id'])
136 self.assertEqual(ports[0]['device_id'], router['id'])
137
138 @test.attr(type='smoke')
139 def test_list_ports_fields(self):
140 # Verify specific fields of ports
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500141 fields = ['id', 'mac_address']
David Kranz34e88122014-12-11 15:24:05 -0500142 body = self.client.list_ports(fields=fields)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400143 ports = body['ports']
144 self.assertNotEmpty(ports, "Port list returned is empty")
145 # Asserting the fields returned are correct
146 for port in ports:
Zhi Kun Liu903596c2014-04-11 08:55:53 -0500147 self.assertEqual(sorted(fields), sorted(port.keys()))
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400148
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400149 @test.attr(type='smoke')
Neeti Dahiyade291772014-09-22 10:43:12 +0530150 def test_create_update_port_with_second_ip(self):
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400151 # Create a network with two subnets
152 network = self.create_network()
153 subnet_1 = self.create_subnet(network)
154 subnet_2 = self.create_subnet(network)
155 fixed_ip_1 = [{'subnet_id': subnet_1['id']}]
156 fixed_ip_2 = [{'subnet_id': subnet_2['id']}]
157
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400158 fixed_ips = fixed_ip_1 + fixed_ip_2
Neeti Dahiyade291772014-09-22 10:43:12 +0530159
160 # Create a port with multiple IP addresses
161 port = self.create_port(network,
162 fixed_ips=fixed_ips)
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400163 self.assertEqual(2, len(port['fixed_ips']))
Neeti Dahiyade291772014-09-22 10:43:12 +0530164 check_fixed_ips = [subnet_1['id'], subnet_2['id']]
165 for item in port['fixed_ips']:
166 self.assertIn(item['subnet_id'], check_fixed_ips)
Dane LeBlanccbc4bc52014-03-19 16:03:23 -0400167
168 # Update the port to return to a single IP address
169 port = self.update_port(port, fixed_ips=fixed_ip_1)
170 self.assertEqual(1, len(port['fixed_ips']))
171
Neeti Dahiyade291772014-09-22 10:43:12 +0530172 # Update the port with a second IP address from second subnet
173 port = self.update_port(port, fixed_ips=fixed_ips)
174 self.assertEqual(2, len(port['fixed_ips']))
175
Ashish Guptadba59f92014-07-16 02:24:45 -0700176 def _update_port_with_security_groups(self, security_groups_names):
Neeti Dahiyade291772014-09-22 10:43:12 +0530177 subnet_1 = self.create_subnet(self.network)
178 fixed_ip_1 = [{'subnet_id': subnet_1['id']}]
179
Ashish Guptadba59f92014-07-16 02:24:45 -0700180 security_groups_list = list()
181 for name in security_groups_names:
David Kranz34e88122014-12-11 15:24:05 -0500182 group_create_body = self.client.create_security_group(
Ashish Guptadba59f92014-07-16 02:24:45 -0700183 name=name)
184 self.addCleanup(self.client.delete_security_group,
185 group_create_body['security_group']['id'])
186 security_groups_list.append(group_create_body['security_group']
187 ['id'])
188 # Create a port
Neeti Dahiyade291772014-09-22 10:43:12 +0530189 sec_grp_name = data_utils.rand_name('secgroup')
190 security_group = self.client.create_security_group(name=sec_grp_name)
191 self.addCleanup(self.client.delete_security_group,
192 security_group['security_group']['id'])
193 post_body = {
194 "name": data_utils.rand_name('port-'),
195 "security_groups": [security_group['security_group']['id']],
196 "network_id": self.network['id'],
197 "admin_state_up": True,
198 "fixed_ips": fixed_ip_1}
David Kranz34e88122014-12-11 15:24:05 -0500199 body = self.client.create_port(**post_body)
Ashish Guptadba59f92014-07-16 02:24:45 -0700200 self.addCleanup(self.client.delete_port, body['port']['id'])
201 port = body['port']
Neeti Dahiyade291772014-09-22 10:43:12 +0530202
Ashish Guptadba59f92014-07-16 02:24:45 -0700203 # Update the port with security groups
Neeti Dahiyade291772014-09-22 10:43:12 +0530204 subnet_2 = self.create_subnet(self.network)
205 fixed_ip_2 = [{'subnet_id': subnet_2['id']}]
206 update_body = {"name": data_utils.rand_name('port-'),
207 "admin_state_up": False,
208 "fixed_ips": fixed_ip_2,
209 "security_groups": security_groups_list}
David Kranz34e88122014-12-11 15:24:05 -0500210 body = self.client.update_port(port['id'], **update_body)
Ashish Guptadba59f92014-07-16 02:24:45 -0700211 port_show = body['port']
Neeti Dahiyade291772014-09-22 10:43:12 +0530212 # Verify the security groups and other attributes updated to port
213 exclude_keys = set(port_show).symmetric_difference(update_body)
214 exclude_keys.add('fixed_ips')
215 exclude_keys.add('security_groups')
216 self.assertThat(port_show, custom_matchers.MatchesDictExceptForKeys(
217 update_body, exclude_keys))
218 self.assertEqual(fixed_ip_2[0]['subnet_id'],
219 port_show['fixed_ips'][0]['subnet_id'])
220
Ashish Guptadba59f92014-07-16 02:24:45 -0700221 for security_group in security_groups_list:
222 self.assertIn(security_group, port_show['security_groups'])
223
224 @test.attr(type='smoke')
Neeti Dahiyade291772014-09-22 10:43:12 +0530225 def test_update_port_with_security_group_and_extra_attributes(self):
Ashish Guptadba59f92014-07-16 02:24:45 -0700226 self._update_port_with_security_groups(
227 [data_utils.rand_name('secgroup')])
228
229 @test.attr(type='smoke')
Neeti Dahiyade291772014-09-22 10:43:12 +0530230 def test_update_port_with_two_security_groups_and_extra_attributes(self):
Ashish Guptadba59f92014-07-16 02:24:45 -0700231 self._update_port_with_security_groups(
232 [data_utils.rand_name('secgroup'),
233 data_utils.rand_name('secgroup')])
234
Ashish Guptad42b6e12014-11-20 02:06:03 -0800235 @test.attr(type='smoke')
236 def test_create_show_delete_port_user_defined_mac(self):
237 # Create a port for a legal mac
David Kranz34e88122014-12-11 15:24:05 -0500238 body = self.client.create_port(network_id=self.network['id'])
Ashish Guptad42b6e12014-11-20 02:06:03 -0800239 old_port = body['port']
240 free_mac_address = old_port['mac_address']
241 self.client.delete_port(old_port['id'])
242 # Create a new port with user defined mac
David Kranz34e88122014-12-11 15:24:05 -0500243 body = self.client.create_port(network_id=self.network['id'],
244 mac_address=free_mac_address)
Ashish Guptad42b6e12014-11-20 02:06:03 -0800245 self.addCleanup(self.client.delete_port, body['port']['id'])
246 port = body['port']
David Kranz34e88122014-12-11 15:24:05 -0500247 body = self.client.show_port(port['id'])
Ashish Guptad42b6e12014-11-20 02:06:03 -0800248 show_port = body['port']
249 self.assertEqual(free_mac_address,
250 show_port['mac_address'])
251
Rajkumar Thiyagarajan0f562a82014-08-21 01:59:19 -0700252 @test.attr(type='smoke')
253 def test_create_port_with_no_securitygroups(self):
Salvatore18dd66e2014-12-31 00:13:57 +0100254 network = self.create_network()
255 self.create_subnet(network)
256 port = self.create_port(network, security_groups=[])
Rajkumar Thiyagarajan0f562a82014-08-21 01:59:19 -0700257 self.assertIsNotNone(port['security_groups'])
258 self.assertEmpty(port['security_groups'])
259
260 @test.attr(type='smoke')
261 def test_update_port_with_no_securitygroups(self):
Salvatore18dd66e2014-12-31 00:13:57 +0100262 network = self.create_network()
263 self.create_subnet(network)
264 port = self.create_port(network)
Rajkumar Thiyagarajan0f562a82014-08-21 01:59:19 -0700265 # Verify that port is created with default security group
266 self.assertIsNotNone(port['security_groups'])
267 self.assertNotEmpty(port['security_groups'])
268 updated_port = self.update_port(port, security_groups=[])
269 self.assertIsNotNone(updated_port['security_groups'])
270 self.assertEmpty(updated_port['security_groups'])
271
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400272
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400273class PortsAdminExtendedAttrsTestJSON(base.BaseAdminNetworkTest):
274 _interface = 'json'
275
276 @classmethod
Andrea Frittolida4a2452014-09-15 13:12:08 +0100277 def resource_setup(cls):
278 super(PortsAdminExtendedAttrsTestJSON, cls).resource_setup()
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400279 cls.identity_client = cls._get_identity_admin_client()
280 cls.tenant = cls.identity_client.get_tenant_by_name(
281 CONF.identity.tenant_name)
282 cls.network = cls.create_network()
283 cls.host_id = socket.gethostname()
284
285 @test.attr(type='smoke')
286 def test_create_port_binding_ext_attr(self):
287 post_body = {"network_id": self.network['id'],
288 "binding:host_id": self.host_id}
David Kranz34e88122014-12-11 15:24:05 -0500289 body = self.admin_client.create_port(**post_body)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400290 port = body['port']
291 self.addCleanup(self.admin_client.delete_port, port['id'])
292 host_id = port['binding:host_id']
293 self.assertIsNotNone(host_id)
294 self.assertEqual(self.host_id, host_id)
295
296 @test.attr(type='smoke')
297 def test_update_port_binding_ext_attr(self):
298 post_body = {"network_id": self.network['id']}
David Kranz34e88122014-12-11 15:24:05 -0500299 body = self.admin_client.create_port(**post_body)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400300 port = body['port']
301 self.addCleanup(self.admin_client.delete_port, port['id'])
302 update_body = {"binding:host_id": self.host_id}
David Kranz34e88122014-12-11 15:24:05 -0500303 body = self.admin_client.update_port(port['id'], **update_body)
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400304 updated_port = body['port']
305 host_id = updated_port['binding:host_id']
306 self.assertIsNotNone(host_id)
307 self.assertEqual(self.host_id, host_id)
308
309 @test.attr(type='smoke')
310 def test_list_ports_binding_ext_attr(self):
Adam Gandelman7e80e4e2014-04-03 00:38:26 -0700311 # Create a new port
312 post_body = {"network_id": self.network['id']}
David Kranz34e88122014-12-11 15:24:05 -0500313 body = self.admin_client.create_port(**post_body)
Adam Gandelman7e80e4e2014-04-03 00:38:26 -0700314 port = body['port']
315 self.addCleanup(self.admin_client.delete_port, port['id'])
316
317 # Update the port's binding attributes so that is now 'bound'
318 # to a host
319 update_body = {"binding:host_id": self.host_id}
Rohan Kanadeeeb21642014-08-14 12:00:26 +0200320 self.admin_client.update_port(port['id'], **update_body)
Adam Gandelman7e80e4e2014-04-03 00:38:26 -0700321
322 # List all ports, ensure new port is part of list and its binding
323 # attributes are set and accurate
David Kranz34e88122014-12-11 15:24:05 -0500324 body = self.admin_client.list_ports()
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400325 ports_list = body['ports']
Adam Gandelman7e80e4e2014-04-03 00:38:26 -0700326 pids_list = [p['id'] for p in ports_list]
327 self.assertIn(port['id'], pids_list)
328 listed_port = [p for p in ports_list if p['id'] == port['id']]
329 self.assertEqual(1, len(listed_port),
330 'Multiple ports listed with id %s in ports listing: '
331 '%s' % (port['id'], ports_list))
332 self.assertEqual(self.host_id, listed_port[0]['binding:host_id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400333
334 @test.attr(type='smoke')
335 def test_show_port_binding_ext_attr(self):
David Kranz34e88122014-12-11 15:24:05 -0500336 body = self.admin_client.create_port(network_id=self.network['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400337 port = body['port']
338 self.addCleanup(self.admin_client.delete_port, port['id'])
David Kranz34e88122014-12-11 15:24:05 -0500339 body = self.admin_client.show_port(port['id'])
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400340 show_port = body['port']
341 self.assertEqual(port['binding:host_id'],
342 show_port['binding:host_id'])
343 self.assertEqual(port['binding:vif_type'],
344 show_port['binding:vif_type'])
345 self.assertEqual(port['binding:vif_details'],
346 show_port['binding:vif_details'])
347
348
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400349class PortsIpV6TestJSON(PortsTestJSON):
350 _ip_version = 6
351 _tenant_network_cidr = CONF.network.tenant_network_v6_cidr
352 _tenant_network_mask_bits = CONF.network.tenant_network_v6_mask_bits
353
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400354
Elena Ezhova1ec6e182013-12-24 17:45:59 +0400355class PortsAdminExtendedAttrsIpV6TestJSON(PortsAdminExtendedAttrsTestJSON):
356 _ip_version = 6
357 _tenant_network_cidr = CONF.network.tenant_network_v6_cidr
358 _tenant_network_mask_bits = CONF.network.tenant_network_v6_mask_bits