Commit 660a2b19 authored by Noah Misch's avatar Noah Misch

Consolidate methods for translating a Perl path to a Windows path.

This fixes some TAP suites when using msys Perl and a builddir located
in an msys mount point other than "/".  For example, builddir=/c/pg
exhibited the problem, since /c/pg falls in mount point "/c".
Back-patch to 9.6, where tests first started to perform such
translations.  In back branches, offer both new and old APIs.

Reviewed by Andrew Dunstan.

Discussion: https://postgr.es/m/20190610045838.GA238501@rfd.leadboat.com
parent 25b93a29
...@@ -183,7 +183,7 @@ check_relation_corruption($node, 'corrupt1', 'pg_default'); ...@@ -183,7 +183,7 @@ check_relation_corruption($node, 'corrupt1', 'pg_default');
my $basedir = $node->basedir; my $basedir = $node->basedir;
my $tablespace_dir = "$basedir/ts_corrupt_dir"; my $tablespace_dir = "$basedir/ts_corrupt_dir";
mkdir($tablespace_dir); mkdir($tablespace_dir);
$tablespace_dir = TestLib::real_dir($tablespace_dir); $tablespace_dir = TestLib::perl2host($tablespace_dir);
$node->safe_psql('postgres', $node->safe_psql('postgres',
"CREATE TABLESPACE ts_corrupt LOCATION '$tablespace_dir';"); "CREATE TABLESPACE ts_corrupt LOCATION '$tablespace_dir';");
check_relation_corruption($node, 'corrupt2', 'ts_corrupt'); check_relation_corruption($node, 'corrupt2', 'ts_corrupt');
......
...@@ -107,15 +107,6 @@ our @EXPORT = qw( ...@@ -107,15 +107,6 @@ our @EXPORT = qw(
our ($use_tcp, $test_localhost, $test_pghost, $last_host_assigned, our ($use_tcp, $test_localhost, $test_pghost, $last_host_assigned,
$last_port_assigned, @all_nodes, $died); $last_port_assigned, @all_nodes, $died);
# Windows path to virtual file system root
our $vfs_path = '';
if ($Config{osname} eq 'msys')
{
$vfs_path = `cd / && pwd -W`;
chomp $vfs_path;
}
INIT INIT
{ {
...@@ -945,7 +936,7 @@ primary_conninfo='$root_connstr' ...@@ -945,7 +936,7 @@ primary_conninfo='$root_connstr'
sub enable_restoring sub enable_restoring
{ {
my ($self, $root_node) = @_; my ($self, $root_node) = @_;
my $path = $vfs_path . $root_node->archive_dir; my $path = TestLib::perl2host($root_node->archive_dir);
my $name = $self->name; my $name = $self->name;
print "### Enabling WAL restore for node \"$name\"\n"; print "### Enabling WAL restore for node \"$name\"\n";
...@@ -990,7 +981,7 @@ sub set_standby_mode ...@@ -990,7 +981,7 @@ sub set_standby_mode
sub enable_archiving sub enable_archiving
{ {
my ($self) = @_; my ($self) = @_;
my $path = $vfs_path . $self->archive_dir; my $path = TestLib::perl2host($self->archive_dir);
my $name = $self->name; my $name = $self->name;
print "### Enabling WAL archiving for node \"$name\"\n"; print "### Enabling WAL archiving for node \"$name\"\n";
......
...@@ -166,22 +166,31 @@ sub tempdir_short ...@@ -166,22 +166,31 @@ sub tempdir_short
return File::Temp::tempdir(CLEANUP => 1); return File::Temp::tempdir(CLEANUP => 1);
} }
# Return the real directory for a virtual path directory under msys. # Translate a Perl file name to a host file name. Currently, this is a no-op
# The directory must exist. If it's not an existing directory or we're # except for the case of Perl=msys and host=mingw32. The subject need not
# not under msys, return the input argument unchanged. # exist, but its parent directory must exist.
sub real_dir sub perl2host
{ {
my $dir = "$_[0]"; my ($subject) = @_;
return $dir unless -d $dir; return $subject unless $Config{osname} eq 'msys';
return $dir unless $Config{osname} eq 'msys';
my $here = cwd; my $here = cwd;
chdir $dir; my $leaf;
if (chdir $subject)
{
$leaf = '';
}
else
{
$leaf = '/' . basename $subject;
my $parent = dirname $subject;
chdir $parent or die "could not chdir \"$parent\": $!";
}
# this odd way of calling 'pwd -W' is the only way that seems to work. # this odd way of calling 'pwd -W' is the only way that seems to work.
$dir = qx{sh -c "pwd -W"}; my $dir = qx{sh -c "pwd -W"};
chomp $dir; chomp $dir;
chdir $here; chdir $here;
return $dir; return $dir . $leaf;
} }
sub system_log sub system_log
......
...@@ -30,7 +30,7 @@ ok(-f "$pgdata/$baseUnloggedPath", 'main fork in base exists'); ...@@ -30,7 +30,7 @@ ok(-f "$pgdata/$baseUnloggedPath", 'main fork in base exists');
my $tablespaceDir = TestLib::tempdir; my $tablespaceDir = TestLib::tempdir;
my $realTSDir = TestLib::real_dir($tablespaceDir); my $realTSDir = TestLib::perl2host($tablespaceDir);
$node->safe_psql('postgres', "CREATE TABLESPACE ts1 LOCATION '$realTSDir'"); $node->safe_psql('postgres', "CREATE TABLESPACE ts1 LOCATION '$realTSDir'");
$node->safe_psql('postgres', $node->safe_psql('postgres',
......
...@@ -12,14 +12,6 @@ use Time::HiRes qw(usleep); ...@@ -12,14 +12,6 @@ use Time::HiRes qw(usleep);
plan tests => 5; plan tests => 5;
# See PostgresNode
my $vfs_path = '';
if ($Config{osname} eq 'msys')
{
$vfs_path = `cd / && pwd -W`;
chomp $vfs_path;
}
my $tempdir = TestLib::tempdir; my $tempdir = TestLib::tempdir;
my $port; my $port;
...@@ -103,10 +95,11 @@ log_ipcs(); ...@@ -103,10 +95,11 @@ log_ipcs();
# Scenarios involving no postmaster.pid, dead postmaster, and a live backend. # Scenarios involving no postmaster.pid, dead postmaster, and a live backend.
# Use a regress.c function to emulate the responsiveness of a backend working # Use a regress.c function to emulate the responsiveness of a backend working
# through a CPU-intensive task. # through a CPU-intensive task.
my $regress_shlib = TestLib::perl2host($ENV{REGRESS_SHLIB});
$gnat->safe_psql('postgres', <<EOSQL); $gnat->safe_psql('postgres', <<EOSQL);
CREATE FUNCTION wait_pid(int) CREATE FUNCTION wait_pid(int)
RETURNS void RETURNS void
AS '$vfs_path$ENV{REGRESS_SHLIB}' AS '$regress_shlib'
LANGUAGE C STRICT; LANGUAGE C STRICT;
EOSQL EOSQL
my $slow_query = 'SELECT wait_pid(pg_backend_pid())'; my $slow_query = 'SELECT wait_pid(pg_backend_pid())';
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment