iotests: test bitmap moving inside 254
Test persistent bitmap copying with and without removal of original bitmap. Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Signed-off-by: John Snow <jsnow@redhat.com> Reviewed-by: Max Reitz <mreitz@redhat.com> Message-id: 20190708220502.12977-4-jsnow@redhat.com [Edited comment "bitmap1" --> "bitmap2" as per review. --js] Signed-off-by: John Snow <jsnow@redhat.com>
This commit is contained in:
parent
c4e4b0fa59
commit
3f7b2fa8cd
@ -1,6 +1,6 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
#
|
#
|
||||||
# Test external snapshot with bitmap copying.
|
# Test external snapshot with bitmap copying and moving.
|
||||||
#
|
#
|
||||||
# Copyright (c) 2019 Virtuozzo International GmbH. All rights reserved.
|
# Copyright (c) 2019 Virtuozzo International GmbH. All rights reserved.
|
||||||
#
|
#
|
||||||
@ -32,6 +32,10 @@ vm = iotests.VM().add_drive(disk, opts='node-name=base')
|
|||||||
vm.launch()
|
vm.launch()
|
||||||
|
|
||||||
vm.qmp_log('block-dirty-bitmap-add', node='drive0', name='bitmap0')
|
vm.qmp_log('block-dirty-bitmap-add', node='drive0', name='bitmap0')
|
||||||
|
vm.qmp_log('block-dirty-bitmap-add', node='drive0', name='bitmap1',
|
||||||
|
persistent=True)
|
||||||
|
vm.qmp_log('block-dirty-bitmap-add', node='drive0', name='bitmap2',
|
||||||
|
persistent=True)
|
||||||
|
|
||||||
vm.hmp_qemu_io('drive0', 'write 0 512K')
|
vm.hmp_qemu_io('drive0', 'write 0 512K')
|
||||||
|
|
||||||
@ -39,16 +43,38 @@ vm.qmp_log('transaction', indent=2, actions=[
|
|||||||
{'type': 'blockdev-snapshot-sync',
|
{'type': 'blockdev-snapshot-sync',
|
||||||
'data': {'device': 'drive0', 'snapshot-file': top,
|
'data': {'device': 'drive0', 'snapshot-file': top,
|
||||||
'snapshot-node-name': 'snap'}},
|
'snapshot-node-name': 'snap'}},
|
||||||
|
|
||||||
|
# copy non-persistent bitmap0
|
||||||
{'type': 'block-dirty-bitmap-add',
|
{'type': 'block-dirty-bitmap-add',
|
||||||
'data': {'node': 'snap', 'name': 'bitmap0'}},
|
'data': {'node': 'snap', 'name': 'bitmap0'}},
|
||||||
{'type': 'block-dirty-bitmap-merge',
|
{'type': 'block-dirty-bitmap-merge',
|
||||||
'data': {'node': 'snap', 'target': 'bitmap0',
|
'data': {'node': 'snap', 'target': 'bitmap0',
|
||||||
'bitmaps': [{'node': 'base', 'name': 'bitmap0'}]}}
|
'bitmaps': [{'node': 'base', 'name': 'bitmap0'}]}},
|
||||||
|
|
||||||
|
# copy persistent bitmap1, original will be saved to base image
|
||||||
|
{'type': 'block-dirty-bitmap-add',
|
||||||
|
'data': {'node': 'snap', 'name': 'bitmap1', 'persistent': True}},
|
||||||
|
{'type': 'block-dirty-bitmap-merge',
|
||||||
|
'data': {'node': 'snap', 'target': 'bitmap1',
|
||||||
|
'bitmaps': [{'node': 'base', 'name': 'bitmap1'}]}},
|
||||||
|
|
||||||
|
# move persistent bitmap2, original will be removed and not saved
|
||||||
|
# to base image
|
||||||
|
{'type': 'block-dirty-bitmap-add',
|
||||||
|
'data': {'node': 'snap', 'name': 'bitmap2', 'persistent': True}},
|
||||||
|
{'type': 'block-dirty-bitmap-merge',
|
||||||
|
'data': {'node': 'snap', 'target': 'bitmap2',
|
||||||
|
'bitmaps': [{'node': 'base', 'name': 'bitmap2'}]}},
|
||||||
|
{'type': 'block-dirty-bitmap-remove',
|
||||||
|
'data': {'node': 'base', 'name': 'bitmap2'}}
|
||||||
], filters=[iotests.filter_qmp_testfiles])
|
], filters=[iotests.filter_qmp_testfiles])
|
||||||
|
|
||||||
result = vm.qmp('query-block')['return'][0]
|
result = vm.qmp('query-block')['return'][0]
|
||||||
log("query-block: device = {}, node-name = {}, dirty-bitmaps:".format(
|
log("query-block: device = {}, node-name = {}, dirty-bitmaps:".format(
|
||||||
result['device'], result['inserted']['node-name']))
|
result['device'], result['inserted']['node-name']))
|
||||||
log(result['dirty-bitmaps'], indent=2)
|
log(result['dirty-bitmaps'], indent=2)
|
||||||
|
log("\nbitmaps in backing image:")
|
||||||
|
log(result['inserted']['image']['backing-image']['format-specific'] \
|
||||||
|
['data']['bitmaps'], indent=2)
|
||||||
|
|
||||||
vm.shutdown()
|
vm.shutdown()
|
||||||
|
@ -1,5 +1,9 @@
|
|||||||
{"execute": "block-dirty-bitmap-add", "arguments": {"name": "bitmap0", "node": "drive0"}}
|
{"execute": "block-dirty-bitmap-add", "arguments": {"name": "bitmap0", "node": "drive0"}}
|
||||||
{"return": {}}
|
{"return": {}}
|
||||||
|
{"execute": "block-dirty-bitmap-add", "arguments": {"name": "bitmap1", "node": "drive0", "persistent": true}}
|
||||||
|
{"return": {}}
|
||||||
|
{"execute": "block-dirty-bitmap-add", "arguments": {"name": "bitmap2", "node": "drive0", "persistent": true}}
|
||||||
|
{"return": {}}
|
||||||
{
|
{
|
||||||
"execute": "transaction",
|
"execute": "transaction",
|
||||||
"arguments": {
|
"arguments": {
|
||||||
@ -31,6 +35,55 @@
|
|||||||
"target": "bitmap0"
|
"target": "bitmap0"
|
||||||
},
|
},
|
||||||
"type": "block-dirty-bitmap-merge"
|
"type": "block-dirty-bitmap-merge"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"data": {
|
||||||
|
"name": "bitmap1",
|
||||||
|
"node": "snap",
|
||||||
|
"persistent": true
|
||||||
|
},
|
||||||
|
"type": "block-dirty-bitmap-add"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"data": {
|
||||||
|
"bitmaps": [
|
||||||
|
{
|
||||||
|
"name": "bitmap1",
|
||||||
|
"node": "base"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"node": "snap",
|
||||||
|
"target": "bitmap1"
|
||||||
|
},
|
||||||
|
"type": "block-dirty-bitmap-merge"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"data": {
|
||||||
|
"name": "bitmap2",
|
||||||
|
"node": "snap",
|
||||||
|
"persistent": true
|
||||||
|
},
|
||||||
|
"type": "block-dirty-bitmap-add"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"data": {
|
||||||
|
"bitmaps": [
|
||||||
|
{
|
||||||
|
"name": "bitmap2",
|
||||||
|
"node": "base"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"node": "snap",
|
||||||
|
"target": "bitmap2"
|
||||||
|
},
|
||||||
|
"type": "block-dirty-bitmap-merge"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"data": {
|
||||||
|
"name": "bitmap2",
|
||||||
|
"node": "base"
|
||||||
|
},
|
||||||
|
"type": "block-dirty-bitmap-remove"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@ -40,6 +93,24 @@
|
|||||||
}
|
}
|
||||||
query-block: device = drive0, node-name = snap, dirty-bitmaps:
|
query-block: device = drive0, node-name = snap, dirty-bitmaps:
|
||||||
[
|
[
|
||||||
|
{
|
||||||
|
"busy": false,
|
||||||
|
"count": 524288,
|
||||||
|
"granularity": 65536,
|
||||||
|
"name": "bitmap2",
|
||||||
|
"persistent": true,
|
||||||
|
"recording": true,
|
||||||
|
"status": "active"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"busy": false,
|
||||||
|
"count": 524288,
|
||||||
|
"granularity": 65536,
|
||||||
|
"name": "bitmap1",
|
||||||
|
"persistent": true,
|
||||||
|
"recording": true,
|
||||||
|
"status": "active"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"busy": false,
|
"busy": false,
|
||||||
"count": 524288,
|
"count": 524288,
|
||||||
@ -50,3 +121,14 @@ query-block: device = drive0, node-name = snap, dirty-bitmaps:
|
|||||||
"status": "active"
|
"status": "active"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
||||||
|
bitmaps in backing image:
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"flags": [
|
||||||
|
"auto"
|
||||||
|
],
|
||||||
|
"granularity": 65536,
|
||||||
|
"name": "bitmap1"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
Loading…
Reference in New Issue
Block a user