Update vmware_inventory (#26308)
Fix adds * Exception handling * Unit tests Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
parent
4e01397817
commit
f7c8e7bdab
2 changed files with 39 additions and 25 deletions
|
@ -39,14 +39,12 @@ from six.moves import configparser
|
||||||
from time import time
|
from time import time
|
||||||
from jinja2 import Environment
|
from jinja2 import Environment
|
||||||
|
|
||||||
HAS_PYVMOMI = False
|
|
||||||
try:
|
|
||||||
from pyVmomi import vim
|
|
||||||
from pyVim.connect import SmartConnect, Disconnect
|
|
||||||
|
|
||||||
HAS_PYVMOMI = True
|
try:
|
||||||
|
from pyVmomi import vim, vmodl
|
||||||
|
from pyVim.connect import SmartConnect, Disconnect
|
||||||
except ImportError:
|
except ImportError:
|
||||||
pass
|
sys.exit("ERROR: This inventory script required 'pyVmomi' Python module, it was not able to load it")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
import json
|
import json
|
||||||
|
@ -119,14 +117,12 @@ class VMWareInventory(object):
|
||||||
env.filters['regex_match'] = regex_match
|
env.filters['regex_match'] = regex_match
|
||||||
|
|
||||||
# translation table for attributes to fetch for known vim types
|
# translation table for attributes to fetch for known vim types
|
||||||
if not HAS_PYVMOMI:
|
|
||||||
vimTable = {}
|
vimTable = {
|
||||||
else:
|
vim.Datastore: ['_moId', 'name'],
|
||||||
vimTable = {
|
vim.ResourcePool: ['_moId', 'name'],
|
||||||
vim.Datastore: ['_moId', 'name'],
|
vim.HostSystem: ['_moId', 'name'],
|
||||||
vim.ResourcePool: ['_moId', 'name'],
|
}
|
||||||
vim.HostSystem: ['_moId', 'name'],
|
|
||||||
}
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _empty_inventory():
|
def _empty_inventory():
|
||||||
|
@ -347,13 +343,21 @@ class VMWareInventory(object):
|
||||||
''' Make API calls '''
|
''' Make API calls '''
|
||||||
|
|
||||||
instances = []
|
instances = []
|
||||||
si = SmartConnect(**inkwargs)
|
try:
|
||||||
|
si = SmartConnect(**inkwargs)
|
||||||
|
except ssl.SSLError as connection_error:
|
||||||
|
if '[SSL: CERTIFICATE_VERIFY_FAILED]' in str(connection_error) and self.validate_certs:
|
||||||
|
sys.exit("Unable to connect to ESXi server due to %s, "
|
||||||
|
"please specify validate_certs=False and try again" % connection_error)
|
||||||
|
|
||||||
|
except Exception as exc:
|
||||||
|
self.debugl("Unable to connect to ESXi server due to %s" % exc)
|
||||||
|
sys.exit("Unable to connect to ESXi server due to %s" % exc)
|
||||||
|
|
||||||
self.debugl('retrieving all instances')
|
self.debugl('retrieving all instances')
|
||||||
if not si:
|
if not si:
|
||||||
print("Could not connect to the specified host using specified "
|
sys.exit("Could not connect to the specified host using specified "
|
||||||
"username and password")
|
"username and password")
|
||||||
return -1
|
|
||||||
atexit.register(Disconnect, si)
|
atexit.register(Disconnect, si)
|
||||||
content = si.RetrieveContent()
|
content = si.RetrieveContent()
|
||||||
|
|
||||||
|
@ -384,12 +388,16 @@ class VMWareInventory(object):
|
||||||
instance_tuples.append((instance, ifacts))
|
instance_tuples.append((instance, ifacts))
|
||||||
self.debugl('facts collected for all instances')
|
self.debugl('facts collected for all instances')
|
||||||
|
|
||||||
cfm = content.customFieldsManager
|
try:
|
||||||
if cfm is not None and cfm.field:
|
cfm = content.customFieldsManager
|
||||||
for f in cfm.field:
|
if cfm is not None and cfm.field:
|
||||||
if f.managedObjectType == vim.VirtualMachine:
|
for f in cfm.field:
|
||||||
self.custom_fields[f.key] = f.name
|
if f.managedObjectType == vim.VirtualMachine:
|
||||||
self.debugl('%d custom fieds collected' % len(self.custom_fields))
|
self.custom_fields[f.key] = f.name
|
||||||
|
self.debugl('%d custom fields collected' % len(self.custom_fields))
|
||||||
|
except vmodl.RuntimeFault as exc:
|
||||||
|
self.debugl("Unable to gather custom fields due to %s" % exc.msg)
|
||||||
|
|
||||||
return instance_tuples
|
return instance_tuples
|
||||||
|
|
||||||
def instances_to_inventory(self, instances):
|
def instances_to_inventory(self, instances):
|
||||||
|
|
|
@ -3,11 +3,17 @@ import os
|
||||||
import pickle
|
import pickle
|
||||||
import unittest
|
import unittest
|
||||||
import sys
|
import sys
|
||||||
|
from nose.plugins.skip import SkipTest
|
||||||
|
|
||||||
|
|
||||||
|
try:
|
||||||
|
from pyVmomi import vim, vmodl
|
||||||
|
except ImportError:
|
||||||
|
raise SkipTest("test_vmware_inventory.py requires the python module 'pyVmomi'")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from vmware_inventory import VMWareInventory
|
from vmware_inventory import VMWareInventory
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from nose.plugins.skip import SkipTest
|
|
||||||
raise SkipTest("test_vmware_inventory.py requires the python module 'vmware_inventory'")
|
raise SkipTest("test_vmware_inventory.py requires the python module 'vmware_inventory'")
|
||||||
|
|
||||||
# contrib's dirstruct doesn't contain __init__.py files
|
# contrib's dirstruct doesn't contain __init__.py files
|
||||||
|
|
Loading…
Add table
Reference in a new issue