pgsql: Check availability of module injection_points in TAP tests

From: Michael Paquier <michael(at)paquier(dot)xyz>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: Check availability of module injection_points in TAP tests
Date: 2024-09-05 04:30:43
Message-ID: E1sm48o-000CCy-Rq@gemulon.postgresql.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Check availability of module injection_points in TAP tests

This fixes defects with installcheck for TAP tests that expect the
module injection_points to exist in an installation, but the contents of
src/test/modules are not installed by default with installcheck. This
would cause, for example, failures under installcheck-world for a build
with injection points enabled, when the contents of src/test/modules/
are not installed.

The availability of the module can be done with a scan of
pg_available_extension. This has been introduced in 2cdcae9da696, and
it is refactored here as a new routine in Cluster.pm.

Tests are changed in different ways depending on what they need:
- The libpq TAP test sets up a node even without injection points, so it
is enough to check that CREATE EXTENSION can be used. There is no need
for the variable enable_injection_points.
- In test_misc, 006_signal_autovacuum requires a runtime check.
- 041_checkpoint_at_promote in recovery tests and 005_timeouts in
test_misc are updated to use the routine introduced in Cluster.pm.
- test_slru's 001_multixact, injection_points's 001_stats and
modules/gin/ do not require a check as these modules disable
installcheck entirely.

Discussion: https://postgr.es/m/ZtesYQ-WupeAK7xK@paquier.xyz

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/5735521ac2d52485bca673039ba43e2b8cc71cd4

Modified Files
--------------
src/interfaces/libpq/Makefile | 2 +-
src/interfaces/libpq/meson.build | 1 -
src/interfaces/libpq/t/005_negotiate_encryption.pl | 7 +++++--
src/test/modules/test_misc/t/005_timeouts.pl | 5 +----
.../modules/test_misc/t/006_signal_autovacuum.pl | 9 +++++++++
src/test/perl/PostgreSQL/Test/Cluster.pm | 22 ++++++++++++++++++++++
src/test/recovery/t/041_checkpoint_at_promote.pl | 5 +----
7 files changed, 39 insertions(+), 12 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Michael Paquier 2024-09-05 05:37:23 pgsql: Fix two NULL pointer dereferences when reading custom pgstats fr
Previous Message David Rowley 2024-09-05 04:18:44 pgsql: Optimize WindowAgg's use of tuplestores