blob: 579a535f26292993a7de8bbc1a3ece9b33ec9ae4 [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
Masayuki Igawa67b827f2014-03-17 18:44:57 +090030 @test.safe_setup
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080031 def setUpClass(cls):
Ken'ichi Ohmichi7f508ed2014-01-30 22:35:20 +090032 super(ServersAdminV3Test, cls).setUpClass()
Zhi Kun Liude892722013-12-30 15:27:52 +080033 cls.client = cls.servers_admin_client
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080034 cls.non_admin_client = cls.servers_client
Zhi Kun Liude892722013-12-30 15:27:52 +080035 cls.flavors_client = cls.flavors_admin_client
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080036
37 cls.s1_name = data_utils.rand_name('server')
38 resp, server = cls.create_test_server(name=cls.s1_name,
39 wait_until='ACTIVE')
40 cls.s1_id = server['id']
41
42 cls.s2_name = data_utils.rand_name('server')
43 resp, 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']
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080046
47 def _get_unused_flavor_id(self):
48 flavor_id = data_utils.rand_int_id(start=1000)
49 while True:
50 try:
51 resp, body = self.flavors_client.get_flavor_details(flavor_id)
52 except exceptions.NotFound:
53 break
54 flavor_id = data_utils.rand_int_id(start=1000)
55 return flavor_id
56
ChenZhengd4acec42014-01-03 15:22:31 +080057 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080058 def test_list_servers_by_admin(self):
59 # Listing servers by admin user returns empty list by default
60 resp, body = self.client.list_servers_with_detail()
61 servers = body['servers']
62 self.assertEqual('200', resp['status'])
63 self.assertEqual([], servers)
64
He Jie Xueb6890f2014-01-22 16:11:45 +080065 @test.skip_because(bug='1265416')
ChenZhengd4acec42014-01-03 15:22:31 +080066 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +080067 def test_list_servers_by_admin_with_all_tenants(self):
68 # Listing servers by admin user with all tenants parameter
69 # Here should be listed all servers
70 params = {'all_tenants': ''}
71 resp, body = self.client.list_servers_with_detail(params)
72 servers = body['servers']
73 servers_name = map(lambda x: x['name'], servers)
74
75 self.assertIn(self.s1_name, servers_name)
76 self.assertIn(self.s2_name, servers_name)
77
ChenZhengd4acec42014-01-03 15:22:31 +080078 @test.attr(type='gate')
79 def test_list_servers_filter_by_existent_host(self):
80 # Filter the list of servers by existent host
81 name = data_utils.rand_name('server')
82 flavor = self.flavor_ref
83 image_id = self.image_ref
84 resp, test_server = self.client.create_server(
85 name, image_id, flavor)
86 self.assertEqual('202', resp['status'])
87 self.addCleanup(self.client.delete_server, test_server['id'])
88 self.client.wait_for_server_status(test_server['id'], 'ACTIVE')
89 resp, server = self.client.get_server(test_server['id'])
90 self.assertEqual(server['status'], 'ACTIVE')
91 hostname = server[self._host_key]
92 params = {'host': hostname}
93 resp, body = self.client.list_servers(params)
94 self.assertEqual('200', resp['status'])
95 servers = body['servers']
96 nonexistent_params = {'host': 'nonexistent_host'}
97 resp, nonexistent_body = self.client.list_servers(
98 nonexistent_params)
99 self.assertEqual('200', resp['status'])
100 nonexistent_servers = nonexistent_body['servers']
101 self.assertIn(test_server['id'], map(lambda x: x['id'], servers))
102 self.assertNotIn(test_server['id'],
103 map(lambda x: x['id'], nonexistent_servers))
104
105 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800106 def test_reset_state_server(self):
107 # Reset server's state to 'error'
108 resp, server = self.client.reset_state(self.s1_id)
109 self.assertEqual(202, resp.status)
110
111 # Verify server's state
112 resp, server = self.client.get_server(self.s1_id)
113 self.assertEqual(server['status'], 'ERROR')
114
115 # Reset server's state to 'active'
116 resp, server = self.client.reset_state(self.s1_id, state='active')
117 self.assertEqual(202, resp.status)
118
119 # Verify server's state
120 resp, server = self.client.get_server(self.s1_id)
121 self.assertEqual(server['status'], 'ACTIVE')
122
ChenZhengd4acec42014-01-03 15:22:31 +0800123 @test.attr(type='gate')
124 @test.skip_because(bug="1240043")
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800125 def test_get_server_diagnostics_by_admin(self):
126 # Retrieve server diagnostics by admin user
127 resp, diagnostic = self.client.get_server_diagnostics(self.s1_id)
128 self.assertEqual(200, resp.status)
129 basic_attrs = ['rx_packets', 'rx_errors', 'rx_drop',
130 'tx_packets', 'tx_errors', 'tx_drop',
131 'read_req', 'write_req', 'cpu', 'memory']
132 for key in basic_attrs:
133 self.assertIn(key, str(diagnostic.keys()))
134
ChenZhengd4acec42014-01-03 15:22:31 +0800135 @test.attr(type='gate')
ChenZheng5b62f652014-01-03 15:03:33 +0800136 def test_list_servers_filter_by_error_status(self):
137 # Filter the list of servers by server error status
138 params = {'status': 'error'}
139 resp, server = self.client.reset_state(self.s1_id, state='error')
140 resp, body = self.non_admin_client.list_servers(params)
141 # Reset server's state to 'active'
142 resp, server = self.client.reset_state(self.s1_id, state='active')
143 # Verify server's state
144 resp, server = self.client.get_server(self.s1_id)
145 self.assertEqual(server['status'], 'ACTIVE')
146 servers = body['servers']
147 # Verify error server in list result
148 self.assertIn(self.s1_id, map(lambda x: x['id'], servers))
149 self.assertNotIn(self.s2_id, map(lambda x: x['id'], servers))
150
ChenZhengd4acec42014-01-03 15:22:31 +0800151 @test.attr(type='gate')
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800152 def test_rebuild_server_in_error_state(self):
153 # The server in error state should be rebuilt using the provided
154 # image and changed to ACTIVE state
155
Marc Solanasb15d8b62014-02-07 00:04:15 -0800156 # resetting vm state require admin privilege
Zhi Kun Liu1eebb992013-12-10 17:46:47 +0800157 resp, server = self.client.reset_state(self.s1_id, state='error')
158 self.assertEqual(202, resp.status)
159 resp, rebuilt_server = self.non_admin_client.rebuild(
160 self.s1_id, self.image_ref_alt)
161 self.addCleanup(self.non_admin_client.wait_for_server_status,
162 self.s1_id, 'ACTIVE')
163 self.addCleanup(self.non_admin_client.rebuild, self.s1_id,
164 self.image_ref)
165
166 # Verify the properties in the initial response are correct
167 self.assertEqual(self.s1_id, rebuilt_server['id'])
168 rebuilt_image_id = rebuilt_server['image']['id']
169 self.assertEqual(self.image_ref_alt, rebuilt_image_id)
170 self.assertEqual(self.flavor_ref, rebuilt_server['flavor']['id'])
171 self.non_admin_client.wait_for_server_status(rebuilt_server['id'],
172 'ACTIVE',
173 raise_on_error=False)
174 # Verify the server properties after rebuilding
175 resp, server = self.non_admin_client.get_server(rebuilt_server['id'])
176 rebuilt_image_id = server['image']['id']
177 self.assertEqual(self.image_ref_alt, rebuilt_image_id)
Ghanshyam0549f7b2014-03-04 19:07:52 +0900178
179 @test.attr(type='gate')
180 def test_reset_network_inject_network_info(self):
181 resp, server = self.create_test_server(wait_until='ACTIVE')
182 # Reset Network of a Server
183 resp, server_body = self.client.reset_network(server['id'])
184 self.assertEqual(202, resp.status)
185 # Inject the Network Info into Server
186 resp, server = self.client.inject_network_info(server['id'])
187 self.assertEqual(202, resp.status)