blob: 79777d041572d76f0ccc2f29c0b0496c7238a1c7 [file] [log] [blame]
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +08001# Copyright 2013 IBM Corp.
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may
4# not use this file except in compliance with the License. You may obtain
5# a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations
13# under the License.
14
15from tempest.api.compute import base
Jordan Pittier599a3562016-01-08 17:38:14 +010016from tempest.common import compute
Rohan Kanade9ce97df2013-12-10 18:59:35 +053017from tempest.common import fixed_network
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +000018from tempest.common import waiters
Ken'ichi Ohmichi757833a2017-03-10 10:30:30 -080019from tempest.lib.common.utils import data_utils
Andrea Frittoli (andreaf)db9672e2016-02-23 14:07:24 -050020from tempest.lib import decorators
ghanshyam33310122017-01-31 07:47:42 +000021from tempest import test
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080022
23
ivan-zhuf2b00502013-10-18 10:06:52 +080024class ServersAdminTestJSON(base.BaseV2ComputeAdminTest):
Ken'ichi Ohmichi9e3dac02015-11-19 07:01:07 +000025 """Tests Servers API using admin privileges"""
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080026
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080027 @classmethod
Rohan Kanade60b73092015-02-04 17:58:19 +053028 def setup_clients(cls):
29 super(ServersAdminTestJSON, cls).setup_clients()
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080030 cls.client = cls.os_adm.servers_client
Zhi Kun Liue5401762013-09-11 20:45:48 +080031 cls.non_admin_client = cls.servers_client
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080032
Rohan Kanade60b73092015-02-04 17:58:19 +053033 @classmethod
34 def resource_setup(cls):
35 super(ServersAdminTestJSON, cls).resource_setup()
36
zhuflc6ce5392016-08-17 14:34:37 +080037 cls.s1_name = data_utils.rand_name(cls.__name__ + '-server')
David Kranz0fb14292015-02-11 15:55:20 -050038 server = cls.create_test_server(name=cls.s1_name,
39 wait_until='ACTIVE')
LingxianKongc26e6072013-09-28 21:16:52 +080040 cls.s1_id = server['id']
41
zhuflc6ce5392016-08-17 14:34:37 +080042 cls.s2_name = data_utils.rand_name(cls.__name__ + '-server')
David Kranz0fb14292015-02-11 15:55:20 -050043 server = cls.create_test_server(name=cls.s2_name,
44 wait_until='ACTIVE')
ChenZheng5b62f652014-01-03 15:03:33 +080045 cls.s2_id = server['id']
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080046
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -080047 @decorators.idempotent_id('06f960bb-15bb-48dc-873d-f96e89be7870')
ChenZheng5b62f652014-01-03 15:03:33 +080048 def test_list_servers_filter_by_error_status(self):
49 # Filter the list of servers by server error status
50 params = {'status': 'error'}
David Kranzae99b9a2015-02-16 13:37:01 -050051 self.client.reset_state(self.s1_id, state='error')
Ken'ichi Ohmichicbc26a82015-07-03 08:18:04 +000052 body = self.non_admin_client.list_servers(**params)
ChenZheng5b62f652014-01-03 15:03:33 +080053 # Reset server's state to 'active'
David Kranzae99b9a2015-02-16 13:37:01 -050054 self.client.reset_state(self.s1_id, state='active')
ChenZheng5b62f652014-01-03 15:03:33 +080055 # Verify server's state
ghanshyam0f825252015-08-25 16:02:50 +090056 server = self.client.show_server(self.s1_id)['server']
ChenZheng5b62f652014-01-03 15:03:33 +080057 self.assertEqual(server['status'], 'ACTIVE')
58 servers = body['servers']
59 # Verify error server in list result
60 self.assertIn(self.s1_id, map(lambda x: x['id'], servers))
61 self.assertNotIn(self.s2_id, map(lambda x: x['id'], servers))
62
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -080063 @decorators.idempotent_id('d56e9540-73ed-45e0-9b88-98fc419087eb')
Ken'ichi Ohmichi68be16f2016-06-03 13:19:26 -070064 def test_list_servers_detailed_filter_by_invalid_status(self):
65 params = {'status': 'invalid_status'}
66 body = self.client.list_servers(detail=True, **params)
67 servers = body['servers']
68 self.assertEqual([], servers)
69
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -080070 @decorators.idempotent_id('51717b38-bdc1-458b-b636-1cf82d99f62f')
Ken'ichi Ohmichi3f9cd0c2016-09-01 14:52:03 -070071 def test_list_servers_by_admin(self):
72 # Listing servers by admin user returns a list which doesn't
73 # contain the other tenants' server by default
74 body = self.client.list_servers(detail=True)
75 servers = body['servers']
76
77 # This case is for the test environments which contain
78 # the existing servers before testing
79 servers_name = [server['name'] for server in servers]
80 self.assertNotIn(self.s1_name, servers_name)
81 self.assertNotIn(self.s2_name, servers_name)
82
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -080083 @decorators.idempotent_id('9f5579ae-19b4-4985-a091-2a5d56106580')
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080084 def test_list_servers_by_admin_with_all_tenants(self):
85 # Listing servers by admin user with all tenants parameter
86 # Here should be listed all servers
87 params = {'all_tenants': ''}
Ken'ichi Ohmichicbc26a82015-07-03 08:18:04 +000088 body = self.client.list_servers(detail=True, **params)
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080089 servers = body['servers']
Sirushti Murugesan935f2cc2016-07-12 19:48:24 +053090 servers_name = [server['name'] for server in servers]
Liu, Zhi Kunb0ac0b82013-06-20 16:20:21 +080091
92 self.assertIn(self.s1_name, servers_name)
93 self.assertIn(self.s2_name, servers_name)
94
ghanshyam33310122017-01-31 07:47:42 +000095 @test.related_bug('1659811')
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -080096 @decorators.idempotent_id('7e5d6b8f-454a-4ba1-8ae2-da857af8338b')
David Kranzb28b4182015-01-05 16:07:19 -050097 def test_list_servers_by_admin_with_specified_tenant(self):
98 # In nova v2, tenant_id is ignored unless all_tenants is specified
99
100 # List the primary tenant but get nothing due to odd specified behavior
101 tenant_id = self.non_admin_client.tenant_id
102 params = {'tenant_id': tenant_id}
Ken'ichi Ohmichicbc26a82015-07-03 08:18:04 +0000103 body = self.client.list_servers(detail=True, **params)
David Kranzb28b4182015-01-05 16:07:19 -0500104 servers = body['servers']
Davanum Srinivas816607c2017-01-17 16:01:31 -0500105 servers_name = [x['name'] for x in servers]
zhufl80b8d0a2016-09-22 14:35:27 +0800106 self.assertNotIn(self.s1_name, servers_name)
107 self.assertNotIn(self.s2_name, servers_name)
David Kranzb28b4182015-01-05 16:07:19 -0500108
guo yunxian88a7e092016-09-28 17:36:57 +0800109 # List the primary tenant with all_tenants is specified
110 params = {'all_tenants': '', 'tenant_id': tenant_id}
111 body = self.client.list_servers(detail=True, **params)
112 servers = body['servers']
Davanum Srinivas816607c2017-01-17 16:01:31 -0500113 servers_name = [x['name'] for x in servers]
guo yunxian88a7e092016-09-28 17:36:57 +0800114 self.assertIn(self.s1_name, servers_name)
115 self.assertIn(self.s2_name, servers_name)
116
zhufl80b8d0a2016-09-22 14:35:27 +0800117 # List the admin tenant shouldn't get servers created by other tenants
David Kranzb28b4182015-01-05 16:07:19 -0500118 admin_tenant_id = self.client.tenant_id
119 params = {'all_tenants': '', 'tenant_id': admin_tenant_id}
Ken'ichi Ohmichicbc26a82015-07-03 08:18:04 +0000120 body = self.client.list_servers(detail=True, **params)
David Kranzb28b4182015-01-05 16:07:19 -0500121 servers = body['servers']
Davanum Srinivas816607c2017-01-17 16:01:31 -0500122 servers_name = [x['name'] for x in servers]
zhufl80b8d0a2016-09-22 14:35:27 +0800123 self.assertNotIn(self.s1_name, servers_name)
124 self.assertNotIn(self.s2_name, servers_name)
David Kranzb28b4182015-01-05 16:07:19 -0500125
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -0800126 @decorators.idempotent_id('86c7a8f7-50cf-43a9-9bac-5b985317134f')
ChenZhengd4acec42014-01-03 15:22:31 +0800127 def test_list_servers_filter_by_exist_host(self):
128 # Filter the list of servers by existent host
zhuflc6ce5392016-08-17 14:34:37 +0800129 name = data_utils.rand_name(self.__class__.__name__ + '-server')
Rohan Kanade9ce97df2013-12-10 18:59:35 +0530130 network = self.get_tenant_network()
131 network_kwargs = fixed_network.set_networks_kwarg(network)
Jordan Pittier599a3562016-01-08 17:38:14 +0100132 # We need to create the server as an admin, so we can't use
133 # self.create_test_server() here as this method creates the server
134 # in the "primary" (i.e non-admin) tenant.
135 test_server, _ = compute.create_test_server(
136 self.os_adm, wait_until="ACTIVE", name=name, **network_kwargs)
ChenZhengd4acec42014-01-03 15:22:31 +0800137 self.addCleanup(self.client.delete_server, test_server['id'])
ghanshyam0f825252015-08-25 16:02:50 +0900138 server = self.client.show_server(test_server['id'])['server']
ChenZhengd4acec42014-01-03 15:22:31 +0800139 self.assertEqual(server['status'], 'ACTIVE')
Ken'ichi Ohmichi70456892016-08-12 14:31:19 -0700140 hostname = server['OS-EXT-SRV-ATTR:host']
ChenZhengd4acec42014-01-03 15:22:31 +0800141 params = {'host': hostname}
Ken'ichi Ohmichicbc26a82015-07-03 08:18:04 +0000142 body = self.client.list_servers(**params)
ChenZhengd4acec42014-01-03 15:22:31 +0800143 servers = body['servers']
144 nonexistent_params = {'host': 'nonexistent_host'}
Ken'ichi Ohmichicbc26a82015-07-03 08:18:04 +0000145 nonexistent_body = self.client.list_servers(**nonexistent_params)
ChenZhengd4acec42014-01-03 15:22:31 +0800146 nonexistent_servers = nonexistent_body['servers']
147 self.assertIn(test_server['id'], map(lambda x: x['id'], servers))
148 self.assertNotIn(test_server['id'],
149 map(lambda x: x['id'], nonexistent_servers))
150
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -0800151 @decorators.idempotent_id('ee8ae470-db70-474d-b752-690b7892cab1')
LingxianKongc26e6072013-09-28 21:16:52 +0800152 def test_reset_state_server(self):
153 # Reset server's state to 'error'
Ken'ichi Ohmichi36b714c2015-12-09 08:12:47 +0000154 self.client.reset_state(self.s1_id, state='error')
LingxianKongc26e6072013-09-28 21:16:52 +0800155
156 # Verify server's state
ghanshyam0f825252015-08-25 16:02:50 +0900157 server = self.client.show_server(self.s1_id)['server']
LingxianKongc26e6072013-09-28 21:16:52 +0800158 self.assertEqual(server['status'], 'ERROR')
159
160 # Reset server's state to 'active'
David Kranzae99b9a2015-02-16 13:37:01 -0500161 self.client.reset_state(self.s1_id, state='active')
LingxianKongc26e6072013-09-28 21:16:52 +0800162
163 # Verify server's state
ghanshyam0f825252015-08-25 16:02:50 +0900164 server = self.client.show_server(self.s1_id)['server']
LingxianKongc26e6072013-09-28 21:16:52 +0800165 self.assertEqual(server['status'], 'ACTIVE')
166
Matthew Treinishc49fcbe2015-02-05 23:37:34 -0500167 @decorators.skip_because(bug="1240043")
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -0800168 @decorators.idempotent_id('31ff3486-b8a0-4f56-a6c0-aab460531db3')
Zhu Zhuda070852013-09-25 08:07:57 -0500169 def test_get_server_diagnostics_by_admin(self):
170 # Retrieve server diagnostics by admin user
Ken'ichi Ohmichi277d1882015-11-20 00:44:06 +0000171 diagnostic = self.client.show_server_diagnostics(self.s1_id)
Zhu Zhuda070852013-09-25 08:07:57 -0500172 basic_attrs = ['rx_packets', 'rx_errors', 'rx_drop',
173 'tx_packets', 'tx_errors', 'tx_drop',
174 'read_req', 'write_req', 'cpu', 'memory']
175 for key in basic_attrs:
176 self.assertIn(key, str(diagnostic.keys()))
177
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -0800178 @decorators.idempotent_id('682cb127-e5bb-4f53-87ce-cb9003604442')
Zhi Kun Liue5401762013-09-11 20:45:48 +0800179 def test_rebuild_server_in_error_state(self):
180 # The server in error state should be rebuilt using the provided
181 # image and changed to ACTIVE state
182
Marc Solanasb15d8b62014-02-07 00:04:15 -0800183 # resetting vm state require admin privilege
David Kranzae99b9a2015-02-16 13:37:01 -0500184 self.client.reset_state(self.s1_id, state='error')
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000185 rebuilt_server = self.non_admin_client.rebuild_server(
ghanshyam0f825252015-08-25 16:02:50 +0900186 self.s1_id, self.image_ref_alt)['server']
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +0000187 self.addCleanup(waiters.wait_for_server_status, self.non_admin_client,
Zhi Kun Liue5401762013-09-11 20:45:48 +0800188 self.s1_id, 'ACTIVE')
Ken'ichi Ohmichi5271b0f2015-08-10 07:53:27 +0000189 self.addCleanup(self.non_admin_client.rebuild_server, self.s1_id,
Zhi Kun Liue5401762013-09-11 20:45:48 +0800190 self.image_ref)
191
192 # Verify the properties in the initial response are correct
193 self.assertEqual(self.s1_id, rebuilt_server['id'])
194 rebuilt_image_id = rebuilt_server['image']['id']
195 self.assertEqual(self.image_ref_alt, rebuilt_image_id)
196 self.assertEqual(self.flavor_ref, rebuilt_server['flavor']['id'])
Ken'ichi Ohmichi0eb153c2015-07-13 02:18:25 +0000197 waiters.wait_for_server_status(self.non_admin_client,
198 rebuilt_server['id'], 'ACTIVE',
199 raise_on_error=False)
Zhi Kun Liue5401762013-09-11 20:45:48 +0800200 # Verify the server properties after rebuilding
ghanshyam0f825252015-08-25 16:02:50 +0900201 server = (self.non_admin_client.show_server(rebuilt_server['id'])
202 ['server'])
Zhi Kun Liue5401762013-09-11 20:45:48 +0800203 rebuilt_image_id = server['image']['id']
204 self.assertEqual(self.image_ref_alt, rebuilt_image_id)
205
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -0800206 @decorators.idempotent_id('7a1323b4-a6a2-497a-96cb-76c07b945c71')
Ghanshyam Mann79f4a092014-02-27 21:01:31 +0900207 def test_reset_network_inject_network_info(self):
208 # Reset Network of a Server
David Kranz0fb14292015-02-11 15:55:20 -0500209 server = self.create_test_server(wait_until='ACTIVE')
David Kranzae99b9a2015-02-16 13:37:01 -0500210 self.client.reset_network(server['id'])
Ghanshyam Mann79f4a092014-02-27 21:01:31 +0900211 # Inject the Network Info into Server
David Kranzae99b9a2015-02-16 13:37:01 -0500212 self.client.inject_network_info(server['id'])
Ghanshyam Mann79f4a092014-02-27 21:01:31 +0900213
Ken'ichi Ohmichiebbfd1c2017-01-27 16:37:00 -0800214 @decorators.idempotent_id('fdcd9b33-0903-4e00-a1f7-b5f6543068d6')
raiesmh08cbe21b02014-03-12 17:04:44 +0530215 def test_create_server_with_scheduling_hint(self):
216 # Create a server with scheduler hints.
217 hints = {
218 'same_host': self.s1_id
219 }
Ken'ichi Ohmichif2d436e2015-09-03 01:13:16 +0000220 self.create_test_server(scheduler_hints=hints,
David Kranz0fb14292015-02-11 15:55:20 -0500221 wait_until='ACTIVE')