Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
In the pg_upgrade test suite, don't write to src/test/regress.
authorNoah Misch <noah@leadboat.com>
Tue, 28 May 2019 19:59:00 +0000 (12:59 -0700)
committerNoah Misch <noah@leadboat.com>
Tue, 28 May 2019 20:00:26 +0000 (13:00 -0700)
When this suite runs installcheck, redirect file creations from
src/test/regress to src/bin/pg_upgrade/tmp_check/regress.  This closes a
race condition in "make -j check-world".  If the pg_upgrade suite wrote
to a given src/test/regress/results file in parallel with the regular
src/test/regress invocation writing it, a test failed spuriously.  Even
without parallelism, in "make -k check-world", the suite finishing
second overwrote the other's regression.diffs.  This revealed test
"largeobject" assuming @abs_builddir@ is getcwd(), so fix that, too.

Buildfarm client REL_10, released fifty-four days ago, supports saving
regression.diffs from its new location.  When an older client reports a
pg_upgradeCheck failure, it will no longer include regression.diffs.
Back-patch to 9.5, where pg_upgrade moved to src/bin.

Reviewed (in earlier versions) by Andrew Dunstan.

Discussion: https://postgr.es/m/20181224034411.GA3224776@rfd.leadboat.com

src/bin/pg_upgrade/test.sh
src/test/regress/input/largeobject.source
src/test/regress/output/largeobject.source
src/test/regress/output/largeobject_1.source
src/tools/msvc/vcregress.pl

index 82db9849608a17f6eac2f8653fa17c786c1b4eb6..8a8b826e9d9923d6a7aca047e499563f29ed11a8 100644 (file)
@@ -107,6 +107,17 @@ BASE_PGDATA=$temp_root/data
 PGDATA="$BASE_PGDATA.old"
 export PGDATA
 
+# Send installcheck outputs to a private directory.  This avoids conflict when
+# check-world runs pg_upgrade check concurrently with src/test/regress check.
+# To retrieve interesting files after a run, use pattern tmp_check/*/*.diffs.
+outputdir="$temp_root/regress"
+EXTRA_REGRESS_OPTS="$EXTRA_REGRESS_OPTS --outputdir=$outputdir"
+export EXTRA_REGRESS_OPTS
+mkdir "$outputdir"
+mkdir "$outputdir"/sql
+mkdir "$outputdir"/expected
+mkdir "$outputdir"/testtablespace
+
 logdir=`pwd`/log
 rm -rf "$logdir"
 mkdir "$logdir"
index 50c13eb4f3ce4192bc27bcd263e2dfdf572f885a..9aa7b16193d3a8661858cc4268d9c6da63316197 100644 (file)
@@ -203,12 +203,12 @@ END;
 
 SELECT lo_export(loid, '@abs_builddir@/results/lotest.txt') FROM lotest_stash_values;
 
-\lo_import 'results/lotest.txt'
+\lo_import '@abs_builddir@/results/lotest.txt'
 
 \set newloid :LASTOID
 
 -- just make sure \lo_export does not barf
-\lo_export :newloid 'results/lotest2.txt'
+\lo_export :newloid '@abs_builddir@/results/lotest2.txt'
 
 -- This is a hack to test that export/import are reversible
 -- This uses knowledge about the inner workings of large object mechanism
@@ -223,7 +223,7 @@ TRUNCATE lotest_stash_values;
 
 \lo_unlink :newloid
 
-\lo_import 'results/lotest.txt'
+\lo_import '@abs_builddir@/results/lotest.txt'
 
 \set newloid_1 :LASTOID
 
index afdcb4b7dd01ace288151ace59df67714f7662db..969a7c7f40ffea24cbc3396ec631c1e936d1284e 100644 (file)
@@ -385,10 +385,10 @@ SELECT lo_export(loid, '@abs_builddir@/results/lotest.txt') FROM lotest_stash_va
          1
 (1 row)
 
-\lo_import 'results/lotest.txt'
+\lo_import '@abs_builddir@/results/lotest.txt'
 \set newloid :LASTOID
 -- just make sure \lo_export does not barf
