5
0
mirror of git://git.proxmox.com/git/qemu-server.git synced 2025-03-09 08:58:25 +03:00

qemu-server: make nodename mock-able for tests

Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
This commit is contained in:
Thomas Lamprecht 2019-12-10 11:05:39 +01:00
parent cbb39a7e79
commit 38277afcd4
2 changed files with 34 additions and 5 deletions

View File

@ -108,7 +108,11 @@ sub cgroups_write {
}
my $nodename = PVE::INotify::nodename();
my $nodename_cache;
sub nodename {
$nodename_cache //= PVE::INotify::nodename();
return $nodename_cache;
}
my $cpu_vendor_list = {
# Intel CPUs
@ -2805,6 +2809,7 @@ sub config_list {
my $res = {};
return $res if !$vmlist || !$vmlist->{ids};
my $ids = $vmlist->{ids};
my $nodename = nodename();
foreach my $vmid (keys %$ids) {
my $d = $ids->{$vmid};
@ -2863,7 +2868,7 @@ sub shared_nodes {
my $nodelist = PVE::Cluster::get_nodelist();
my $nodehash = { map { $_ => 1 } @$nodelist };
my $nodename = PVE::INotify::nodename();
my $nodename = nodename();
foreach_drive($conf, sub {
my ($ds, $drive) = @_;
@ -3461,6 +3466,7 @@ sub config_to_command {
my $ostype = $conf->{ostype};
my $winversion = windows_version($ostype);
my $kvm = $conf->{kvm};
my $nodename = nodename();
my $arch = get_vm_arch($conf);
my $kvm_binary = get_command_for_arch($arch);
@ -3884,7 +3890,6 @@ sub config_to_command {
my $pciaddr = print_pci_addr("spice", $bridges, $arch, $machine_type);
my $nodename = PVE::INotify::nodename();
my $pfamily = PVE::Tools::get_host_address_family($nodename);
my @nodeaddrs = PVE::Tools::getaddrinfo_all('localhost', family => $pfamily);
die "failed to get an ip address of type $pfamily for 'localhost'\n" if !@nodeaddrs;
@ -5318,7 +5323,7 @@ sub vm_start {
if ($statefile eq 'tcp') {
my $localip = "localhost";
my $datacenterconf = PVE::Cluster::cfs_read_file('datacenter.cfg');
my $nodename = PVE::INotify::nodename();
my $nodename = nodename();
if (!defined($migration_type)) {
if (defined($datacenterconf->{migration}->{type})) {
@ -5458,7 +5463,7 @@ sub vm_start {
#start nbd server for storage migration
if ($targetstorage) {
my $nodename = PVE::INotify::nodename();
my $nodename = nodename();
my $localip = $get_migration_ip->($migration_network, $nodename);
my $pfamily = PVE::Tools::get_host_address_family($nodename);
my $storage_migrate_port = PVE::Tools::next_migrate_port($pfamily);

View File

@ -7,8 +7,12 @@ use lib qw(..);
use Test::More;
use Test::MockModule;
use Socket qw(AF_INET AF_INET6);
use PVE::Tools qw(file_get_contents file_set_contents run_command);
use PVE::INotify;
use PVE::SysFSTools;
use PVE::QemuConfig;
use PVE::QemuServer;
use PVE::QemuServer::Monitor;
@ -164,6 +168,26 @@ $pve_common_tools->mock(
return '61000';
},
getaddrinfo_all => sub {
my ($hostname, @opts) = @_;
die "need stable hostname" if $hostname ne 'localhost';
return (
{
addr => Socket::pack_sockaddr_in(0, Socket::INADDR_LOOPBACK),
family => AF_INET, # IPv4
protocol => 6,
socktype => 1,
},
);
},
);
my $pve_common_inotify;
$pve_common_inotify = Test::MockModule->new('PVE::INotify');
$pve_common_inotify->mock(
nodename => sub {
return 'localhost';
},
);
my $pve_common_sysfstools;