storage config is motly copied from the config2command tests Signed-off-by: Dominik Csapak <d.csa...@proxmox.com> --- test/Makefile | 5 +- test/run_qemu_img_convert_tests.pl | 186 +++++++++++++++++++++++++++++ 2 files changed, 190 insertions(+), 1 deletion(-) create mode 100755 test/run_qemu_img_convert_tests.pl
diff --git a/test/Makefile b/test/Makefile index 902d9e3..d88cbd2 100644 --- a/test/Makefile +++ b/test/Makefile @@ -1,6 +1,6 @@ all: test -test: test_snapshot test_ovf test_cfg_to_cmd test_pci_addr_conflicts +test: test_snapshot test_ovf test_cfg_to_cmd test_pci_addr_conflicts test_qemu_img_convert test_snapshot: run_snapshot_tests.pl ./run_snapshot_tests.pl @@ -12,5 +12,8 @@ test_ovf: run_ovf_tests.pl test_cfg_to_cmd: run_config2command_tests.pl cfg2cmd/*.conf perl -I../ ./run_config2command_tests.pl +test_qemu_img_convert: run_qemu_img_convert_tests.pl + perl -I../ ./run_qemu_img_convert_tests.pl + test_pci_addr_conflicts: run_pci_addr_checks.pl ./run_pci_addr_checks.pl diff --git a/test/run_qemu_img_convert_tests.pl b/test/run_qemu_img_convert_tests.pl new file mode 100755 index 0000000..fafb58a --- /dev/null +++ b/test/run_qemu_img_convert_tests.pl @@ -0,0 +1,186 @@ +#!/usr/bin/env perl + +use strict; +use warnings; + +use lib qw(..); + +use Test::More; +use Test::MockModule; + +use PVE::QemuServer; + +my $vmid = 8006; +my $storage_config = { + ids => { + local => { + content => { + images => 1, + }, + path => "/var/lib/vz", + type => "dir", + shared => 0, + }, + "rbd-store" => { + monhost => "127.0.0.42,127.0.0.21,::1", + content => { + images => 1 + }, + type => "rbd", + pool => "cpool", + username => "admin", + shared => 1 + }, + "local-lvm" => { + vgname => "pve", + bwlimit => "restore=1024", + type => "lvmthin", + thinpool => "data", + content => { + images => 1, + } + }, + "zfs-over-iscsi" => { + type => "zfs", + iscsiprovider => "LIO", + lio_tpg => "tpg1", + portal => "127.0.0.1", + target => "iqn.2019-10.org.test:foobar", + pool => "tank", + } + } +}; + +my $tests = { + qcow2raw => [ + "local:$vmid/vm-$vmid-disk-0.qcow2", "local:$vmid/vm-$vmid-disk-0.raw", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "qcow2", "-O", "raw", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.qcow2", "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw" + ] + ], + raw2qcow2 => [ + "local:$vmid/vm-$vmid-disk-0.raw", "local:$vmid/vm-$vmid-disk-0.qcow2", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "-O", "qcow2", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.qcow2" + ] + ], + local2rbd => [ + "local:$vmid/vm-$vmid-disk-0.raw", "rbd-store:vm-$vmid-disk-0", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "-O", "raw", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", "rbd:cpool/vm-$vmid-disk-0:mon_host=127.0.0.42;127.0.0.21;[\\:\\:1]:auth_supported=none" + ] + ], + rbd2local => [ + "rbd-store:vm-$vmid-disk-0", "local:$vmid/vm-$vmid-disk-0.raw", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "-O", "raw", + "rbd:cpool/vm-$vmid-disk-0:mon_host=127.0.0.42;127.0.0.21;[\\:\\:1]:auth_supported=none", "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw" + ] + ], + local2zos => [ + "local:$vmid/vm-$vmid-disk-0.raw", "zfs-over-iscsi:vm-$vmid-disk-0", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "--target-image-opts", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", + "file.driver=iscsi,file.transport=tcp,file.initiator-name=foobar,file.portal=127.0.0.1,file.target=iqn.2019-10.org.test:foobar,file.lun=1,driver=raw" + ] + ], + zos2local => [ + "zfs-over-iscsi:vm-$vmid-disk-0", "local:$vmid/vm-$vmid-disk-0.raw", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "--image-opts", "-O", "raw", + "file.driver=iscsi,file.transport=tcp,file.initiator-name=foobar,file.portal=127.0.0.1,file.target=iqn.2019-10.org.test:foobar,file.lun=1,driver=raw", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", + ] + ], + zos2rbd => [ + "zfs-over-iscsi:vm-$vmid-disk-0", "rbd-store:vm-$vmid-disk-0", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "--image-opts", "-O", "raw", + "file.driver=iscsi,file.transport=tcp,file.initiator-name=foobar,file.portal=127.0.0.1,file.target=iqn.2019-10.org.test:foobar,file.lun=1,driver=raw", + "rbd:cpool/vm-$vmid-disk-0:mon_host=127.0.0.42;127.0.0.21;[\\:\\:1]:auth_supported=none" + ] + ], + rbd2zos => [ + "rbd-store:vm-$vmid-disk-0", "zfs-over-iscsi:vm-$vmid-disk-0", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "--target-image-opts", + "rbd:cpool/vm-$vmid-disk-0:mon_host=127.0.0.42;127.0.0.21;[\\:\\:1]:auth_supported=none", + "file.driver=iscsi,file.transport=tcp,file.initiator-name=foobar,file.portal=127.0.0.1,file.target=iqn.2019-10.org.test:foobar,file.lun=1,driver=raw", + ] + ], + local2lvmthin => [ + "local:$vmid/vm-$vmid-disk-0.raw", "local-lvm:vm-$vmid-disk-0", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "-O", "raw", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", + "/dev/pve/vm-$vmid-disk-0", + ] + ], + lvmthin2local => [ + "local-lvm:vm-$vmid-disk-0", "local:$vmid/vm-$vmid-disk-0.raw", 1024*10, undef, 0, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "-O", "raw", + "/dev/pve/vm-$vmid-disk-0", + "/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", + ] + ], + zeroinit => [ + "local-lvm:vm-$vmid-disk-0", "local:$vmid/vm-$vmid-disk-0.raw", 1024*10, undef, 1, [ + "/usr/bin/qemu-img", "convert", "-p", "-n", "-f", "raw", "-O", "raw", + "/dev/pve/vm-$vmid-disk-0", + "zeroinit:/var/lib/vz/images/$vmid/vm-$vmid-disk-0.raw", + ] + ], + notexistingstorage => [ + "local-lvm:vm-$vmid-disk-0", "not-existing:$vmid/vm-$vmid-disk-0.raw", 1024*10, undef, 1, + "storage 'not-existing' does not exists\n", + ], +}; + +my $command; + +my $storage_module = Test::MockModule->new("PVE::Storage"); +$storage_module->mock( + config => sub { + return $storage_config; + }, + activate_volumes => sub { + return 1; + } +); + +my $lio_module = Test::MockModule->new("PVE::Storage::LunCmd::LIO"); +$lio_module->mock( + run_lun_command => sub { + return 1; + } +); + +# we use the exported run_command so we have to mock it there +my $zfsplugin_module = Test::MockModule->new("PVE::Storage::ZFSPlugin"); +$zfsplugin_module->mock( + run_command => sub { + return 1; + } +); + +# we use the exported run_command so we have to mock it there +my $qemu_server_module = Test::MockModule->new("PVE::QemuServer"); +$qemu_server_module->mock( + run_command => sub { + $command = shift; + }, + get_initiator_name => sub { + return "foobar"; + } +); + +foreach my $name (sort keys %$tests) { + my $res = $tests->{$name}->[-1]; # last element + eval { PVE::QemuServer::qemu_img_convert(@{$tests->{$name}}) }; + if (my $err = $@) { + is ($err, $res, $name); + } elsif (defined($command)) { + is_deeply($command, $res, $name); + $command = undef; + } else { + fail($name); + note("no command") + } +} + +done_testing(); -- 2.20.1 _______________________________________________ pve-devel mailing list pve-devel@pve.proxmox.com https://pve.proxmox.com/cgi-bin/mailman/listinfo/pve-devel