mirror of
https://github.com/postgres/postgres.git
synced 2025-10-24 01:29:19 +03:00
Refactor PG_TEST_EXTRA logic in autoconf build
To avoid duplicating the PG_TEST_EXTRA logic in Makefiles into the upcoming meson based build definition, move the checks into the the tests themselves. That also has the advantage of making skipped tests visible. Reviewed-by: Peter Eisentraut <peter.eisentraut@enterprisedb.com> Author: Nazir Bilal Yavuz <byavuz81@gmail.com> Author: Andres Freund <andres@anarazel.de> Discussion: https://postgr.es/m/7dae5979-c6c0-cec5-7a36-76a85aa8053d@enterprisedb.com
This commit is contained in:
@@ -17,25 +17,20 @@ SUBDIRS = perl regress isolation modules authentication recovery subscription
|
|||||||
ifeq ($(with_icu),yes)
|
ifeq ($(with_icu),yes)
|
||||||
SUBDIRS += icu
|
SUBDIRS += icu
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Test suites that are not safe by default but can be run if selected
|
|
||||||
# by the user via the whitespace-separated list in variable
|
|
||||||
# PG_TEST_EXTRA:
|
|
||||||
ifeq ($(with_gssapi),yes)
|
ifeq ($(with_gssapi),yes)
|
||||||
ifneq (,$(filter kerberos,$(PG_TEST_EXTRA)))
|
|
||||||
SUBDIRS += kerberos
|
SUBDIRS += kerberos
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
ifeq ($(with_ldap),yes)
|
ifeq ($(with_ldap),yes)
|
||||||
ifneq (,$(filter ldap,$(PG_TEST_EXTRA)))
|
|
||||||
SUBDIRS += ldap
|
SUBDIRS += ldap
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
ifeq ($(with_ssl),openssl)
|
ifeq ($(with_ssl),openssl)
|
||||||
ifneq (,$(filter ssl,$(PG_TEST_EXTRA)))
|
|
||||||
SUBDIRS += ssl
|
SUBDIRS += ssl
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
# Test suites that are not safe by default but can be run if selected
|
||||||
|
# by the user via the whitespace-separated list in variable PG_TEST_EXTRA.
|
||||||
|
# Export PG_TEST_EXTRA to check it in individual tap tests.
|
||||||
|
export PG_TEST_EXTRA
|
||||||
|
|
||||||
# We don't build or execute these by default, but we do want "make
|
# We don't build or execute these by default, but we do want "make
|
||||||
# clean" etc to recurse into them. (We must filter out those that we
|
# clean" etc to recurse into them. (We must filter out those that we
|
||||||
|
@@ -25,6 +25,10 @@ if ($ENV{with_gssapi} ne 'yes')
|
|||||||
{
|
{
|
||||||
plan skip_all => 'GSSAPI/Kerberos not supported by this build';
|
plan skip_all => 'GSSAPI/Kerberos not supported by this build';
|
||||||
}
|
}
|
||||||
|
elsif ($ENV{PG_TEST_EXTRA} !~ /\bkerberos\b/)
|
||||||
|
{
|
||||||
|
plan skip_all => 'Potentially unsafe test GSSAPI/Kerberos not enabled in PG_TEST_EXTRA';
|
||||||
|
}
|
||||||
|
|
||||||
my ($krb5_bin_dir, $krb5_sbin_dir);
|
my ($krb5_bin_dir, $krb5_sbin_dir);
|
||||||
|
|
||||||
|
@@ -16,6 +16,10 @@ if ($ENV{with_ldap} ne 'yes')
|
|||||||
{
|
{
|
||||||
plan skip_all => 'LDAP not supported by this build';
|
plan skip_all => 'LDAP not supported by this build';
|
||||||
}
|
}
|
||||||
|
elsif ($ENV{PG_TEST_EXTRA} !~ /\bldap\b/)
|
||||||
|
{
|
||||||
|
plan skip_all => 'Potentially unsafe test LDAP not enabled in PG_TEST_EXTRA';
|
||||||
|
}
|
||||||
elsif ($^O eq 'darwin' && -d '/usr/local/opt/openldap')
|
elsif ($^O eq 'darwin' && -d '/usr/local/opt/openldap')
|
||||||
{
|
{
|
||||||
# typical paths for Homebrew
|
# typical paths for Homebrew
|
||||||
|
@@ -17,6 +17,10 @@ if ($ENV{with_ssl} ne 'openssl')
|
|||||||
{
|
{
|
||||||
plan skip_all => 'OpenSSL not supported by this build';
|
plan skip_all => 'OpenSSL not supported by this build';
|
||||||
}
|
}
|
||||||
|
elsif ($ENV{PG_TEST_EXTRA} !~ /ssl/)
|
||||||
|
{
|
||||||
|
plan skip_all => 'Potentially unsafe test SSL not enabled in PG_TEST_EXTRA';
|
||||||
|
}
|
||||||
|
|
||||||
my $ssl_server = SSL::Server->new();
|
my $ssl_server = SSL::Server->new();
|
||||||
|
|
||||||
|
@@ -20,6 +20,10 @@ if ($ENV{with_ssl} ne 'openssl')
|
|||||||
{
|
{
|
||||||
plan skip_all => 'OpenSSL not supported by this build';
|
plan skip_all => 'OpenSSL not supported by this build';
|
||||||
}
|
}
|
||||||
|
elsif ($ENV{PG_TEST_EXTRA} !~ /\bssl\b/)
|
||||||
|
{
|
||||||
|
plan skip_all => 'Potentially unsafe test SSL not enabled in PG_TEST_EXTRA';
|
||||||
|
}
|
||||||
|
|
||||||
my $ssl_server = SSL::Server->new();
|
my $ssl_server = SSL::Server->new();
|
||||||
|
|
||||||
|
@@ -18,6 +18,10 @@ if ($ENV{with_ssl} ne 'openssl')
|
|||||||
{
|
{
|
||||||
plan skip_all => 'OpenSSL not supported by this build';
|
plan skip_all => 'OpenSSL not supported by this build';
|
||||||
}
|
}
|
||||||
|
elsif ($ENV{PG_TEST_EXTRA} !~ /\bssl\b/)
|
||||||
|
{
|
||||||
|
plan skip_all => 'Potentially unsafe test SSL not enabled in PG_TEST_EXTRA';
|
||||||
|
}
|
||||||
|
|
||||||
#### Some configuration
|
#### Some configuration
|
||||||
my $ssl_server = SSL::Server->new();
|
my $ssl_server = SSL::Server->new();
|
||||||
|
Reference in New Issue
Block a user