Hi, On Thu, 12 Sept 2024 at 12:35, Ashutosh Bapat <ashutosh.bapat....@gmail.com> wrote: > > Here's what I understand, please correct me: The code in meson.build > is only called at the time of setup; not during meson test. Hence we > can not check the existence of a runtime environment variable in that > file. The things in test_env override those set at run time. So we > save it as an argument to --pg_test_extra and then use it if > PG_TEST_EXTRA is not set at run time. I tried to find if there's some > other place to store "environment variables that can be overriden at > runtime" but I can not find it. So it looks like this is the best we > can do for now.
Yes, that is exactly what is happening. > If it comes to a point where there are more such environment variables > that need to be passed, probably we will pass a key-value string of > those to testwrap. For now, for a single variable, this looks ok. Yes, that would be better. > > > +# If PG_TEST_EXTRA is not set in the environment, then look for its Meson > > > +# configure option. > > > +if "PG_TEST_EXTRA" not in os.environ and args.pg_test_extra: > > > + env_dict["PG_TEST_EXTRA"] = args.pg_test_extra > > > + > > > > > > If somebody looks at just these lines, it's not clear how > > > PG_TEST_EXTRA is passed to the test environment if it's available in > > > os.environ. So one has to understand that env_dict is the test > > > environment. If that's so, the code and comment rewritten as below > > > makes more sense to me. What do you think? > > > > > > # If PG_TEST_EXTRA is not already part of the test environment, check if > > > it's > > > # passed via program argument --pg_test_extra. Thus we also override > > > # configuration time value by run time value of PG_TEST_EXTRA. > > > if "PG_TEST_EXTRA" not in env_dict and args.pg_test_extra: > > > env_dict["PG_TEST_EXTRA"] = args.pg_test_extra > > > > I think your suggestion is better, done. > > I didn't see the expected change. I was talking about something like attached. > > Also > 1. I have also made changes to the comment, > 2. renamed the argument --pg_test_extra to --pg-test-extra using > convention similar to other arguments. > 3. few other cosmetic changes. > > Please review and incorporate those in the respective patches and > tests. Sorry for a single diff. > > Once this is done, I think we can mark this CF entry as RFC. Thanks for the changes. I applied all of them in respective patches. -- Regards, Nazir Bilal Yavuz Microsoft
From 035fe94107fe2c03647a4bb3ec4f0b3d1673e004 Mon Sep 17 00:00:00 2001 From: Nazir Bilal Yavuz <byavu...@gmail.com> Date: Wed, 11 Sep 2024 15:41:27 +0300 Subject: [PATCH v5 1/2] Make PG_TEST_EXTRA env variable override its Meson configure option Since PG_TEST_EXTRA configure option is set while configuring Meson, each change on PG_TEST_EXTRA needs reconfigure and this is costly. So, first try to use PG_TEST_EXTRA from environment. If it does not exist, then try to use it from its configure option in Meson builds. After the above change, Meson builds are able to get PG_TEST_EXTRA from environment and this overrides the configure option. PG_TEST_EXTRA environment variable is set at the top of the .cirrus.tasks.yml file. So, PG_TEXT_EXTRA in configure scripts became useless and were removed because of that. --- doc/src/sgml/installation.sgml | 6 ++++-- .cirrus.tasks.yml | 6 +----- meson.build | 11 ++++++----- meson_options.txt | 2 +- src/tools/testwrap | 10 ++++++++++ 5 files changed, 22 insertions(+), 13 deletions(-) diff --git a/doc/src/sgml/installation.sgml b/doc/src/sgml/installation.sgml index ff9abd4649d..7c481e07e98 100644 --- a/doc/src/sgml/installation.sgml +++ b/doc/src/sgml/installation.sgml @@ -3073,8 +3073,10 @@ ninja install <listitem> <para> Enable test suites which require special software to run. This option - accepts arguments via a whitespace-separated list. See <xref - linkend="regress-additional"/> for details. + accepts arguments via a whitespace-separated list. Please note that + this configure option is overridden by PG_TEST_EXTRA environment + variable if it is set. See <xref linkend="regress-additional"/> for + details. </para> </listitem> </varlistentry> diff --git a/.cirrus.tasks.yml b/.cirrus.tasks.yml index 90cb95c8681..fc413eb11ef 100644 --- a/.cirrus.tasks.yml +++ b/.cirrus.tasks.yml @@ -175,7 +175,6 @@ task: --buildtype=debug \ -Dcassert=true -Dinjection_points=true \ -Duuid=bsd -Dtcl_version=tcl86 -Ddtrace=auto \ - -DPG_TEST_EXTRA="$PG_TEST_EXTRA" \ -Dextra_lib_dirs=/usr/local/lib -Dextra_include_dirs=/usr/local/include/ \ build EOF @@ -364,7 +363,6 @@ task: --buildtype=debug \ -Dcassert=true -Dinjection_points=true \ ${LINUX_MESON_FEATURES} \ - -DPG_TEST_EXTRA="$PG_TEST_EXTRA" \ build EOF @@ -380,7 +378,6 @@ task: -Dllvm=disabled \ --pkg-config-path /usr/lib/i386-linux-gnu/pkgconfig/ \ -DPERL=perl5.36-i386-linux-gnu \ - -DPG_TEST_EXTRA="$PG_TEST_EXTRA" \ build-32 EOF @@ -502,7 +499,6 @@ task: -Dextra_lib_dirs=/opt/local/lib \ -Dcassert=true -Dinjection_points=true \ -Duuid=e2fs -Ddtrace=auto \ - -DPG_TEST_EXTRA="$PG_TEST_EXTRA" \ build build_script: ninja -C build -j${BUILD_JOBS} @@ -574,7 +570,7 @@ task: # Use /DEBUG:FASTLINK to avoid high memory usage during linking configure_script: | vcvarsall x64 - meson setup --backend ninja --buildtype debug -Dc_link_args=/DEBUG:FASTLINK -Dcassert=true -Dinjection_points=true -Db_pch=true -Dextra_lib_dirs=c:\openssl\1.1\lib -Dextra_include_dirs=c:\openssl\1.1\include -DTAR=%TAR% -DPG_TEST_EXTRA="%PG_TEST_EXTRA%" build + meson setup --backend ninja --buildtype debug -Dc_link_args=/DEBUG:FASTLINK -Dcassert=true -Dinjection_points=true -Db_pch=true -Dextra_lib_dirs=c:\openssl\1.1\lib -Dextra_include_dirs=c:\openssl\1.1\include -DTAR=%TAR% build build_script: | vcvarsall x64 diff --git a/meson.build b/meson.build index 4764b09266e..9d1d8847af3 100644 --- a/meson.build +++ b/meson.build @@ -3322,11 +3322,6 @@ test_env.set('PG_REGRESS', pg_regress.full_path()) test_env.set('REGRESS_SHLIB', regress_module.full_path()) test_env.set('INITDB_TEMPLATE', test_initdb_template) -# 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 so it can be checked in individual tap tests. -test_env.set('PG_TEST_EXTRA', get_option('PG_TEST_EXTRA')) - # Add the temporary installation to the library search path on platforms where # that works (everything but windows, basically). On windows everything # library-like gets installed into bindir, solving that issue. @@ -3390,6 +3385,12 @@ foreach test_dir : tests testwrap, '--basedir', meson.build_root(), '--srcdir', test_dir['sd'], + # 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 so it can be checked in individual tap tests. + # This configure option is overridden by PG_TEST_EXTRA environment variable + # if it exists. + '--pg-test-extra', get_option('PG_TEST_EXTRA'), ] foreach kind, v : test_dir diff --git a/meson_options.txt b/meson_options.txt index b9421557606..38935196394 100644 --- a/meson_options.txt +++ b/meson_options.txt @@ -47,7 +47,7 @@ option('injection_points', type: 'boolean', value: false, description: 'Enable injection points') option('PG_TEST_EXTRA', type: 'string', value: '', - description: 'Enable selected extra tests') + description: 'Enable selected extra tests. Overridden by PG_TEST_EXTRA environment variable.') option('PG_GIT_REVISION', type: 'string', value: 'HEAD', description: 'git revision to be packaged by pgdist target') diff --git a/src/tools/testwrap b/src/tools/testwrap index 9a270beb72d..8ae8fb79ba7 100755 --- a/src/tools/testwrap +++ b/src/tools/testwrap @@ -13,6 +13,7 @@ parser.add_argument('--basedir', help='base directory of test', type=str) parser.add_argument('--testgroup', help='test group', type=str) parser.add_argument('--testname', help='test name', type=str) parser.add_argument('--skip', help='skip test (with reason)', type=str) +parser.add_argument('--pg-test-extra', help='extra tests', type=str) parser.add_argument('test_command', nargs='*') args = parser.parse_args() @@ -41,6 +42,15 @@ env_dict = {**os.environ, 'TESTDATADIR': os.path.join(testdir, 'data'), 'TESTLOGDIR': os.path.join(testdir, 'log')} + +# The configuration time value of PG_TEST_EXTRA is supplied via arguement +# --pg-test-extra. But it can be overridden by environment variable +# PG_TEST_EXTRA at the time of running a test. Hence use value from arguments +# only if PG_TEST_EXTRA is not set in the test environment, which already +# contains all the environment variables at the time of running the test. +if "PG_TEST_EXTRA" not in env_dict and args.pg_test_extra: + env_dict["PG_TEST_EXTRA"] = args.pg_test_extra + sp = subprocess.Popen(args.test_command, env=env_dict, stdout=subprocess.PIPE) # Meson categorizes a passing TODO test point as bad # (https://github.com/mesonbuild/meson/issues/13183). Remove the TODO -- 2.45.2
From 8326585575b7571e227392269afae272fdb3eb28 Mon Sep 17 00:00:00 2001 From: Jacob Champion <jacob.champ...@enterprisedb.com> Date: Wed, 11 Sep 2024 15:46:33 +0300 Subject: [PATCH v5 2/2] Add PG_TEST_EXTRA configure option to the make builds The Meson builds have PG_TEST_EXTRA as a configure-time option, which was not available in the make builds. To ensure both build systems are in sync, PG_TEST_EXTRA is now added as a configure-time option. It can be set like this: ./configure PG_TEST_EXTRA="kerberos, ssl, ..." Note that to preserve the old behavior, this configure-time option is overridden by the PG_TEST_EXTRA environment variable. --- src/test/Makefile | 5 ----- configure | 4 ++++ configure.ac | 2 ++ src/Makefile.global.in | 10 ++++++++++ 4 files changed, 16 insertions(+), 5 deletions(-) diff --git a/src/test/Makefile b/src/test/Makefile index dbd3192874d..fc42f1db2b9 100644 --- a/src/test/Makefile +++ b/src/test/Makefile @@ -27,11 +27,6 @@ ifeq ($(with_ssl),openssl) SUBDIRS += ssl 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 # clean" etc to recurse into them. (We must filter out those that we # have conditionally included into SUBDIRS above, else there will be diff --git a/configure b/configure index 53c8a1f2bad..31e547816f3 100755 --- a/configure +++ b/configure @@ -764,6 +764,7 @@ LDFLAGS CFLAGS CC enable_injection_points +PG_TEST_EXTRA enable_tap_tests enable_dtrace DTRACEFLAGS @@ -880,6 +881,7 @@ enable_largefile ac_precious_vars='build_alias host_alias target_alias +PG_TEST_EXTRA CC CFLAGS LDFLAGS @@ -1587,6 +1589,8 @@ Optional Packages: --with-openssl obsolete spelling of --with-ssl=openssl Some influential environment variables: + PG_TEST_EXTRA + enable selected extra tests CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L<lib dir> if you have libraries in a diff --git a/configure.ac b/configure.ac index 6a35b2880bf..cd63ed803af 100644 --- a/configure.ac +++ b/configure.ac @@ -236,6 +236,8 @@ AC_SUBST(enable_dtrace) PGAC_ARG_BOOL(enable, tap-tests, no, [enable TAP tests (requires Perl and IPC::Run)]) AC_SUBST(enable_tap_tests) +AC_ARG_VAR(PG_TEST_EXTRA, + [Enable selected extra tests. Overridden by PG_TEST_EXTRA environment variable.]) # # Injection points diff --git a/src/Makefile.global.in b/src/Makefile.global.in index 42f50b49761..4859343153b 100644 --- a/src/Makefile.global.in +++ b/src/Makefile.global.in @@ -642,6 +642,16 @@ submake-libpgfeutils: | submake-generated-headers # # Testing support +# Store any configure-time setting for PG_TEST_EXTRA, but let environment +# variables override it to maintain the historical behavior of the tests. +# (Standard `=` assignment would require devs to use a commandline option.) +# This is skipped in PGXS mode to keep the setting from escaping into other +# projects' builds. +ifndef PGXS +PG_TEST_EXTRA ?= @PG_TEST_EXTRA@ +export PG_TEST_EXTRA +endif + ifneq ($(USE_MODULE_DB),) PL_TESTDB = pl_regression_$(NAME) ifneq ($(MODULE_big),) -- 2.45.2