Added missing extension file and tests. Also modified the get_host_list() docstring to be more accurate about the return value.
This commit is contained in:
@@ -116,8 +116,9 @@ class ZoneManager(object):
|
||||
return [zone.to_dict() for zone in self.zone_states.values()]
|
||||
|
||||
def get_host_list(self):
|
||||
"""Returns a list of all the host names that the Zone Manager
|
||||
knows about.
|
||||
"""Returns a list of dicts for each host that the Zone Manager
|
||||
knows about. Each dict contains the host_name and the service
|
||||
for that host.
|
||||
"""
|
||||
all_hosts = self.service_states.keys()
|
||||
ret = []
|
||||
|
101
nova/tests/test_hosts.py
Normal file
101
nova/tests/test_hosts.py
Normal file
@@ -0,0 +1,101 @@
|
||||
# Copyright (c) 2011 Openstack, LLC.
|
||||
# All Rights Reserved.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
# not use this file except in compliance with the License. You may obtain
|
||||
# a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
import stubout
|
||||
|
||||
from nova import context
|
||||
from nova import exception
|
||||
from nova import flags
|
||||
from nova import log as logging
|
||||
from nova import test
|
||||
from nova.api.openstack.contrib import hosts as os_hosts
|
||||
from nova.scheduler import api as scheduler_api
|
||||
|
||||
|
||||
FLAGS = flags.FLAGS
|
||||
LOG = logging.getLogger('nova.tests.hosts')
|
||||
# Simulate the hosts returned by the zone manager.
|
||||
HOST_LIST = [
|
||||
{"host_name": "host_c1", "service": "compute"},
|
||||
{"host_name": "host_c2", "service": "compute"},
|
||||
{"host_name": "host_v1", "service": "volume"},
|
||||
{"host_name": "host_v2", "service": "volume"}]
|
||||
|
||||
|
||||
def stub_get_host_list(req):
|
||||
return HOST_LIST
|
||||
|
||||
|
||||
def stub_set_host_enabled(context, host, enabled):
|
||||
# We'll simulate success and failure by assuming
|
||||
# that 'host_c1' always succeeds, and 'host_c2'
|
||||
# always fails
|
||||
fail = (host == "host_c2")
|
||||
status = "enabled" if (enabled ^ fail) else "disabled"
|
||||
return status
|
||||
|
||||
|
||||
class FakeRequest(object):
|
||||
environ = {"nova.context": context.get_admin_context()}
|
||||
|
||||
|
||||
class HostTestCase(test.TestCase):
|
||||
"""Test Case for hosts."""
|
||||
|
||||
def setUp(self):
|
||||
super(HostTestCase, self).setUp()
|
||||
self.controller = os_hosts.HostController()
|
||||
self.req = FakeRequest()
|
||||
self.stubs.Set(scheduler_api, 'get_host_list', stub_get_host_list)
|
||||
self.stubs.Set(self.controller.compute_api, 'set_host_enabled',
|
||||
stub_set_host_enabled)
|
||||
|
||||
def test_list_hosts(self):
|
||||
"""Verify that the compute hosts are returned."""
|
||||
hosts = os_hosts._list_hosts(self.req)
|
||||
self.assertEqual(hosts, HOST_LIST)
|
||||
|
||||
compute_hosts = os_hosts._list_hosts(self.req, "compute")
|
||||
expected = [host for host in HOST_LIST
|
||||
if host["service"] == "compute"]
|
||||
self.assertEqual(compute_hosts, expected)
|
||||
|
||||
def test_disable_host(self):
|
||||
dis_body = {"status": "disable"}
|
||||
result_c1 = self.controller.update(self.req, "host_c1", body=dis_body)
|
||||
self.assertEqual(result_c1["status"], "disabled")
|
||||
result_c2 = self.controller.update(self.req, "host_c2", body=dis_body)
|
||||
self.assertEqual(result_c2["status"], "enabled")
|
||||
|
||||
def test_enable_host(self):
|
||||
en_body = {"status": "enable"}
|
||||
result_c1 = self.controller.update(self.req, "host_c1", body=en_body)
|
||||
self.assertEqual(result_c1["status"], "enabled")
|
||||
result_c2 = self.controller.update(self.req, "host_c2", body=en_body)
|
||||
self.assertEqual(result_c2["status"], "disabled")
|
||||
|
||||
def test_bad_status_value(self):
|
||||
bad_body = {"status": "bad"}
|
||||
self.assertRaises(ValueError, self.controller.update, self.req,
|
||||
"host_c1", body=bad_body)
|
||||
|
||||
def test_bad_update_key(self):
|
||||
bad_body = {"crazy": "bad"}
|
||||
self.assertRaises(ValueError, self.controller.update, self.req,
|
||||
"host_c1", body=bad_body)
|
||||
|
||||
def test_bad_host(self):
|
||||
self.assertRaises(exception.HostNotFound, self.controller.update,
|
||||
self.req, "bogus_host_name", body={"status": "disable"})
|
Reference in New Issue
Block a user