mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
Make PG_TEST_NOCLEAN work for temporary directories in TAP tests
When set, this environment variable was only effective for data directories but not for all the other temporary files created by PostgreSQL::Test::Utils. Keeping the temporary files after a successful run can be useful for debugging purposes. The documentation is updated to reflect the new behavior, with contents available in doc/ since v16 and in src/test/perl/README since v15. Author: Jacob Champion Reviewed-by: Daniel Gustafsson Discussion: https://postgr.es/m/CAAWbhmgHtDH1SGZ+Fw05CsXtE0mzTmjbuUxLB9mY9iPKgM6cUw@mail.gmail.com Discussion: https://postgr.es/m/YyPd9unV14SX2bLF@paquier.xyz Backpatch-through: 11
This commit is contained in:
@@ -818,6 +818,8 @@ make check PROVE_TESTS='t/001_test1.pl t/003_test3.pl'
|
|||||||
<programlisting>
|
<programlisting>
|
||||||
PG_TEST_NOCLEAN=1 make -C src/bin/pg_dump check
|
PG_TEST_NOCLEAN=1 make -C src/bin/pg_dump check
|
||||||
</programlisting>
|
</programlisting>
|
||||||
|
This environment variable also prevents the test's temporary directories
|
||||||
|
from being removed.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>
|
<para>
|
||||||
|
@@ -272,7 +272,7 @@ sub all_tests_passing
|
|||||||
|
|
||||||
Securely create a temporary directory inside C<$tmp_check>, like C<mkdtemp>,
|
Securely create a temporary directory inside C<$tmp_check>, like C<mkdtemp>,
|
||||||
and return its name. The directory will be removed automatically at the
|
and return its name. The directory will be removed automatically at the
|
||||||
end of the tests.
|
end of the tests, unless the environment variable PG_TEST_NOCLEAN is provided.
|
||||||
|
|
||||||
If C<prefix> is given, the new directory is templated as C<${prefix}_XXXX>.
|
If C<prefix> is given, the new directory is templated as C<${prefix}_XXXX>.
|
||||||
Otherwise the template is C<tmp_test_XXXX>.
|
Otherwise the template is C<tmp_test_XXXX>.
|
||||||
@@ -286,7 +286,7 @@ sub tempdir
|
|||||||
return File::Temp::tempdir(
|
return File::Temp::tempdir(
|
||||||
$prefix . '_XXXX',
|
$prefix . '_XXXX',
|
||||||
DIR => $tmp_check,
|
DIR => $tmp_check,
|
||||||
CLEANUP => 1);
|
CLEANUP => not defined $ENV{'PG_TEST_NOCLEAN'});
|
||||||
}
|
}
|
||||||
|
|
||||||
=pod
|
=pod
|
||||||
@@ -301,7 +301,8 @@ name, to avoid path length issues.
|
|||||||
sub tempdir_short
|
sub tempdir_short
|
||||||
{
|
{
|
||||||
|
|
||||||
return File::Temp::tempdir(CLEANUP => 1);
|
return File::Temp::tempdir(
|
||||||
|
CLEANUP => not defined $ENV{'PG_TEST_NOCLEAN'});
|
||||||
}
|
}
|
||||||
|
|
||||||
=pod
|
=pod
|
||||||
|
@@ -31,8 +31,9 @@ some lesser number of seconds.
|
|||||||
|
|
||||||
Data directories will also be left behind for analysis when a test fails;
|
Data directories will also be left behind for analysis when a test fails;
|
||||||
they are named according to the test filename. But if the environment
|
they are named according to the test filename. But if the environment
|
||||||
variable PG_TEST_NOCLEAN is set, data directories will be retained
|
variable PG_TEST_NOCLEAN is set, the data directories will be retained
|
||||||
regardless of test status.
|
regardless of test status. This environment variable also prevents the
|
||||||
|
test's temporary directories from being removed.
|
||||||
|
|
||||||
|
|
||||||
Writing tests
|
Writing tests
|
||||||
|
Reference in New Issue
Block a user