Add hypervisor details to hypervisors list if requested
Allow optionally generating a list of hypervisors that includes hypervisor details to reduce both openstacksdk and Nova API calls when details are wanted for all hypervisors and to better mirror the Nova API which provides such a feature. The "details" argument defaults to "False" to maintain API backwards compatibility. Change-Id: Iefa32570a43a7e1fd6f05ab519882424272ae1c1 Signed-off-by: Corey Wright <corey.wright@rackspace.com>
This commit is contained in:
parent
07d3828860
commit
f7da0170ae
@ -937,14 +937,23 @@ class Proxy(proxy.Proxy):
|
|||||||
"""
|
"""
|
||||||
return self._list(_server_group.ServerGroup, paginated=False, **query)
|
return self._list(_server_group.ServerGroup, paginated=False, **query)
|
||||||
|
|
||||||
def hypervisors(self):
|
def hypervisors(self, details=False):
|
||||||
"""Return a generator of hypervisor
|
"""Return a generator of hypervisor
|
||||||
|
|
||||||
|
:param bool details: When set to the default, ``False``,
|
||||||
|
:class:`~openstack.compute.v2.hypervisor.Hypervisor`
|
||||||
|
instances will be returned. ``True`` will cause
|
||||||
|
:class:`~openstack.compute.v2.hypervisor.HypervisorDetail`
|
||||||
|
instances to be returned.
|
||||||
:returns: A generator of hypervisor
|
:returns: A generator of hypervisor
|
||||||
:rtype: class: `~openstack.compute.v2.hypervisor.Hypervisor`
|
:rtype: class: `~openstack.compute.v2.hypervisor.Hypervisor`
|
||||||
"""
|
"""
|
||||||
|
if details:
|
||||||
|
hypervisor = _hypervisor.HypervisorDetail
|
||||||
|
else:
|
||||||
|
hypervisor = _hypervisor.Hypervisor
|
||||||
|
|
||||||
return self._list(_hypervisor.Hypervisor, paginated=False)
|
return self._list(hypervisor, paginated=False)
|
||||||
|
|
||||||
def find_hypervisor(self, name_or_id, ignore_missing=True):
|
def find_hypervisor(self, name_or_id, ignore_missing=True):
|
||||||
"""Find a hypervisor from name or id to get the corresponding info
|
"""Find a hypervisor from name or id to get the corresponding info
|
||||||
|
@ -65,3 +65,11 @@ class Hypervisor(resource.Resource):
|
|||||||
host_ip = resource.Body('host_ip')
|
host_ip = resource.Body('host_ip')
|
||||||
#: Disk space available to the scheduler
|
#: Disk space available to the scheduler
|
||||||
disk_available = resource.Body("disk_available_least")
|
disk_available = resource.Body("disk_available_least")
|
||||||
|
|
||||||
|
|
||||||
|
class HypervisorDetail(Hypervisor):
|
||||||
|
base_path = '/os-hypervisors/detail'
|
||||||
|
|
||||||
|
# capabilities
|
||||||
|
allow_get = False
|
||||||
|
allow_list = True
|
||||||
|
@ -76,3 +76,12 @@ class TestHypervisor(base.TestCase):
|
|||||||
self.assertEqual(EXAMPLE['disk_available_least'], sot.disk_available)
|
self.assertEqual(EXAMPLE['disk_available_least'], sot.disk_available)
|
||||||
self.assertEqual(EXAMPLE['local_gb'], sot.local_disk_size)
|
self.assertEqual(EXAMPLE['local_gb'], sot.local_disk_size)
|
||||||
self.assertEqual(EXAMPLE['free_ram_mb'], sot.memory_free)
|
self.assertEqual(EXAMPLE['free_ram_mb'], sot.memory_free)
|
||||||
|
|
||||||
|
def test_detail(self):
|
||||||
|
sot = hypervisor.HypervisorDetail()
|
||||||
|
self.assertEqual('hypervisor', sot.resource_key)
|
||||||
|
self.assertEqual('hypervisors', sot.resources_key)
|
||||||
|
self.assertEqual('/os-hypervisors/detail', sot.base_path)
|
||||||
|
self.assertEqual('compute', sot.service.service_type)
|
||||||
|
self.assertFalse(sot.allow_get)
|
||||||
|
self.assertTrue(sot.allow_list)
|
||||||
|
@ -475,10 +475,15 @@ class TestComputeProxy(test_proxy_base.TestProxyBase):
|
|||||||
self.verify_list(self.proxy.server_groups, server_group.ServerGroup,
|
self.verify_list(self.proxy.server_groups, server_group.ServerGroup,
|
||||||
paginated=False)
|
paginated=False)
|
||||||
|
|
||||||
def test_hypervisors(self):
|
def test_hypervisors_not_detailed(self):
|
||||||
self.verify_list_no_kwargs(self.proxy.hypervisors,
|
self.verify_list(self.proxy.hypervisors, hypervisor.Hypervisor,
|
||||||
hypervisor.Hypervisor,
|
paginated=False,
|
||||||
paginated=False)
|
method_kwargs={"details": False})
|
||||||
|
|
||||||
|
def test_hypervisors_detailed(self):
|
||||||
|
self.verify_list(self.proxy.hypervisors, hypervisor.HypervisorDetail,
|
||||||
|
paginated=False,
|
||||||
|
method_kwargs={"details": True})
|
||||||
|
|
||||||
def test_find_hypervisor(self):
|
def test_find_hypervisor(self):
|
||||||
self.verify_find(self.proxy.find_hypervisor,
|
self.verify_find(self.proxy.find_hypervisor,
|
||||||
|
Loading…
Reference in New Issue
Block a user