]> git.proxmox.com Git - qemu-server.git/commitdiff
move helper to check running QEMU version out of the 'Machine' module
authorFiona Ebner <f.ebner@proxmox.com>
Thu, 4 Jul 2024 09:32:12 +0000 (11:32 +0200)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Tue, 30 Jul 2024 19:19:51 +0000 (21:19 +0200)
The version of the running QEMU binary is not related to the machine
version and so it's a bit confusing to have the helper in the
'Machine' module. It cannot live in the 'Helpers' module, because that
would lead to a cyclic inclusion Helpers <-> Monitor. Thus,
'QMPHelpers' is chosen as the new home.

Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
PVE/QemuMigrate.pm
PVE/QemuServer/Machine.pm
PVE/QemuServer/QMPHelpers.pm
test/MigrationTest/QemuMigrateMock.pm
test/run_config2command_tests.pl

index 34fc46eeebf6469e3c08f422402f7d513c0017c5..e71face453ec36f5a80d2583f35b90a7fbd9bbbd 100644 (file)
@@ -30,6 +30,7 @@ use PVE::QemuServer::Helpers qw(min_version);
 use PVE::QemuServer::Machine;
 use PVE::QemuServer::Monitor qw(mon_cmd);
 use PVE::QemuServer::Memory qw(get_current_memory);
+use PVE::QemuServer::QMPHelpers;
 use PVE::QemuServer;
 
 use PVE::AbstractMigrate;
@@ -1140,7 +1141,7 @@ sub phase2 {
            PVE::QemuServer::qemu_drive_mirror($vmid, $drive, $nbd_uri, $vmid, undef, $self->{storage_migration_jobs}, 'skip', undef, $bwlimit, $bitmap);
        }
 
-       if (PVE::QemuServer::Machine::runs_at_least_qemu_version($vmid, 8, 2)) {
+       if (PVE::QemuServer::QMPHelpers::runs_at_least_qemu_version($vmid, 8, 2)) {
            $self->log('info', "switching mirror jobs to actively synced mode");
            PVE::QemuServer::qemu_drive_mirror_switch_to_active_mode(
                $vmid,
index cc92e7e6771d2e8dc237cbbc36a465dac3b82bc1..a3917dae6cd79d4bd76f04dbd036da5834a98c17 100644 (file)
@@ -161,18 +161,6 @@ sub can_run_pve_machine_version {
     return 0;
 }
 
-# dies if a) VM not running or not exisiting b) Version query failed
-# So, any defined return value is valid, any invalid state can be caught by eval
-sub runs_at_least_qemu_version {
-    my ($vmid, $major, $minor, $extra) = @_;
-
-    my $v = PVE::QemuServer::Monitor::mon_cmd($vmid, 'query-version');
-    die "could not query currently running version for VM $vmid\n" if !defined($v);
-    $v = $v->{qemu};
-
-    return PVE::QemuServer::Helpers::version_cmp($v->{major}, $major, $v->{minor}, $minor, $v->{micro}, $extra) >= 0;
-}
-
 sub qemu_machine_pxe {
     my ($vmid, $conf) = @_;
 
index d3a52327682fff71dd59b6722346f3a4339cbf75..0269ea46a94cc93cc87bb382d947c750e366267d 100644 (file)
@@ -3,6 +3,7 @@ package PVE::QemuServer::QMPHelpers;
 use warnings;
 use strict;
 
+use PVE::QemuServer::Helpers;
 use PVE::QemuServer::Monitor qw(mon_cmd);
 
 use base 'Exporter';
@@ -45,4 +46,16 @@ sub qemu_objectdel {
     return 1;
 }
 
+# dies if a) VM not running or not exisiting b) Version query failed
+# So, any defined return value is valid, any invalid state can be caught by eval
+sub runs_at_least_qemu_version {
+    my ($vmid, $major, $minor, $extra) = @_;
+
+    my $v = PVE::QemuServer::Monitor::mon_cmd($vmid, 'query-version');
+    die "could not query currently running version for VM $vmid\n" if !defined($v);
+    $v = $v->{qemu};
+
+    return PVE::QemuServer::Helpers::version_cmp($v->{major}, $major, $v->{minor}, $minor, $v->{micro}, $extra) >= 0;
+}
+
 1;
index f5b44424d22a57756a69fbfa09747bb394176f25..11c58c08bc0ec845c7e4c7e3a85d135c710bb5d8 100644 (file)
@@ -188,6 +188,10 @@ $qemu_server_machine_module->mock(
            if !defined($vm_status->{runningmachine});
        return $vm_status->{runningmachine};
     },
+);
+
+my $qemu_server_qmphelpers_module = Test::MockModule->new("PVE::QemuServer::QMPHelpers");
+$qemu_server_qmphelpers_module->mock(
     runs_at_least_qemu_version => sub {
        return 1;
     },
index 7212acc44bd701d22bacdd64c6da72f14f0546f4..d48ef562e502b90b8d7a64963acb0944544cfcf5 100755 (executable)
@@ -16,7 +16,7 @@ use PVE::SysFSTools;
 use PVE::QemuConfig;
 use PVE::QemuServer;
 use PVE::QemuServer::Monitor;
-use PVE::QemuServer::Machine;
+use PVE::QemuServer::QMPHelpers;
 use PVE::QemuServer::CPUConfig;
 
 my $base_env = {
@@ -472,7 +472,7 @@ sub do_test($) {
     # check if QEMU version set correctly and test version_cmp
     (my $qemu_major = get_test_qemu_version()) =~ s/\..*$//;
     die "runs_at_least_qemu_version returned false, maybe error in version_cmp?"
-       if !PVE::QemuServer::Machine::runs_at_least_qemu_version($vmid, $qemu_major);
+       if !PVE::QemuServer::QMPHelpers::runs_at_least_qemu_version($vmid, $qemu_major);
 
     $cmdline =~ s/ -/ \\\n  -/g; # same as qm showcmd --pretty
     $cmdline .= "\n";