Merge "Add support for using extensions"

This commit is contained in:
Jenkins 2014-07-16 14:13:14 +00:00 committed by Gerrit Code Review
commit 05ef356b3d
2 changed files with 58 additions and 0 deletions

View File

@ -19,6 +19,8 @@ The VMware API utility module.
import suds import suds
from oslo.vmware.openstack.common import timeutils
def get_moref(value, type_): def get_moref(value, type_):
"""Get managed object reference. """Get managed object reference.
@ -372,3 +374,43 @@ def get_object_property(vim, moref, property_name):
if prop: if prop:
prop_val = prop[0].val prop_val = prop[0].val
return prop_val return prop_val
def find_extension(vim, key):
"""Looks for an existing extension.
:param vim: Vim object
:param key: the key to search for
:returns: the data object Extension or None
"""
extension_manager = vim.service_content.extensionManager
return vim.client.service.FindExtension(extension_manager, key)
def register_extension(vim, key, type, label='OpenStack',
summary='OpenStack services', version='1.0'):
"""Create a new extention.
:param vim: Vim object
:param key: the key for the extension
:param type: Managed entity type, as defined by the extension. This
matches the type field in the configuration about a
virtual machine or vApp
:param label: Display label
:param summary: Summary description
:param version: Extension version number as a dot-separated string
"""
extension_manager = vim.service_content.extensionManager
client_factory = vim.client.factory
os_ext = client_factory.create('ns0:Extension')
os_ext.key = key
entity_info = client_factory.create('ns0:ExtManagedEntityInfo')
entity_info.type = type
os_ext.managedEntityInfo = [entity_info]
os_ext.version = version
desc = client_factory.create('ns0:Description')
desc.label = label
desc.summary = summary
os_ext.description = desc
os_ext.lastHeartbeatTime = timeutils.strtime()
vim.client.service.RegisterExtension(extension_manager, os_ext)

View File

@ -292,3 +292,19 @@ class VimUtilTest(base.TestCase):
self.assertEqual(prop.val, val) self.assertEqual(prop.val, val)
get_object_properties.assert_called_once_with( get_object_properties.assert_called_once_with(
vim, moref, [property_name]) vim, moref, [property_name])
def test_find_extension(self):
vim = mock.Mock()
ret = vim_util.find_extension(vim, 'fake-key')
self.assertIsNotNone(ret)
service_content = vim.service_content
vim.client.service.FindExtension.assert_called_once_with(
service_content.extensionManager, 'fake-key')
def test_register_extension(self):
vim = mock.Mock()
ret = vim_util.register_extension(vim, 'fake-key', 'fake-type')
self.assertIsNone(ret)
service_content = vim.service_content
vim.client.service.RegisterExtension.assert_called_once_with(
service_content.extensionManager, mock.ANY)