blob: 7787770706b09ba26e9d82630957e4050184998b [file] [log] [blame]
Zhi Kun Liu1eebb992013-12-10 17:46:47 +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
16from tempest.common.utils import data_utils
17from tempest import exceptions
He Jie Xueb6890f2014-01-22 16:11:45 +080018from tempest import test
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080019
20
Ken'ichi Ohmichi7f508ed2014-01-30 22:35:20 +090021class ServersAdminV3Test(base.BaseV3ComputeAdminTest):
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080022
23 """
24 Tests Servers API using admin privileges
25 """
26
ChenZhengd4acec42014-01-03 15:22:31 +080027 _host_key = 'os-extended-server-attributes:host'
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080028
29 @classmethod
30 def setUpClass(cls):
Ken'ichi Ohmichi7f508ed2014-01-30 22:35:20 +090031 super(ServersAdminV3Test, cls).setUpClass()
Zhi Kun Liude892722013-12-30 15:27:52 +080032 cls.client = cls.servers_admin_client
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080033 cls.non_admin_client = cls.servers_client
Zhi Kun Liude892722013-12-30 15:27:52 +080034 cls.flavors_client = cls.flavors_admin_client
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080035
36 cls.s1_name = data_utils.rand_name('server')
37 resp, server = cls.create_test_server(name=cls.s1_name,
38 wait_until='ACTIVE')
39 cls.s1_id = server['id']
40
41 cls.s2_name = data_utils.rand_name('server')
42 resp, server = cls.create_test_server(name=cls.s2_name,
43 wait_until='ACTIVE')
ChenZheng5b62f652014-01-03 15:03:33 +080044 cls.s2_id = server['id']
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080045
46 def _get_unused_flavor_id(self):
47 flavor_id = data_utils.rand_int_id(start=1000)
48 while True:
49 try:
50 resp, body = self.flavors_client.get_flavor_details(flavor_id)
51 except exceptions.NotFound:
52 break
53 flavor_id = data_utils.rand_int_id(start=1000)
54 return flavor_id
55
ChenZhengd4acec42014-01-03 15:22:31 +080056 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080057 def test_list_servers_by_admin(self):
58 # Listing servers by admin user returns empty list by default
59 resp, body = self.client.list_servers_with_detail()
60 servers = body['servers']
61 self.assertEqual('200', resp['status'])
62 self.assertEqual([], servers)
63
He Jie Xueb6890f2014-01-22 16:11:45 +080064 @test.skip_because(bug='1265416')
ChenZhengd4acec42014-01-03 15:22:31 +080065 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080066 def test_list_servers_by_admin_with_all_tenants(self):
67 # Listing servers by admin user with all tenants parameter
68 # Here should be listed all servers
69 params = {'all_tenants': ''}
70 resp, body = self.client.list_servers_with_detail(params)
71 servers = body['servers']
72 servers_name = map(lambda x: x['name'], servers)
73
74 self.assertIn(self.s1_name, servers_name)
75 self.assertIn(self.s2_name, servers_name)
76
ChenZhengd4acec42014-01-03 15:22:31 +080077 @test.attr(type='gate')
78 def test_list_servers_filter_by_existent_host(self):
79 # Filter the list of servers by existent host
80 name = data_utils.rand_name('server')
81 flavor = self.flavor_ref
82 image_id = self.image_ref
83 resp, test_server = self.client.create_server(
84 name, image_id, flavor)
85 self.assertEqual('202', resp['status'])
86 self.addCleanup(self.client.delete_server, test_server['id'])
87 self.client.wait_for_server_status(test_server['id'], 'ACTIVE')
88 resp, server = self.client.get_server(test_server['id'])
89 self.assertEqual(server['status'], 'ACTIVE')
90 hostname = server[self._host_key]
91 params = {'host': hostname}
92 resp, body = self.client.list_servers(params)
93 self.assertEqual('200', resp['status'])
94 servers = body['servers']
95 nonexistent_params = {'host': 'nonexistent_host'}
96 resp, nonexistent_body = self.client.list_servers(
97 nonexistent_params)
98 self.assertEqual('200', resp['status'])
99 nonexistent_servers = nonexistent_body['servers']
100 self.assertIn(test_server['id'], map(lambda x: x['id'], servers))
101 self.assertNotIn(test_server['id'],
102 map(lambda x: x['id'], nonexistent_servers))
103
104 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800105 def test_reset_state_server(self):
106 # Reset server's state to 'error'
107 resp, server = self.client.reset_state(self.s1_id)
108 self.assertEqual(202, resp.status)
109
110 # Verify server's state
111 resp, server = self.client.get_server(self.s1_id)
112 self.assertEqual(server['status'], 'ERROR')
113
114 # Reset server's state to 'active'
115 resp, server = self.client.reset_state(self.s1_id, state='active')
116 self.assertEqual(202, resp.status)
117
118 # Verify server's state
119 resp, server = self.client.get_server(self.s1_id)
120 self.assertEqual(server['status'], 'ACTIVE')
121
ChenZhengd4acec42014-01-03 15:22:31 +0800122 @test.attr(type='gate')
123 @test.skip_because(bug="1240043")
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800124 def test_get_server_diagnostics_by_admin(self):
125 # Retrieve server diagnostics by admin user
126 resp, diagnostic = self.client.get_server_diagnostics(self.s1_id)
127 self.assertEqual(200, resp.status)
128 basic_attrs = ['rx_packets', 'rx_errors', 'rx_drop',
129 'tx_packets', 'tx_errors', 'tx_drop',
130 'read_req', 'write_req', 'cpu', 'memory']
131 for key in basic_attrs:
132 self.assertIn(key, str(diagnostic.keys()))
133
ChenZhengd4acec42014-01-03 15:22:31 +0800134 @test.attr(type='gate')
ChenZheng5b62f652014-01-03 15:03:33 +0800135 def test_list_servers_filter_by_error_status(self):
136 # Filter the list of servers by server error status
137 params = {'status': 'error'}
138 resp, server = self.client.reset_state(self.s1_id, state='error')
139 resp, body = self.non_admin_client.list_servers(params)
140 # Reset server's state to 'active'
141 resp, server = self.client.reset_state(self.s1_id, state='active')
142 # Verify server's state
143 resp, server = self.client.get_server(self.s1_id)
144 self.assertEqual(server['status'], 'ACTIVE')
145 servers = body['servers']
146 # Verify error server in list result
147 self.assertIn(self.s1_id, map(lambda x: x['id'], servers))
148 self.assertNotIn(self.s2_id, map(lambda x: x['id'], servers))
149
ChenZhengd4acec42014-01-03 15:22:31 +0800150 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800151 def test_rebuild_server_in_error_state(self):
152 # The server in error state should be rebuilt using the provided
153 # image and changed to ACTIVE state
154
Marc Solanasb15d8b62014-02-07 00:04:15 -0800155 # resetting vm state require admin privilege
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800156 resp, server = self.client.reset_state(self.s1_id, state='error')
157 self.assertEqual(202, resp.status)
158 resp, rebuilt_server = self.non_admin_client.rebuild(
159 self.s1_id, self.image_ref_alt)
160 self.addCleanup(self.non_admin_client.wait_for_server_status,
161 self.s1_id, 'ACTIVE')
162 self.addCleanup(self.non_admin_client.rebuild, self.s1_id,
163 self.image_ref)
164
165 # Verify the properties in the initial response are correct
166 self.assertEqual(self.s1_id, rebuilt_server['id'])
167 rebuilt_image_id = rebuilt_server['image']['id']
168 self.assertEqual(self.image_ref_alt, rebuilt_image_id)
169 self.assertEqual(self.flavor_ref, rebuilt_server['flavor']['id'])
170 self.non_admin_client.wait_for_server_status(rebuilt_server['id'],
171 'ACTIVE',
172 raise_on_error=False)
173 # Verify the server properties after rebuilding
174 resp, server = self.non_admin_client.get_server(rebuilt_server['id'])
175 rebuilt_image_id = server['image']['id']
176 self.assertEqual(self.image_ref_alt, rebuilt_image_id)