mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-24 18:55:04 +08:00
Try harder to detect a port conflict in PostgresNode.pm.
Commit fab84c7787
tried to get away without doing an actual bind(),
but buildfarm results show that that doesn't get the job done. So we must
really bind to the target port --- and at least on my Linux box, we need a
listen() as well, or conflicts won't be detected. We rely on SO_REUSEADDR
to prevent problems from starting a postmaster on the socket immediately
after we've bound to it in the test code. (There may be platforms where
that doesn't work too well. But fortunately, we only really care whether
this works on Windows, and there the default behavior should be OK.)
This commit is contained in:
parent
63417b4b2e
commit
40e89e2ab8
@ -859,12 +859,18 @@ sub get_new_node
|
||||
# to open a TCP port on Unix.
|
||||
if ($found == 1)
|
||||
{
|
||||
my $iaddr = inet_aton($test_localhost);
|
||||
my $paddr = sockaddr_in($port, $iaddr);
|
||||
my $proto = getprotobyname("tcp");
|
||||
my $iaddr = inet_aton($test_localhost);
|
||||
my $paddr = sockaddr_in($port, $iaddr);
|
||||
my $proto = getprotobyname("tcp");
|
||||
|
||||
socket(SOCK, PF_INET, SOCK_STREAM, $proto) or die;
|
||||
$found = 0 if connect(SOCK, $paddr);
|
||||
socket(SOCK, PF_INET, SOCK_STREAM, $proto)
|
||||
or die "socket failed: $!";
|
||||
|
||||
# As in postmaster, don't use SO_REUSEADDR on Windows
|
||||
setsockopt(SOCK, SOL_SOCKET, SO_REUSEADDR, pack("l", 1))
|
||||
unless $TestLib::windows_os;
|
||||
(bind(SOCK, $paddr) && listen(SOCK, SOMAXCONN))
|
||||
or $found = 0;
|
||||
close(SOCK);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user