iotests/236: fix transaction kwarg order
It's not enough to order the kwargs for consistent QMP log output, we must also sort any sub-dictionaries in lists that appear as values. Reported-by: Kevin Wolf <kwolf@redhat.com> Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
fff2388d5d
commit
039be85c41
@ -45,23 +45,23 @@ write -P0xcd 0x3ff0000 64k
|
||||
"actions": [
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapB"
|
||||
"name": "bitmapB",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-disable"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"granularity": 65536,
|
||||
"name": "bitmapC",
|
||||
"granularity": 65536
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-add"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapA"
|
||||
"name": "bitmapA",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-clear"
|
||||
},
|
||||
@ -105,30 +105,30 @@ write -P0xcd 0x3ff0000 64k
|
||||
"actions": [
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapB"
|
||||
"name": "bitmapB",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-disable"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"granularity": 65536,
|
||||
"name": "bitmapC",
|
||||
"granularity": 65536
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-add"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapC"
|
||||
"name": "bitmapC",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-disable"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapC"
|
||||
"name": "bitmapC",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-enable"
|
||||
}
|
||||
@ -158,15 +158,15 @@ write -P0xea 0x3fe0000 64k
|
||||
"actions": [
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapA"
|
||||
"name": "bitmapA",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-disable"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"name": "bitmapC"
|
||||
"name": "bitmapC",
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-disable"
|
||||
}
|
||||
@ -209,21 +209,21 @@ write -P0xea 0x3fe0000 64k
|
||||
"actions": [
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"disabled": true,
|
||||
"granularity": 65536,
|
||||
"name": "bitmapD",
|
||||
"granularity": 65536
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-add"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"target": "bitmapD",
|
||||
"bitmaps": [
|
||||
"bitmapB",
|
||||
"bitmapC"
|
||||
]
|
||||
],
|
||||
"node": "drive0",
|
||||
"target": "bitmapD"
|
||||
},
|
||||
"type": "block-dirty-bitmap-merge"
|
||||
},
|
||||
@ -273,21 +273,21 @@ write -P0xea 0x3fe0000 64k
|
||||
"actions": [
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"disabled": true,
|
||||
"granularity": 65536,
|
||||
"name": "bitmapD",
|
||||
"granularity": 65536
|
||||
"node": "drive0"
|
||||
},
|
||||
"type": "block-dirty-bitmap-add"
|
||||
},
|
||||
{
|
||||
"data": {
|
||||
"node": "drive0",
|
||||
"target": "bitmapD",
|
||||
"bitmaps": [
|
||||
"bitmapB",
|
||||
"bitmapC"
|
||||
]
|
||||
],
|
||||
"node": "drive0",
|
||||
"target": "bitmapD"
|
||||
},
|
||||
"type": "block-dirty-bitmap-merge"
|
||||
}
|
||||
|
@ -76,15 +76,16 @@ def qemu_img(*args):
|
||||
sys.stderr.write('qemu-img received signal %i: %s\n' % (-exitcode, ' '.join(qemu_img_args + list(args))))
|
||||
return exitcode
|
||||
|
||||
def ordered_kwargs(kwargs):
|
||||
# kwargs prior to 3.6 are not ordered, so:
|
||||
def ordered_qmp(qmsg):
|
||||
# Dictionaries are not ordered prior to 3.6, therefore:
|
||||
if isinstance(qmsg, list):
|
||||
return [ordered_qmp(atom) for atom in qmsg]
|
||||
if isinstance(qmsg, dict):
|
||||
od = OrderedDict()
|
||||
for k, v in sorted(kwargs.items()):
|
||||
if isinstance(v, dict):
|
||||
od[k] = ordered_kwargs(v)
|
||||
else:
|
||||
od[k] = v
|
||||
for k, v in sorted(qmsg.items()):
|
||||
od[k] = ordered_qmp(v)
|
||||
return od
|
||||
return qmsg
|
||||
|
||||
def qemu_img_create(*args):
|
||||
args = list(args)
|
||||
@ -506,7 +507,7 @@ class VM(qtest.QEMUQtestMachine):
|
||||
def qmp_log(self, cmd, filters=[], indent=None, **kwargs):
|
||||
full_cmd = OrderedDict((
|
||||
("execute", cmd),
|
||||
("arguments", ordered_kwargs(kwargs))
|
||||
("arguments", ordered_qmp(kwargs))
|
||||
))
|
||||
log(full_cmd, filters, indent=indent)
|
||||
result = self.qmp(cmd, **kwargs)
|
||||
|
Loading…
Reference in New Issue
Block a user