Cleanup utilsfactory map

This change cleans up the utilsfactory map, making it easier to add
new classes.

Most classes have 6.2 as a minimum version, without having a maximum
version cap. For this reason, this change sets those versions as
defaults so that we don't have to be explicit every time.

At the same time, we're now using a list for each class type, instead
of a dict that uses the class name as a key (which is redundant). So,
something like this:

'networkutils': {
    'NetworkUtils': {
        'min_version': 6.2,
        'max_version': 6.3,
        'path': 'os_win.utils.network.networkutils.NetworkUtils'},
    'NetworkUtilsR2': {
        'min_version': 6.3,
        'max_version': None,
        'path': 'os_win.utils.network.networkutils.NetworkUtilsR2'}},

... becomes

'networkutils': [
    {'max_version': 6.3,
     'path': 'os_win.utils.network.networkutils.NetworkUtils'},
    {'min_version': 6.3,
     'path': 'os_win.utils.network.networkutils.NetworkUtilsR2'},
],

Change-Id: I7919617166b2e872f1b50c0a0f40196fc90e9a82
This commit is contained in:
Lucian Petrut 2019-01-14 15:10:43 +02:00
parent d139d77167
commit 0857a0eb81
2 changed files with 85 additions and 131 deletions

View File

@ -154,14 +154,13 @@ class TestHyperVUtilsFactory(test_base.OsWinBaseTestCase):
def test_utils_public_signatures(self): def test_utils_public_signatures(self):
for module_name in utilsfactory.utils_map.keys(): for module_name in utilsfactory.utils_map.keys():
classes = utilsfactory.utils_map[module_name] classes = utilsfactory.utils_map[module_name]
class_names = list(classes.keys()) if len(classes) < 2:
if len(class_names) < 2:
continue continue
base_class_dict = classes[class_names[0]] base_class_dict = classes[0]
base_class = importutils.import_object(base_class_dict['path']) base_class = importutils.import_object(base_class_dict['path'])
for i in range(1, len(class_names)): for i in range(1, len(classes)):
tested_class_dict = classes[class_names[i]] tested_class_dict = classes[i]
tested_class = importutils.import_object( tested_class = importutils.import_object(
tested_class_dict['path']) tested_class_dict['path'])
self.assertPublicAPISignatures(base_class, tested_class) self.assertPublicAPISignatures(base_class, tested_class)

View File

