34 lines
855 B
Perl
34 lines
855 B
Perl
#!/usr/bin/perl
|
|
|
|
use IO::Socket;
|
|
|
|
$vm = shift;
|
|
$log = shift;
|
|
|
|
# start virtualbox gui in minimized mode - this should be the first thing we do since this process
|
|
# inherits all handles and we want our sockets/log file closed
|
|
system("start /min virtualbox --startvm $vm");
|
|
|
|
# start a server; vm will connect to the server via autotest-remote-host.pl
|
|
my $server = new IO::Socket::INET(LocalPort => 7183, Listen => 1);
|
|
die "Could not create socket: $!\n" unless $server;
|
|
|
|
open LOG, ">> $log" || die "Could not open log file: $!\n";
|
|
|
|
print LOG "Listening for connection...\n";
|
|
|
|
my $client = $server->accept();
|
|
|
|
# echo all input to log file
|
|
print LOG $_ while (<$client>);
|
|
close LOG;
|
|
|
|
$client->close();
|
|
$server->close();
|
|
|
|
# wait for vm shutdown to decrease peak memory consumption
|
|
while (`vboxmanage showvminfo $vm` !~ /State:\s+powered off/)
|
|
{
|
|
sleep(1);
|
|
}
|