libvirt-cim-bounces(a)redhat.com wrote on 2008-12-24 14:21:55:
yunguol(a)cn.ibm.com wrote:
> # HG changeset patch
> # User Guolian Yun <yunguol(a)cn.ibm.com>
> # Date 1230088019 28800
> # Node ID 4337528f363855cc8945a9a60417ab0b83634ff8
> # Parent b7d80fdeb2a3318749f0faa4b2ad9725da97cc56
> [TEST] #4 Add new test to verify enum of DiskRASD to have
EmulatedType=0 for Disk and EmulatedType=1 for CDROM
>
> This tc only works with KVM now, follow patch to support the other
types
>
> Signed-off-by: Guolian Yun <yunguol(a)cn.ibm.com>
>
> diff -r b7d80fdeb2a3 -r 4337528f3638 suites/libvirt-
cim/cimtest/RASD/05_disk_rasd_emu_type.py
> --- /dev/null Thu Jan 01 00:00:00 1970 +0000
> +++ b/suites/libvirt-cim/cimtest/RASD/05_disk_rasd_emu_type.py
Tue Dec 23 19:06:59 2008 -0800
> @@ -0,0 +1,98 @@
> +#!/usr/bin/python
> +#
> +# Copyright 2008 IBM Corp.
> +#
> +# Authors:
> +# Guolian Yun <yunguol(a)cn.ibm.com>
> +#
> +# This library is free software; you can redistribute it and/or
> +# modify it under the terms of the GNU General Public
> +# License as published by the Free Software Foundation; either
> +# version 2.1 of the License, or (at your option) any later version.
> +#
> +# This library is distributed in the hope that it will be useful,
> +# but WITHOUT ANY WARRANTY; without even the implied warranty of
> +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
> +# General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public
> +# License along with this library; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
USA
> +#
> +
> +import sys
> +import pywbem
> +from VirtLib import utils
> +from XenKvmLib import enumclass
> +from XenKvmLib.classes import get_typed_class
> +from XenKvmLib.test_doms import undefine_test_domain
> +from XenKvmLib.common_util import parse_instance_id
> +from XenKvmLib.const import do_main
> +from XenKvmLib import vxml
> +from CimTest.ReturnCodes import PASS, FAIL
> +from CimTest.Globals import logger, CIM_ERROR_ENUMERATE
> +from XenKvmLib.const import get_provider_version
> +
> +SUPPORTED_TYPES = ['KVM']
> +default_dom = 'test_domain'
> +libvirt_em_type_changeset = 737
> +
> +@do_main(SUPPORTED_TYPES)
> +def main():
> + status = FAIL
> + options = main.options
> + curr_cim_rev, changeset = get_provider_version(options.virt,
options.ip)
> + if curr_cim_rev < libvirt_em_type_changeset:
> + return SKIP
> +
> + emu_types = [0, 1]
> + for exp_emu_type in emu_types:
> + cxml = vxml.get_class(options.virt)(default_dom,
emu_type=exp_emu_type)
> + ret = cxml.cim_define(options.ip)
> + if not ret:
> + logger.error("Failed to call DefineSystem()")
> + return FAIL
> +
> + drasd= get_typed_class(options.virt,
'DiskResourceAllocationSettingData')
> + try:
> + drasd_list = enumclass.EnumInstances(options.ip,
drasd, ret_cim_inst=True)
> + if len(drasd_list) < 1:
> + logger.error("%s returned %i instances, excepted
at least 1.",
> + drasd, len(drasd_list))
> + cxml.undefine(options.ip)
> + return FAIL
> + except Exception, detail:
> + logger.error(CIM_ERROR_ENUMERATE, drasd)
> + logger.error("Exception: %s", detail)
> + cxml.undefine(options.ip)
> + return FAIL
> +
> + found_rasd = None
> + for rasd in drasd_list:
> + guest, dev, status =
parse_instance_id(rasd['InstanceID'])
> + if status != PASS:
> + logger.error("Unable to parse InstanceID: %s" %
rasd['InstanceID'])
> + cxml.undefine(options.ip)
> + return FAIL
> + if guest == default_dom:
> + if rasd['EmulatedType'] == exp_emu_type:
> + found_rasd = rasd
> + status = PASS
> + break
> + else:
> + logger.error("EmulatedType Mismatch: got %d,
expected %d",\
> + rasd['EmulatedType'], exp_emu_type)
> + cxml.undefine(options.ip)
> + return FAIL
> +
> + if found_rasd == None:
> + logger.error("The defined dom is not found")
> + cxml.undefine(options.ip)
> + return FAIL
>
You can reduce the call to undefine(), if you can move the except block
above after the if found_rasd == None check here and use the raise
statement to reach the expect block.
Good catch. A new patch on the way.
Thanks!
otherwise +1 for me.
> +
> + cxml.undefine(options.ip)
> +
> + return status
> +
> +if __name__ == "__main__":
> + sys.exit(main())
> diff -r b7d80fdeb2a3 -r 4337528f3638 suites/libvirt-
cim/lib/XenKvmLib/vsms.py
> --- a/suites/libvirt-cim/lib/XenKvmLib/vsms.py Mon Dec 22 23:03:
01 2008 -0800
> +++ b/suites/libvirt-cim/lib/XenKvmLib/vsms.py Tue Dec 23 19:06:
59 2008 -0800
> @@ -126,8 +126,10 @@
>
> # classes to define RASD parameters
> class CIM_DiskResourceAllocationSettingData(CIMClassMOF):
> - def __init__(self, dev, source, name):
> + def __init__(self, dev, source, name, emu_type=None):
> self.ResourceType = RASD_TYPE_DISK
> + if emu_type != None:
> + self.EmulatedType = emu_type
> if dev != None:
> self.VirtualDevice = dev
> self.InstanceID = '%s/%s' % (name, dev)
> @@ -141,10 +143,12 @@
> pass
>
> class LXC_DiskResourceAllocationSettingData(CIMClassMOF):
> - def __init__(self, mountpoint, source, name):
> + def __init__(self, mountpoint, source, name, emu_type=None):
> self.MountPoint = mountpoint
> self.Address = source
> self.InstanceID = '%s/%s' % (name, mountpoint)
> + if emu_type != None:
> + self.EmulatedType = emu_type
>
> @eval_cls('DiskResourceAllocationSettingData')
> def get_dasd_class(virt):
> @@ -239,6 +243,7 @@
> proc_vcpu=1,
> mem_mb=512,
> malloc_units="MegaBytes",
> + emu_type=None,
> virt='Xen'):
> vssd = get_vssd_mof(virt, dom_name)
>
> @@ -252,7 +257,7 @@
> elif virt == 'LXC':
> disk_dev = const.LXC_default_mp
> disk_source = const.LXC_default_source
> - d = class_dasd(disk_dev, disk_source, dom_name)
> + d = class_dasd(disk_dev, disk_source, dom_name, emu_type)
>
> class_masd = get_masd_class(virt)
> m = class_masd(
> diff -r b7d80fdeb2a3 -r 4337528f3638 suites/libvirt-
cim/lib/XenKvmLib/vxml.py
> --- a/suites/libvirt-cim/lib/XenKvmLib/vxml.py Mon Dec 22 23:03:
01 2008 -0800
> +++ b/suites/libvirt-cim/lib/XenKvmLib/vxml.py Tue Dec 23 19:06:
59 2008 -0800
> @@ -466,11 +466,13 @@
>
> class VirtCIM:
> def __init__(self, virt, dom_name, disk_dev, disk_source,
> - net_type, net_name, net_mac, vcpus, mem,
mem_allocunits):
> + net_type, net_name, net_mac, vcpus, mem,
> + mem_allocunits, emu_type=None):
> self.virt = virt
> self.domain_name = dom_name
> self.vssd = vsms.get_vssd_mof(virt, dom_name)
> - self.dasd = vsms.get_dasd_class(virt)(disk_dev,
disk_source, dom_name)
> + self.dasd = vsms.get_dasd_class(virt)(disk_dev, disk_source,
> + dom_name, emu_type)
> self.nasd = vsms.get_nasd_class(virt)(type=net_type,
> mac=net_mac,
> name=dom_name,
> @@ -695,13 +697,15 @@
> disk_file_path=const.KVM_disk_path,
> disk=const.KVM_default_disk_dev,
> ntype=const.default_net_type,
> - net_name=const.default_network_name):
> + net_name=const.default_network_name,
> + emu_type=None):
> if not os.path.exists(disk_file_path):
> logger.error('Error: Disk image does not exist')
> sys.exit(1)
> VirtXML.__init__(self, 'kvm', test_dom, set_uuid(), mem,
vcpus)
> VirtCIM.__init__(self, 'KVM', test_dom, disk,
disk_file_path,
> - ntype, net_name, mac, vcpus, mem,
mem_allocunits)
> + ntype, net_name, mac, vcpus, mem,
mem_allocunits,
> + emu_type)
> self._os()
> self._devices(const.KVM_default_emulator, ntype,
> disk_file_path, disk, mac, net_name)
>
> _______________________________________________
> Libvirt-cim mailing list
> Libvirt-cim(a)redhat.com
>
https://www.redhat.com/mailman/listinfo/libvirt-cim
>
_______________________________________________
Libvirt-cim mailing list
Libvirt-cim(a)redhat.com
https://www.redhat.com/mailman/listinfo/libvirt-cim