@ -22,125 +22,80 @@ from os_win.utils.io import namedpipe
utils = hostutils.HostUtils() utils = hostutils.HostUtils()
DEFAULT_MIN_VERSION = 6.2
DEFAULT_MAX_VERSION = None
utils_map = { utils_map = {
'diskutils': { 'diskutils': [
'DiskUtils': { {'path': 'os_win.utils.storage.diskutils.DiskUtils'}
'min_version': 6.2, ],
'max_version': None, 'hostutils': [
'path': 'os_win.utils.storage.diskutils.DiskUtils'}}, {'max_version': 10,
'hostutils': {
'HostUtils': {
'min_version': 6.2,
'max_version': 10,
'path': 'os_win.utils.hostutils.HostUtils'}, 'path': 'os_win.utils.hostutils.HostUtils'},
'HostUtils10': { {'min_version': 10,
'min_version': 10, 'path': 'os_win.utils.hostutils10.HostUtils10'},
'max_version': None, ],
'path': 'os_win.utils.hostutils10.HostUtils10'}}, 'iscsi_initiator_utils': [
'iscsi_initiator_utils': { {'path': 'os_win.utils.storage.initiator.iscsi_utils.'
'ISCSIInitiatorUtils': { 'ISCSIInitiatorUtils'},
'min_version': 6.2, ],
'max_version': None, 'iscsi_target_utils': [
'path': 'os_win.utils.storage.initiator.iscsi_utils.' {'path': 'os_win.utils.storage.target.iscsi_target_utils.'
'ISCSIInitiatorUtils'}}, 'ISCSITargetUtils'}],
'iscsi_target_utils': { 'fc_utils': [
'ISCSITargetUtils': { {'path': 'os_win.utils.storage.initiator.fc_utils.FCUtils'},
'min_version': 6.2, ],
'max_version': None, 'livemigrationutils': [
'path': 'os_win.utils.storage.target.iscsi_target_utils.' {'path': 'os_win.utils.compute.livemigrationutils.LiveMigrationUtils'}
'ISCSITargetUtils'}}, ],
'fc_utils': { 'metricsutils': [
'FCUtils': { {'path': 'os_win.utils.metrics.metricsutils.MetricsUtils'},
'min_version': 6.2, ],
'max_version': None, 'migrationutils': [
'path': 'os_win.utils.storage.initiator.fc_utils.' {'path': 'os_win.utils.compute.migrationutils.MigrationUtils'},
'FCUtils'}}, ],
'livemigrationutils': { 'networkutils': [
'LiveMigrationUtils': { {'max_version': 6.3,
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.compute.livemigrationutils.'
'LiveMigrationUtils'}},
'metricsutils': {
'MetricsUtils': {
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.metrics.metricsutils.MetricsUtils'}},
'migrationutils': {
'MigrationUtils': {
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.compute.migrationutils.MigrationUtils'}},
'networkutils': {
'NetworkUtils': {
'min_version': 6.2,
'max_version': 6.3,
'path': 'os_win.utils.network.networkutils.NetworkUtils'}, 'path': 'os_win.utils.network.networkutils.NetworkUtils'},
'NetworkUtilsR2': { {'min_version': 6.3,
'min_version': 6.3, 'path': 'os_win.utils.network.networkutils.NetworkUtilsR2'},
'max_version': None, ],
'path': 'os_win.utils.network.networkutils.NetworkUtilsR2'}}, 'nvgreutils': [
'nvgreutils': { {'path': 'os_win.utils.network.nvgreutils.NvgreUtils'},
'NvgreUtils': { ],
'min_version': 6.2, 'pathutils': [
'max_version': None, {'path': 'os_win.utils.pathutils.PathUtils'},
'path': 'os_win.utils.network.nvgreutils.NvgreUtils'}}, ],
'pathutils': { 'rdpconsoleutils': [
'PathUtils': { {'path': 'os_win.utils.compute.rdpconsoleutils.RDPConsoleUtils'},
'min_version': 6.2, ],
'max_version': None, 'smbutils': [
'path': 'os_win.utils.pathutils.PathUtils'}}, {'path': 'os_win.utils.storage.smbutils.SMBUtils'},
'rdpconsoleutils': { ],
'RDPConsoleUtils': { 'vhdutils': [
'min_version': 6.2, {'path': 'os_win.utils.storage.virtdisk.vhdutils.VHDUtils'},
'max_version': None, ],
'path': 'os_win.utils.compute.rdpconsoleutils.RDPConsoleUtils'}}, 'vmutils': [
'smbutils': { {'max_version': 6.3,
'SMBUtils': {
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.storage.smbutils.SMBUtils'}},
'vhdutils': {
'VHDUtils': {
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.storage.virtdisk.vhdutils.VHDUtils'}},
'vmutils': {
'VMUtils': {
'min_version': 6.2,
'max_version': 6.3,
'path': 'os_win.utils.compute.vmutils.VMUtils'}, 'path': 'os_win.utils.compute.vmutils.VMUtils'},
'VMUtils6_3': { {'min_version': 6.3,
'min_version': 6.3,
'max_version': 10, 'max_version': 10,
'path': 'os_win.utils.compute.vmutils.VMUtils6_3'}, 'path': 'os_win.utils.compute.vmutils.VMUtils6_3'},
'VMUtils10': { {'min_version': 10,
'min_version': 10, 'path': 'os_win.utils.compute.vmutils10.VMUtils10'}],
'max_version': None, 'clusterutils': [
'path': 'os_win.utils.compute.vmutils10.VMUtils10'}}, {'path': 'os_win.utils.compute.clusterutils.ClusterUtils'},
'clusterutils': { ],
'ClusterUtils': { 'dnsutils': [
'min_version': 6.2, {'path': 'os_win.utils.dns.dnsutils.DNSUtils'},
'max_version': None, ],
'path': 'os_win.utils.compute.clusterutils.ClusterUtils'}}, 'processutils': [
'dnsutils': { {'path': 'os_win.utils.processutils.ProcessUtils'},
'DNSUtils': { ],
'min_version': 6.2, 'ioutils': [
'max_version': None, {'path': 'os_win.utils.io.ioutils.IOUtils'},
'path': 'os_win.utils.dns.dnsutils.DNSUtils'}}, ],
'processutils': {
'ProcessUtils': {
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.processutils.ProcessUtils'},
},
'ioutils': {
'IOUtils': {
'min_version': 6.2,
'max_version': None,
'path': 'os_win.utils.io.ioutils.IOUtils'
}
}
} }
@ -153,14 +108,14 @@ def _get_class(class_type, *args, **kwargs):
build = list(map(int, windows_version.split('.'))) build = list(map(int, windows_version.split('.')))
windows_version = float("%i.%i" % (build[0], build[1])) windows_version = float("%i.%i" % (build[0], build[1]))
existing_classes = utils_map.get(class_type) existing_classes = utils_map.get(class_type, [])
for class_variant in existing_classes.keys(): for class_variant in existing_classes:
utils_class = existing_classes.get(class_variant) min_version = class_variant.get('min_version', DEFAULT_MIN_VERSION)
if (utils_class['min_version'] <= windows_version and max_version = class_variant.get('max_version', DEFAULT_MAX_VERSION)
(utils_class['max_version'] is None or class_path = class_variant['path']
windows_version < utils_class['max_version'])): if (min_version <= windows_version and
return importutils.import_object(utils_class['path'], (max_version is None or windows_version < max_version)):
*args, **kwargs) return importutils.import_object(class_path, *args, **kwargs)
raise exceptions.HyperVException(_('Could not find any %(class)s class for' raise exceptions.HyperVException(_('Could not find any %(class)s class for'
'this Windows version: %(win_version)s') 'this Windows version: %(win_version)s')