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:
parent
06ce166944
commit
d1239b50be
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user