Bug 787906

Summary: [python binding] migrateGetMaxSpeed did not work right with parameters
Product: Red Hat Enterprise Linux 6 Reporter: Wayne Sun <gsun>
Component: libvirtAssignee: Gunannan Ren <gren>
Status: CLOSED ERRATA QA Contact: Virtualization Bugs <virt-bugs>
Severity: medium Docs Contact:
Priority: high    
Version: 6.3CC: acathrow, ajia, dallan, mzhan, rwu
Target Milestone: rc   
Target Release: ---   
Hardware: Unspecified   
OS: Unspecified   
Whiteboard:
Fixed In Version: libvirt-0.9.13-3.el6 Doc Type: Bug Fix
Doc Text:
Story Points: ---
Clone Of: Environment:
Last Closed: 2013-02-21 07:07:46 UTC Type: ---
Regression: --- Mount Type: ---
Documentation: --- CRM:
Verified Versions: Category: ---
oVirt Team: --- RHEL 7.3 requirements from Atomic Host:
Cloudforms Team: --- Target Upstream Version:
Embargoed:

Description Wayne Sun 2012-02-07 02:33:24 UTC
Description of problem:
migrateGetMaxSpeed() not working right:
# python
Python 2.6.6 (r266:84292, Sep 12 2011, 14:03:14)
[GCC 4.4.5 20110214 (Red Hat 4.4.5-6)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>>  import libvirt
>>>  conn = libvirt.open(None)
>>>  domobj = conn.lookupByName("winxp")
>>>  domobj.migrateGetMaxSpeed(0)
Traceback (most recent call last):
  File "<stdin>", line 1, in<module>
  File "/usr/lib64/python2.6/site-packages/libvirt.py", line 1531, in migrateGetMaxSpeed
    ret = libvirtmod.virDomainMigrateGetMaxSpeed(self._o, flags)
TypeError: virDomainMigrateGetMaxSpeed() takes exactly 1 argument (2 given)

^^
virDomainMigrateGetMaxSpeed() actually take 3 parameters:

virDomainMigrateGetMaxSpeed(virDomainPtr domain,
                            unsigned long *bandwidth,
                            unsigned int flags)


Version-Release number of selected component (if applicable):
libvirt-0.9.9-1.el6.x86_64

How reproducible:
always

Steps to Reproduce:
1. prepare a domain
2. set domain migrate max speed
# virsh migrate-setspeed $dom_name 2
3. check domain migrate max speed
# virsh migrate-getspeed $dom_name
2
4. check with python as in description 
  
Actual results:
Fail to work 

Expected results:
should work 

Additional info:
bandwidth parameter in virDomainMigrateGetMaxSpeed() is for accept the return value of current migration bandwidth limit in Mbps

Comment 1 Gunannan Ren 2012-02-09 04:58:49 UTC
ommit 4165d68aaabbf262fe4050ddcf1b68bff5a6b0c8
Author: Osier Yang <jyang>
Date:   Wed Feb 8 17:33:22 2012 +0800
    python: Correct arguments number for migrateSetMaxSpeed
    
    The API definition accepts "flags" argument, however, the
    implementation ignores it, though "flags" is unused currently,
    we should expose it instead of hard coding, the API
    implementation inside hypervisor driver is responsible to check
    if the passed "flags" is valid.

Comment 4 Wayne Sun 2012-07-24 10:34:25 UTC
pkgs:
libvirt-0.9.13-3.el6.x86_64
qemu-kvm-rhev-0.12.1.2-2.297.el6_3.x86_64
kernel-2.6.32-280.el6.x86_64

Prepare a domain
# virsh list --all
 Id    Name                           State
----------------------------------------------------
 -     aaa                            shut off


# python
Python 2.6.6 (r266:84292, May  1 2012, 13:52:17) 
[GCC 4.4.6 20110731 (Red Hat 4.4.6-3)] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import libvirt
>>> conn = libvirt.open(None)
>>> domobj = conn.lookupByName("aaa")
>>> domobj.migrateGetMaxSpeed(0)
32L

Setting speed in another terminal:
# virsh migrate-setspeed aaa 2

Switch back and check:
>>> domobj.migrateGetMaxSpeed(0)
2L

Works fine now.

Comment 5 errata-xmlrpc 2013-02-21 07:07:46 UTC
Since the problem described in this bug report should be
resolved in a recent advisory, it has been closed with a
resolution of ERRATA.

For information on the advisory, and where to find the updated
files, follow the link below.

If the solution does not work for you, open a new bug report.

http://rhn.redhat.com/errata/RHSA-2013-0276.html