From 37e435b3ee71ff08f1416cd411c13e76000f2a5a Mon Sep 17 00:00:00 2001 From: Aihua Liang Date: Fri, 29 Nov 2024 14:32:57 +0800 Subject: [PATCH 1/2] storage_volume:support add backing:null Support adding backing:null when creating a target node Signed-off-by: Aihua Liang --- provider/virt_storage/storage_volume.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/provider/virt_storage/storage_volume.py b/provider/virt_storage/storage_volume.py index 76ac6b07f6..d51402d38b 100644 --- a/provider/virt_storage/storage_volume.py +++ b/provider/virt_storage/storage_volume.py @@ -157,8 +157,11 @@ def refresh_format_by_params(self, params): backing = params.get("backing") if backing: - backing_node = "drive_%s" % backing - self.format.set_param("backing", backing_node) + if params.get("backing_null", "no") == "no": + backing_node = "drive_%s" % backing + self.format.set_param("backing", backing_node) + else: + self.format.params["backing"] = None data_file_name = params.get("image_data_file") if data_file_name: From 5b4d8681f92a153edc41d9e6da1165e94a7320ef Mon Sep 17 00:00:00 2001 From: Aihua Liang Date: Mon, 16 Dec 2024 14:49:14 +0800 Subject: [PATCH 2/2] blockdev_commit_cancel:add a new case New case:checking backing file status after canceling commit operations Signed-off-by: Aihua Liang --- qemu/tests/blockdev_commit_cancel.py | 73 +++++++++++++++++++++++ qemu/tests/cfg/blockdev_commit_cancel.cfg | 37 ++++++++++++ 2 files changed, 110 insertions(+) create mode 100644 qemu/tests/blockdev_commit_cancel.py create mode 100644 qemu/tests/cfg/blockdev_commit_cancel.cfg diff --git a/qemu/tests/blockdev_commit_cancel.py b/qemu/tests/blockdev_commit_cancel.py new file mode 100644 index 0000000000..1d0f447c2d --- /dev/null +++ b/qemu/tests/blockdev_commit_cancel.py @@ -0,0 +1,73 @@ +from avocado.utils import process + +from provider import backup_utils, job_utils +from provider.blockdev_commit_base import BlockDevCommitTest + + +class BlockDevCommitCancel(BlockDevCommitTest): + def generate_tempfile(self, root_dir, filename="data", size="1500M", timeout=360): + backup_utils.generate_tempfile(self.main_vm, root_dir, filename, size, timeout) + self.files_info.append([root_dir, filename]) + + def commit_snapshot(self): + device = self.params.get_list("device_tag")[0] + device_params = self.params.object_params(device) + snapshot_tags = device_params["snapshot_tags"].split() + self.device_node = self.get_node_name(device) + options = ["base-node", "top-node", "speed"] + arguments = self.params.copy_from_keys(options) + arguments["base-node"] = self.get_node_name(device) + arguments["top-node"] = self.get_node_name(snapshot_tags[-1]) + arguments["speed"] = self.params["speed"] + device = self.get_node_name(snapshot_tags[-1]) + commit_cmd = backup_utils.block_commit_qmp_cmd + cmd, args = commit_cmd(device, **arguments) + backup_utils.set_default_block_job_options(self.main_vm, args) + job_id = args.get("job-id", device) + self.main_vm.monitor.cmd(cmd, args) + if job_utils.is_block_job_running(self.main_vm, job_id): + self.main_vm.monitor.cmd("block-job-cancel", {"device": job_id}) + event = job_utils.get_event_by_condition( + self.main_vm, + "BLOCK_JOB_CANCELLED", + self.params.get_numeric("job_cancelled_timeout", 60), + device=job_id, + ) + if event is None: + self.test.fail("Commit job failed to cancel") + + def check_backing_rw(self): + base_image = self.get_image_by_tag(self.params["device_tag"]) + cmd = "lsof %s" % base_image.image_filename + if "nbd" in base_image.image_filename: + cmd = "lsof -i:%s" % self.params["nbd_port_%s" % self.params["device_tag"]] + elif "rbd" in base_image.image_filename: + cmd = "lsof -i:6800" + output = process.run(cmd, verbose=True).stdout_text.split("\n")[1].split() + pid, fd = (output[1], output[3][:-1]) + cmd = "cat /proc/%s/fdinfo/%s" % (pid, fd) + output = process.run(cmd, verbose=True).stdout_text.split("\n")[1].split()[1] + if output[-1] == "2": + self.test.fail("backing image in rw status, should be in ro satus") + + def run_test(self): + self.pre_test() + try: + self.commit_snapshot() + self.check_backing_rw() + finally: + self.post_test() + + +def run(test, params, env): + """ + Block commit base Test + + 1. boot guest with data disk + 2. create 4 snapshots and save file in each snapshot + 3. commit snapshot 3 to snapshot 4 + 4. verify files's md5 + """ + + block_test = BlockDevCommitCancel(test, params, env) + block_test.run_test() diff --git a/qemu/tests/cfg/blockdev_commit_cancel.cfg b/qemu/tests/cfg/blockdev_commit_cancel.cfg new file mode 100644 index 0000000000..8b5070c362 --- /dev/null +++ b/qemu/tests/cfg/blockdev_commit_cancel.cfg @@ -0,0 +1,37 @@ +- blockdev_commit_cancel: + type = blockdev_commit_cancel + virt_test_type = qemu + only Linux + images += " data" + force_create_image = yes + force_remove_image = yes + force_create_image_image1 = no + force_remove_image_image1 = no + start_vm = yes + kill_vm = yes + storage_pools = default + storage_type_default = "directory" + storage_pool = default + image_size_data = 2G + image_name_data = data + snapshot_tags = sn1 + + image_name_sn1 = sn1 + backing_sn1 = data + backing_null = yes + image_format_sn1 = qcow2 + + device_tag = "data" + format = qcow2 + speed = 10000000 + ceph: + image_format_data = raw + enable_ceph_sn1 = no + nbd: + image_format_data = raw + image_size_data = 2G + nbd_port_data = 10831 + enable_nbd_sn1 = no + force_create_image_data = no + remove_image_data = no + image_size_sn1 = ${image_size_data}