1
0
mirror of https://github.com/moparisthebest/curl synced 2025-01-11 14:08:07 -05:00

tests: pick a random port number for SSH

Since sshd doesn't have such an option by itself, we iterate over a
series of random ports until one works.

Closes #5273
This commit is contained in:
Daniel Stenberg 2020-04-20 15:10:24 +02:00
parent 06ce166944
commit d1239b50be
No known key found for this signature in database
GPG Key ID: 5CC908FDB71E12C2

View File

@ -2117,7 +2117,6 @@ sub runrtspserver {
sub runsshserver { sub runsshserver {
my ($id, $verbose, $ipv6) = @_; my ($id, $verbose, $ipv6) = @_;
my $ip=$HOSTIP; my $ip=$HOSTIP;
my $port = $SSHPORT;
my $proto = 'ssh'; my $proto = 'ssh';
my $ipvnum = 4; my $ipvnum = 4;
my $idnum = ($id && ($id =~ /^(\d+)$/) && ($id > 1)) ? $id : 1; my $idnum = ($id && ($id =~ /^(\d+)$/) && ($id > 1)) ? $id : 1;
@ -2125,7 +2124,7 @@ sub runsshserver {
my $srvrname; my $srvrname;
my $pidfile; my $pidfile;
my $logfile; my $logfile;
my $flags = ""; my $port = 20000; # no lower port
$server = servername_id($proto, $ipvnum, $idnum); $server = servername_id($proto, $ipvnum, $idnum);
@ -2135,7 +2134,6 @@ sub runsshserver {
if ($doesntrun{$pidfile}) { if ($doesntrun{$pidfile}) {
return (0,0); return (0,0);
} }
my $pid = processexists($pidfile); my $pid = processexists($pidfile);
if($pid > 0) { if($pid > 0) {
stopserver($server, "$pid"); stopserver($server, "$pid");
@ -2146,32 +2144,48 @@ sub runsshserver {
$logfile = server_logfilename($LOGDIR, $proto, $ipvnum, $idnum); $logfile = server_logfilename($LOGDIR, $proto, $ipvnum, $idnum);
my $flags = "";
$flags .= "--verbose " if($verbose); $flags .= "--verbose " if($verbose);
$flags .= "--debugprotocol " if($debugprotocol); $flags .= "--debugprotocol " if($debugprotocol);
$flags .= "--pidfile \"$pidfile\" "; $flags .= "--pidfile \"$pidfile\" ";
$flags .= "--id $idnum " if($idnum > 1); $flags .= "--id $idnum " if($idnum > 1);
$flags .= "--ipv$ipvnum --addr \"$ip\" "; $flags .= "--ipv$ipvnum --addr \"$ip\" ";
$flags .= "--sshport $port ";
$flags .= "--user \"$USER\""; $flags .= "--user \"$USER\"";
my $cmd = "$perl $srcdir/sshserver.pl $flags"; my $sshpid;
my ($sshpid, $pid2) = startnew($cmd, $pidfile, 60, 0); my $pid2;
# on loaded systems sshserver start up can take longer than the timeout my $wport = 0,
# passed to startnew, when this happens startnew completes without being my @tports;
# able to read the pidfile and consequently returns a zero pid2 above. for(1 .. 10) {
# sshd doesn't have a way to pick an unused random port number, so
# instead we iterate over possible port numbers to use until we find
# one that works
$port += int(rand(500));
push @tports, $port;
my $options = "$flags --sshport $port";
my $cmd = "$perl $srcdir/sshserver.pl $options";
($sshpid, $pid2) = startnew($cmd, $pidfile, 60, 0);
# on loaded systems sshserver start up can take longer than the
# timeout passed to startnew, when this happens startnew completes
# without being able to read the pidfile and consequently returns a
# zero pid2 above.
if($sshpid <= 0 || !pidexists($sshpid)) { if($sshpid <= 0 || !pidexists($sshpid)) {
# it is NOT alive # it is NOT alive
logmsg "RUN: failed to start the $srvrname server\n"; logmsg "RUN: failed to start the $srvrname server on $port\n";
stopserver($server, "$pid2"); stopserver($server, "$pid2");
$doesntrun{$pidfile} = 1; $doesntrun{$pidfile} = 1;
return (0,0); next;
} }
# ssh server verification allows some extra time for the server to start up # ssh server verification allows some extra time for the server to
# and gives us the opportunity of recovering the pid from the pidfile, when # start up and gives us the opportunity of recovering the pid from the
# this verification succeeds the recovered pid is assigned to pid2. # pidfile, when this verification succeeds the recovered pid is
# assigned to pid2.
my $pid3 = verifyserver($proto, $ipvnum, $idnum, $ip, $port); my $pid3 = verifyserver($proto, $ipvnum, $idnum, $ip, $port);
if(!$pid3) { if(!$pid3) {
@ -2179,13 +2193,14 @@ sub runsshserver {
# failed to fetch server pid. Kill the server and return failure # failed to fetch server pid. Kill the server and return failure
stopserver($server, "$sshpid $pid2"); stopserver($server, "$sshpid $pid2");
$doesntrun{$pidfile} = 1; $doesntrun{$pidfile} = 1;
return (0,0); next;
} }
$pid2 = $pid3; $pid2 = $pid3;
# once it is known that the ssh server is alive, sftp server verification # once it is known that the ssh server is alive, sftp server
# is performed actually connecting to it, authenticating and performing a # verification is performed actually connecting to it, authenticating
# very simple remote command. This verification is tried only one time. # and performing a very simple remote command. This verification is
# tried only one time.
$sshdlog = server_logfilename($LOGDIR, 'ssh', $ipvnum, $idnum); $sshdlog = server_logfilename($LOGDIR, 'ssh', $ipvnum, $idnum);
$sftplog = server_logfilename($LOGDIR, 'sftp', $ipvnum, $idnum); $sftplog = server_logfilename($LOGDIR, 'sftp', $ipvnum, $idnum);
@ -2199,7 +2214,17 @@ sub runsshserver {
display_sshdconfig(); display_sshdconfig();
stopserver($server, "$sshpid $pid2"); stopserver($server, "$sshpid $pid2");
$doesntrun{$pidfile} = 1; $doesntrun{$pidfile} = 1;
return (0,0); next;
}
# we're happy, no need to loop anymore!
$wport = $port;
last;
}
if(!$wport) {
logmsg "RUN: couldn't start $srvrname. Tried these ports:";
logmsg "RUN: ".join(", ", @tports);
return (0,0,0);
} }
my $hstpubmd5f = "curl_host_rsa_key.pub_md5"; my $hstpubmd5f = "curl_host_rsa_key.pub_md5";
@ -2214,11 +2239,9 @@ sub runsshserver {
die $msg; die $msg;
} }
if($verbose) { logmsg "RUN: $srvrname on PID $pid2 port $wport\n";
logmsg "RUN: $srvrname server is now running PID $pid2\n";
}
return ($pid2, $sshpid); return ($pid2, $sshpid, $wport);
} }
####################################################################### #######################################################################
@ -3168,7 +3191,6 @@ sub checksystem {
logmsg sprintf("FTPS/%d ", $FTPSPORT); logmsg sprintf("FTPS/%d ", $FTPSPORT);
logmsg sprintf("HTTPS/%d ", $HTTPSPORT); logmsg sprintf("HTTPS/%d ", $HTTPSPORT);
} }
logmsg sprintf("\n* SSH/%d ", $SSHPORT);
if($httptlssrv) { if($httptlssrv) {
logmsg sprintf("HTTPTLS/%d ", $HTTPTLSPORT); logmsg sprintf("HTTPTLS/%d ", $HTTPTLSPORT);
if($has_ipv6) { if($has_ipv6) {
@ -3718,8 +3740,7 @@ sub singletest {
return -1; return -1;
} }
my $fileContent = join('', @inputfile); my $fileContent = join('', @inputfile);
subVariables \$fileContent; subVariables(\$fileContent);
# logmsg "DEBUG: writing file " . $filename . "\n";
open(OUTFILE, ">$filename"); open(OUTFILE, ">$filename");
binmode OUTFILE; # for crapage systems, use binary binmode OUTFILE; # for crapage systems, use binary
print OUTFILE $fileContent; print OUTFILE $fileContent;
@ -3987,7 +4008,7 @@ sub singletest {
if(@postcheck) { if(@postcheck) {
$cmd = join("", @postcheck); $cmd = join("", @postcheck);
chomp $cmd; chomp $cmd;
subVariables \$cmd; subVariables(\$cmd);
if($cmd) { if($cmd) {
logmsg "postcheck $cmd\n" if($verbose); logmsg "postcheck $cmd\n" if($verbose);
my $rc = runclient("$cmd"); my $rc = runclient("$cmd");
@ -4828,7 +4849,7 @@ sub startservers {
} }
elsif($what eq "sftp" || $what eq "scp") { elsif($what eq "sftp" || $what eq "scp") {
if(!$run{'ssh'}) { if(!$run{'ssh'}) {
($pid, $pid2) = runsshserver("", $verbose); ($pid, $pid2, $SSHPORT) = runsshserver("", $verbose);
if($pid <= 0) { if($pid <= 0) {
return "failed starting SSH server"; return "failed starting SSH server";
} }
@ -5396,7 +5417,6 @@ if ($gdbthis) {
$minport = $base; # original base port number $minport = $base; # original base port number
$HTTPSPORT = $base++; # HTTPS (stunnel) server port $HTTPSPORT = $base++; # HTTPS (stunnel) server port
$FTPSPORT = $base++; # FTPS (stunnel) server port $FTPSPORT = $base++; # FTPS (stunnel) server port
$SSHPORT = $base++; # SSH (SCP/SFTP) port
$HTTPTLSPORT = $base++; # HTTP TLS (non-stunnel) server port $HTTPTLSPORT = $base++; # HTTP TLS (non-stunnel) server port
$HTTPTLS6PORT = $base++; # HTTP TLS (non-stunnel) IPv6 server port $HTTPTLS6PORT = $base++; # HTTP TLS (non-stunnel) IPv6 server port
$HTTP2PORT = $base++; # HTTP/2 port $HTTP2PORT = $base++; # HTTP/2 port