-\lo_export :newloid 'results/lotest2.txt'
+\lo_export :newloid '@abs_builddir@/results/lotest2.txt'
 -- This is a hack to test that export/import are reversible
 -- This uses knowledge about the inner workings of large object mechanism
 -- which should not be used outside it.  This makes it a HACK
@@ -407,7 +407,7 @@ SELECT lo_unlink(loid) FROM lotest_stash_values;
 
 TRUNCATE lotest_stash_values;
 \lo_unlink :newloid
-\lo_import 'results/lotest.txt'
+\lo_import '@abs_builddir@/results/lotest.txt'
 \set newloid_1 :LASTOID
 SELECT lo_from_bytea(0, lo_get(:newloid_1)) AS newloid_2
 \gset
index 86aa3c003224756630662358d5bce206f3fd0e4a..bb636b6fe62aed6c06a530c63e79a1cccfc20b92 100644 (file)
@@ -385,10 +385,10 @@ SELECT lo_export(loid, '@abs_builddir@/results/lotest.txt') FROM lotest_stash_va
          1
 (1 row)
 
-\lo_import 'results/lotest.txt'
+\lo_import '@abs_builddir@/results/lotest.txt'
 \set newloid :LASTOID
 -- just make sure \lo_export does not barf
-\lo_export :newloid 'results/lotest2.txt'
+\lo_export :newloid '@abs_builddir@/results/lotest2.txt'
 -- This is a hack to test that export/import are reversible
 -- This uses knowledge about the inner workings of large object mechanism
 -- which should not be used outside it.  This makes it a HACK
@@ -407,7 +407,7 @@ SELECT lo_unlink(loid) FROM lotest_stash_values;
 
 TRUNCATE lotest_stash_values;
 \lo_unlink :newloid
-\lo_import 'results/lotest.txt'
+\lo_import '@abs_builddir@/results/lotest.txt'
 \set newloid_1 :LASTOID
 SELECT lo_from_bytea(0, lo_get(:newloid_1)) AS newloid_2
 \gset
index 7b388d2365b0f42ef81821cb90cb3be97c0e955e..699873cd029582f351b5d3f552cd41d5b2b10d6d 100644 (file)
@@ -97,9 +97,9 @@ exit 0;
 
 ########################################################################
 
-sub installcheck
+sub installcheck_internal
 {
-   my $schedule = shift || 'serial';
+   my ($schedule, @EXTRA_REGRESS_OPTS) = @_;
    my @args = (
        "../../../$Config/pg_regress/pg_regress",
        "--dlpath=.",
@@ -108,11 +108,19 @@ sub installcheck
        "--encoding=SQL_ASCII",
        "--no-locale");
    push(@args, $maxconn) if $maxconn;
+   push(@args, @EXTRA_REGRESS_OPTS);
    system(@args);
    my $status = $? >> 8;
    exit $status if $status;
 }
 
+sub installcheck
+{
+   my $schedule = shift || 'serial';
+   installcheck_internal($schedule);
+   return;
+}
+
 sub check
 {
    my $schedule = shift || 'parallel';
@@ -501,6 +509,13 @@ sub upgradecheck
    $ENV{PATH} = "$bindir;$ENV{PATH}";
    my $data = "$tmp_root/data";
    $ENV{PGDATA} = "$data.old";
+   my $outputdir          = "$tmp_root/regress";
+   my @EXTRA_REGRESS_OPTS = ("--outputdir=$outputdir");
+   mkdir "$outputdir"                || die $!;
+   mkdir "$outputdir/sql"            || die $!;
+   mkdir "$outputdir/expected"       || die $!;
+   mkdir "$outputdir/testtablespace" || die $!;
+
    my $logdir = "$topdir/src/bin/pg_upgrade/log";
    rmtree($logdir);
    mkdir $logdir || die $!;
@@ -516,7 +531,7 @@ sub upgradecheck
    generate_db('',       91, 127, '');
 
    print "\nSetting up data for upgrading\n\n";
-   installcheck();
+   installcheck_internal('serial', @EXTRA_REGRESS_OPTS);
 
    # now we can chdir into the source dir
    chdir "$topdir/src/bin/pg_upgrade";