Commit dcae5fac authored by Peter Eisentraut's avatar Peter Eisentraut

Improve speed of make check-world

Before, make check-world would create a new temporary installation for
each test suite, which is slow and wasteful.  Instead, we now create one
test installation that is used by all test suites that are part of a
make run.

The management of the temporary installation is removed from pg_regress
and handled in the makefiles.  This allows for better control, and
unifies the code with that of test suites not run through pg_regress.

review and msvc support by Michael Paquier <michael.paquier@gmail.com>

more review by Fabien Coelho <coelho@cri.ensmp.fr>
parent 50a16e30
...@@ -36,3 +36,4 @@ lib*.pc ...@@ -36,3 +36,4 @@ lib*.pc
/pgsql.sln.cache /pgsql.sln.cache
/Debug/ /Debug/
/Release/ /Release/
/tmp_install/
...@@ -47,6 +47,7 @@ $(call recurse,distprep,doc src config contrib) ...@@ -47,6 +47,7 @@ $(call recurse,distprep,doc src config contrib)
# it's not built by default # it's not built by default
$(call recurse,clean,doc contrib src config) $(call recurse,clean,doc contrib src config)
clean: clean:
rm -rf tmp_install/
# Garbage from autoconf: # Garbage from autoconf:
@rm -rf autom4te.cache/ @rm -rf autom4te.cache/
......
...@@ -7,7 +7,7 @@ DATA = earthdistance--1.0.sql earthdistance--unpackaged--1.0.sql ...@@ -7,7 +7,7 @@ DATA = earthdistance--1.0.sql earthdistance--unpackaged--1.0.sql
PGFILEDESC = "earthdistance - calculate distances on the surface of the Earth" PGFILEDESC = "earthdistance - calculate distances on the surface of the Earth"
REGRESS = earthdistance REGRESS = earthdistance
REGRESS_OPTS = --extra-install=contrib/cube EXTRA_INSTALL = contrib/cube
LDFLAGS_SL += $(filter -lm, $(LIBS)) LDFLAGS_SL += $(filter -lm, $(LIBS))
......
...@@ -39,35 +39,33 @@ submake-test_decoding: ...@@ -39,35 +39,33 @@ submake-test_decoding:
REGRESSCHECKS=ddl rewrite toast permissions decoding_in_xact decoding_into_rel binary prepared REGRESSCHECKS=ddl rewrite toast permissions decoding_in_xact decoding_into_rel binary prepared
regresscheck: all | submake-regress submake-test_decoding regresscheck: all | submake-regress submake-test_decoding temp-install
$(MKDIR_P) regression_output $(MKDIR_P) regression_output
$(pg_regress_check) \ $(pg_regress_check) \
--temp-config $(top_srcdir)/contrib/test_decoding/logical.conf \ --temp-config $(top_srcdir)/contrib/test_decoding/logical.conf \
--temp-install=./tmp_check \ --temp-instance=./tmp_check \
--extra-install=contrib/test_decoding \
--outputdir=./regression_output \ --outputdir=./regression_output \
$(REGRESSCHECKS) $(REGRESSCHECKS)
regresscheck-install-force: | submake-regress submake-test_decoding regresscheck-install-force: | submake-regress submake-test_decoding temp-install
$(pg_regress_installcheck) \ $(pg_regress_installcheck) \
--extra-install=contrib/test_decoding \
$(REGRESSCHECKS) $(REGRESSCHECKS)
ISOLATIONCHECKS=mxact delayed_startup ondisk_startup concurrent_ddl_dml ISOLATIONCHECKS=mxact delayed_startup ondisk_startup concurrent_ddl_dml
isolationcheck: all | submake-isolation submake-test_decoding isolationcheck: all | submake-isolation submake-test_decoding temp-install
$(MKDIR_P) isolation_output $(MKDIR_P) isolation_output
$(pg_isolation_regress_check) \ $(pg_isolation_regress_check) \
--temp-config $(top_srcdir)/contrib/test_decoding/logical.conf \ --temp-config $(top_srcdir)/contrib/test_decoding/logical.conf \
--extra-install=contrib/test_decoding \
--outputdir=./isolation_output \ --outputdir=./isolation_output \
$(ISOLATIONCHECKS) $(ISOLATIONCHECKS)
isolationcheck-install-force: all | submake-isolation submake-test_decoding isolationcheck-install-force: all | submake-isolation submake-test_decoding temp-install
$(pg_isolation_regress_installcheck) \ $(pg_isolation_regress_installcheck) \
--extra-install=contrib/test_decoding \
$(ISOLATIONCHECKS) $(ISOLATIONCHECKS)
PHONY: submake-test_decoding submake-regress check \ PHONY: submake-test_decoding submake-regress check \
regresscheck regresscheck-install-force \ regresscheck regresscheck-install-force \
isolationcheck isolationcheck-install-force isolationcheck isolationcheck-install-force
temp-install: EXTRA_INSTALL=contrib/test_decoding
...@@ -43,6 +43,7 @@ MAJORVERSION = @PG_MAJORVERSION@ ...@@ -43,6 +43,7 @@ MAJORVERSION = @PG_MAJORVERSION@
# (PGXS VPATH support is handled separately in pgxs.mk) # (PGXS VPATH support is handled separately in pgxs.mk)
ifndef PGXS ifndef PGXS
vpath_build = @vpath_build@ vpath_build = @vpath_build@
abs_top_builddir = @abs_top_builddir@
abs_top_srcdir = @abs_top_srcdir@ abs_top_srcdir = @abs_top_srcdir@
ifneq ($(vpath_build),yes) ifneq ($(vpath_build),yes)
...@@ -301,6 +302,17 @@ BZIP2 = bzip2 ...@@ -301,6 +302,17 @@ BZIP2 = bzip2
# Testing # Testing
check: temp-install
.PHONY: temp-install
temp-install:
ifeq ($(MAKELEVEL),0)
rm -rf '$(abs_top_builddir)'/tmp_install
$(MKDIR_P) '$(abs_top_builddir)'/tmp_install/log
$(MAKE) -C '$(top_builddir)' DESTDIR='$(abs_top_builddir)'/tmp_install install >'$(abs_top_builddir)'/tmp_install/log/install.log 2>&1
endif
for extra in $(EXTRA_INSTALL); do $(MAKE) -C '$(top_builddir)'/$$extra DESTDIR='$(abs_top_builddir)'/tmp_install install >>'$(abs_top_builddir)'/tmp_install/log/install.log 2>&1 || exit; done
PROVE = @PROVE@ PROVE = @PROVE@
PG_PROVE_FLAGS = -I $(top_srcdir)/src/test/perl/ PG_PROVE_FLAGS = -I $(top_srcdir)/src/test/perl/
PROVE_FLAGS = --verbose PROVE_FLAGS = --verbose
...@@ -315,6 +327,10 @@ define ld_library_path_var ...@@ -315,6 +327,10 @@ define ld_library_path_var
$(if $(filter $(PORTNAME),darwin),DYLD_LIBRARY_PATH,$(if $(filter $(PORTNAME),aix),LIBPATH,LD_LIBRARY_PATH)) $(if $(filter $(PORTNAME),darwin),DYLD_LIBRARY_PATH,$(if $(filter $(PORTNAME),aix),LIBPATH,LD_LIBRARY_PATH))
endef endef
define with_temp_install
PATH="$(abs_top_builddir)/tmp_install$(bindir):$$PATH" $(call add_to_path,$(ld_library_path_var),$(abs_top_builddir)/tmp_install$(libdir))
endef
ifeq ($(enable_tap_tests),yes) ifeq ($(enable_tap_tests),yes)
define prove_installcheck define prove_installcheck
...@@ -322,9 +338,7 @@ cd $(srcdir) && TESTDIR='$(CURDIR)' PATH="$(bindir):$$PATH" PGPORT='6$(DEF_PGPOR ...@@ -322,9 +338,7 @@ cd $(srcdir) && TESTDIR='$(CURDIR)' PATH="$(bindir):$$PATH" PGPORT='6$(DEF_PGPOR
endef endef
define prove_check define prove_check
$(MKDIR_P) tmp_check/log cd $(srcdir) && TESTDIR='$(CURDIR)' $(with_temp_install) PGPORT='6$(DEF_PGPORT)' top_builddir='$(CURDIR)/$(top_builddir)' $(PROVE) $(PG_PROVE_FLAGS) $(PROVE_FLAGS) t/*.pl
$(MAKE) -C $(top_builddir) DESTDIR='$(CURDIR)'/tmp_check/install install >'$(CURDIR)'/tmp_check/log/install.log 2>&1
cd $(srcdir) && TESTDIR='$(CURDIR)' PATH="$(CURDIR)/tmp_check/install$(bindir):$$PATH" $(call add_to_path,$(ld_library_path_var),$(CURDIR)/tmp_check/install$(libdir)) top_builddir='$(CURDIR)/$(top_builddir)' PGPORT='6$(DEF_PGPORT)' $(PROVE) $(PG_PROVE_FLAGS) $(PROVE_FLAGS) t/*.pl
endef endef
else else
...@@ -495,13 +509,13 @@ endif ...@@ -495,13 +509,13 @@ endif
pg_regress_locale_flags = $(if $(ENCODING),--encoding=$(ENCODING)) $(NOLOCALE) pg_regress_locale_flags = $(if $(ENCODING),--encoding=$(ENCODING)) $(NOLOCALE)
pg_regress_check = $(top_builddir)/src/test/regress/pg_regress --inputdir=$(srcdir) --temp-install=./tmp_check --top-builddir=$(top_builddir) $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS) pg_regress_check = $(with_temp_install) $(top_builddir)/src/test/regress/pg_regress --inputdir=$(srcdir) --temp-instance=./tmp_check --bindir= $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS)
pg_regress_installcheck = $(top_builddir)/src/test/regress/pg_regress --inputdir=$(srcdir) --psqldir='$(PSQLDIR)' $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS) pg_regress_installcheck = $(top_builddir)/src/test/regress/pg_regress --inputdir=$(srcdir) --bindir='$(bindir)' $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS)
pg_regress_clean_files = results/ regression.diffs regression.out tmp_check/ log/ pg_regress_clean_files = results/ regression.diffs regression.out tmp_check/ log/
pg_isolation_regress_check = $(top_builddir)/src/test/isolation/pg_isolation_regress --inputdir=$(srcdir) --temp-install=./tmp_check --top-builddir=$(top_builddir) $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS) pg_isolation_regress_check = $(with_temp_install) $(top_builddir)/src/test/isolation/pg_isolation_regress --inputdir=$(srcdir) --temp-instance=./tmp_check --bindir= $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS)
pg_isolation_regress_installcheck = $(top_builddir)/src/test/isolation/pg_isolation_regress --inputdir=$(srcdir) --top-builddir=$(top_builddir) $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS) pg_isolation_regress_installcheck = $(top_builddir)/src/test/isolation/pg_isolation_regress --inputdir=$(srcdir) $(pg_regress_locale_flags) $(EXTRA_REGRESS_OPTS)
########################################################################## ##########################################################################
# #
...@@ -683,7 +697,7 @@ endif ...@@ -683,7 +697,7 @@ endif
define _create_recursive_target define _create_recursive_target
.PHONY: $(1)-$(2)-recurse .PHONY: $(1)-$(2)-recurse
$(1): $(1)-$(2)-recurse $(1): $(1)-$(2)-recurse
$(1)-$(2)-recurse: $(1)-$(2)-recurse: $(if $(filter check, $(3)), temp-install)
$$(MAKE) -C $(2) $(3) $$(MAKE) -C $(2) $(3)
endef endef
# Note that the use of $$ on the last line above is important; we want # Note that the use of $$ on the last line above is important; we want
......
...@@ -86,7 +86,7 @@ if [ "$1" = '--install' ]; then ...@@ -86,7 +86,7 @@ if [ "$1" = '--install' ]; then
# use psql from the proper installation directory, which might # use psql from the proper installation directory, which might
# be outdated or missing. But don't override anything else that's # be outdated or missing. But don't override anything else that's
# already in EXTRA_REGRESS_OPTS. # already in EXTRA_REGRESS_OPTS.
EXTRA_REGRESS_OPTS="$EXTRA_REGRESS_OPTS --psqldir='$bindir'" EXTRA_REGRESS_OPTS="$EXTRA_REGRESS_OPTS --bindir='$bindir'"
export EXTRA_REGRESS_OPTS export EXTRA_REGRESS_OPTS
fi fi
......
...@@ -11,14 +11,10 @@ override CPPFLAGS := \ ...@@ -11,14 +11,10 @@ override CPPFLAGS := \
'-I$(top_builddir)/src/port' \ '-I$(top_builddir)/src/port' \
'-I$(top_srcdir)/src/test/regress' \ '-I$(top_srcdir)/src/test/regress' \
'-DHOST_TUPLE="$(host_tuple)"' \ '-DHOST_TUPLE="$(host_tuple)"' \
'-DMAKEPROG="$(MAKE)"' \
'-DSHELLPROG="$(SHELL)"' \ '-DSHELLPROG="$(SHELL)"' \
'-DDLSUFFIX="$(DLSUFFIX)"' \ '-DDLSUFFIX="$(DLSUFFIX)"' \
$(CPPFLAGS) $(CPPFLAGS)
# where to find psql for testing an existing installation
PSQLDIR = $(bindir)
# default encoding for regression tests # default encoding for regression tests
ENCODING = SQL_ASCII ENCODING = SQL_ASCII
...@@ -82,11 +78,11 @@ endif ...@@ -82,11 +78,11 @@ endif
REGRESS_OPTS = --dbname=regress1,connectdb --create-role=connectuser,connectdb $(EXTRA_REGRESS_OPTS) REGRESS_OPTS = --dbname=regress1,connectdb --create-role=connectuser,connectdb $(EXTRA_REGRESS_OPTS)
check: all check: all
./pg_regress $(REGRESS_OPTS) --top-builddir=$(top_builddir) --temp-install=./tmp_check $(pg_regress_locale_flags) $(THREAD) --schedule=$(srcdir)/ecpg_schedule $(with_temp_install) ./pg_regress $(REGRESS_OPTS) --temp-instance=./tmp_check --bindir= $(pg_regress_locale_flags) $(THREAD) --schedule=$(srcdir)/ecpg_schedule
# the same options, but with --listen-on-tcp # the same options, but with --listen-on-tcp
checktcp: all checktcp: all
./pg_regress $(REGRESS_OPTS) --top-builddir=$(top_builddir) --temp-install=./tmp_check $(pg_regress_locale_flags) $(THREAD) --schedule=$(srcdir)/ecpg_schedule_tcp --host=localhost $(with_temp_install) ./pg_regress $(REGRESS_OPTS) --temp-instance=./tmp_check --bindir= $(pg_regress_locale_flags) $(THREAD) --schedule=$(srcdir)/ecpg_schedule_tcp --host=localhost
installcheck: all installcheck: all
./pg_regress $(REGRESS_OPTS) --psqldir='$(PSQLDIR)' --top-builddir=$(top_builddir) $(pg_regress_locale_flags) $(THREAD) --schedule=$(srcdir)/ecpg_schedule ./pg_regress $(REGRESS_OPTS) --bindir='$(bindir)' $(pg_regress_locale_flags) $(THREAD) --schedule=$(srcdir)/ecpg_schedule
...@@ -258,9 +258,6 @@ else ...@@ -258,9 +258,6 @@ else
REGRESS_OPTS += --dbname=$(CONTRIB_TESTDB) REGRESS_OPTS += --dbname=$(CONTRIB_TESTDB)
endif endif
# where to find psql for running the tests
PSQLDIR = $(bindir)
# When doing a VPATH build, must copy over the data files so that the # When doing a VPATH build, must copy over the data files so that the
# driver script can find them. We have to use an absolute path for # driver script can find them. We have to use an absolute path for
# the targets, because otherwise make will try to locate the missing # the targets, because otherwise make will try to locate the missing
...@@ -295,7 +292,9 @@ check: ...@@ -295,7 +292,9 @@ check:
@echo 'Do "$(MAKE) install", then "$(MAKE) installcheck" instead.' @echo 'Do "$(MAKE) install", then "$(MAKE) installcheck" instead.'
else else
check: all submake $(REGRESS_PREP) check: all submake $(REGRESS_PREP)
$(pg_regress_check) --extra-install=$(subdir) $(REGRESS_OPTS) $(REGRESS) $(pg_regress_check) $(REGRESS_OPTS) $(REGRESS)
temp-install: EXTRA_INSTALL=$(subdir)
endif endif
endif # REGRESS endif # REGRESS
......
...@@ -69,8 +69,6 @@ ifeq ($(shell $(PERL) -V:usemultiplicity), usemultiplicity='define';) ...@@ -69,8 +69,6 @@ ifeq ($(shell $(PERL) -V:usemultiplicity), usemultiplicity='define';)
REGRESS += plperl_plperlu REGRESS += plperl_plperlu
endif endif
endif endif
# where to find psql for running the tests
PSQLDIR = $(bindir)
# where to find xsubpp for building XS. # where to find xsubpp for building XS.
XSUBPPDIR = $(shell $(PERL) -e 'use List::Util qw(first); print first { -r "$$_/ExtUtils/xsubpp" } @INC') XSUBPPDIR = $(shell $(PERL) -e 'use List::Util qw(first); print first { -r "$$_/ExtUtils/xsubpp" } @INC')
......
...@@ -115,9 +115,6 @@ REGRESS = \ ...@@ -115,9 +115,6 @@ REGRESS = \
REGRESS_PLPYTHON3_MANGLE := $(REGRESS) REGRESS_PLPYTHON3_MANGLE := $(REGRESS)
# where to find psql for running the tests
PSQLDIR = $(bindir)
include $(top_srcdir)/src/Makefile.shlib include $(top_srcdir)/src/Makefile.shlib
all: all-lib all: all-lib
......
...@@ -45,8 +45,6 @@ DATA = pltcl.control pltcl--1.0.sql pltcl--unpackaged--1.0.sql \ ...@@ -45,8 +45,6 @@ DATA = pltcl.control pltcl--1.0.sql pltcl--unpackaged--1.0.sql \
REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-extension=pltcl REGRESS_OPTS = --dbname=$(PL_TESTDB) --load-extension=pltcl
REGRESS = pltcl_setup pltcl_queries REGRESS = pltcl_setup pltcl_queries
# where to find psql for running the tests
PSQLDIR = $(bindir)
# Tcl on win32 ships with import libraries only for Microsoft Visual C++, # Tcl on win32 ships with import libraries only for Microsoft Visual C++,
# which are not compatible with mingw gcc. Therefore we need to build a # which are not compatible with mingw gcc. Therefore we need to build a
......
...@@ -9,9 +9,6 @@ subdir = src/test/isolation ...@@ -9,9 +9,6 @@ subdir = src/test/isolation
top_builddir = ../../.. top_builddir = ../../..
include $(top_builddir)/src/Makefile.global include $(top_builddir)/src/Makefile.global
# where to find psql for testing an existing installation
PSQLDIR = $(bindir)
override CPPFLAGS := -I$(srcdir) -I$(libpq_srcdir) -I$(srcdir)/../regress $(CPPFLAGS) override CPPFLAGS := -I$(srcdir) -I$(libpq_srcdir) -I$(srcdir)/../regress $(CPPFLAGS)
OBJS = specparse.o isolationtester.o $(WIN32RES) OBJS = specparse.o isolationtester.o $(WIN32RES)
...@@ -55,17 +52,17 @@ maintainer-clean: distclean ...@@ -55,17 +52,17 @@ maintainer-clean: distclean
rm -f specparse.c specscanner.c rm -f specparse.c specscanner.c
installcheck: all installcheck: all
./pg_isolation_regress --psqldir='$(PSQLDIR)' $(EXTRA_REGRESS_OPTS) --inputdir=$(srcdir) --schedule=$(srcdir)/isolation_schedule ./pg_isolation_regress --bindir='$(bindir)' $(EXTRA_REGRESS_OPTS) --inputdir=$(srcdir) --schedule=$(srcdir)/isolation_schedule
check: all check: all
./pg_isolation_regress --temp-install=./tmp_check --inputdir=$(srcdir) --top-builddir=$(top_builddir) $(EXTRA_REGRESS_OPTS) --schedule=$(srcdir)/isolation_schedule $(with_temp_install) ./pg_isolation_regress --temp-instance=./tmp_check --inputdir=$(srcdir) --bindir= $(EXTRA_REGRESS_OPTS) --schedule=$(srcdir)/isolation_schedule
# Versions of the check tests that include the prepared_transactions test # Versions of the check tests that include the prepared_transactions test
# It only makes sense to run these if set up to use prepared transactions, # It only makes sense to run these if set up to use prepared transactions,
# via TEMP_CONFIG for the check case, or via the postgresql.conf for the # via TEMP_CONFIG for the check case, or via the postgresql.conf for the
# installcheck case. # installcheck case.
installcheck-prepared-txns: all installcheck-prepared-txns: all temp-install
./pg_isolation_regress --psqldir='$(PSQLDIR)' $(EXTRA_REGRESS_OPTS) --inputdir=$(srcdir) --schedule=$(srcdir)/isolation_schedule prepared-transactions ./pg_isolation_regress --bindir='$(bindir)' $(EXTRA_REGRESS_OPTS) --inputdir=$(srcdir) --schedule=$(srcdir)/isolation_schedule prepared-transactions
check-prepared-txns: all check-prepared-txns: all temp-install
./pg_isolation_regress --temp-install=./tmp_check $(EXTRA_REGRESS_OPTS) --inputdir=$(srcdir) --top-builddir=$(top_builddir) --schedule=$(srcdir)/isolation_schedule prepared-transactions ./pg_isolation_regress --temp-instance=./tmp_check $(EXTRA_REGRESS_OPTS) --inputdir=$(srcdir) --schedule=$(srcdir)/isolation_schedule prepared-transactions
...@@ -23,9 +23,6 @@ ifdef TEMP_CONFIG ...@@ -23,9 +23,6 @@ ifdef TEMP_CONFIG
TEMP_CONF += --temp-config=$(TEMP_CONFIG) TEMP_CONF += --temp-config=$(TEMP_CONFIG)
endif endif
# where to find psql for testing an existing installation
PSQLDIR = $(bindir)
# maximum simultaneous connections for parallel tests # maximum simultaneous connections for parallel tests
MAXCONNOPT = MAXCONNOPT =
ifdef MAX_CONNECTIONS ifdef MAX_CONNECTIONS
...@@ -34,7 +31,6 @@ endif ...@@ -34,7 +31,6 @@ endif
# stuff to pass into build of pg_regress # stuff to pass into build of pg_regress
EXTRADEFS = '-DHOST_TUPLE="$(host_tuple)"' \ EXTRADEFS = '-DHOST_TUPLE="$(host_tuple)"' \
'-DMAKEPROG="$(MAKE)"' \
'-DSHELLPROG="$(SHELL)"' \ '-DSHELLPROG="$(SHELL)"' \
'-DDLSUFFIX="$(DLSUFFIX)"' '-DDLSUFFIX="$(DLSUFFIX)"'
......
...@@ -45,25 +45,10 @@ typedef struct _resultmap ...@@ -45,25 +45,10 @@ typedef struct _resultmap
} _resultmap; } _resultmap;
/* /*
* Values obtained from pg_config_paths.h and Makefile. The PG installation * Values obtained from Makefile.
* paths are only used in temp_install mode: we use these strings to find
* out where "make install" will put stuff under the temp_install directory.
* In non-temp_install mode, the only thing we need is the location of psql,
* which we expect to find in psqldir, or in the PATH if psqldir isn't given.
*
* XXX Because pg_regress is not installed in bindir, we can't support
* this for relocatable trees as it is. --psqldir would need to be
* specified in those cases.
*/ */
char *bindir = PGBINDIR;
char *libdir = LIBDIR;
char *datadir = PGSHAREDIR;
char *host_platform = HOST_TUPLE; char *host_platform = HOST_TUPLE;
#ifndef WIN32_ONLY_COMPILER
static char *makeprog = MAKEPROG;
#endif
#ifndef WIN32 /* not used in WIN32 case */ #ifndef WIN32 /* not used in WIN32 case */
static char *shellprog = SHELLPROG; static char *shellprog = SHELLPROG;
#endif #endif
...@@ -86,7 +71,7 @@ _stringlist *dblist = NULL; ...@@ -86,7 +71,7 @@ _stringlist *dblist = NULL;
bool debug = false; bool debug = false;
char *inputdir = "."; char *inputdir = ".";
char *outputdir = "."; char *outputdir = ".";
char *psqldir = PGBINDIR; char *bindir = PGBINDIR;
char *launcher = NULL; char *launcher = NULL;
static _stringlist *loadlanguage = NULL; static _stringlist *loadlanguage = NULL;
static _stringlist *loadextension = NULL; static _stringlist *loadextension = NULL;
...@@ -94,9 +79,8 @@ static int max_connections = 0; ...@@ -94,9 +79,8 @@ static int max_connections = 0;
static char *encoding = NULL; static char *encoding = NULL;
static _stringlist *schedulelist = NULL; static _stringlist *schedulelist = NULL;
static _stringlist *extra_tests = NULL; static _stringlist *extra_tests = NULL;
static char *temp_install = NULL; static char *temp_instance = NULL;
static char *temp_config = NULL; static char *temp_config = NULL;
static char *top_builddir = NULL;
static bool nolocale = false; static bool nolocale = false;
static bool use_existing = false; static bool use_existing = false;
static char *hostname = NULL; static char *hostname = NULL;
...@@ -105,7 +89,6 @@ static bool port_specified_by_user = false; ...@@ -105,7 +89,6 @@ static bool port_specified_by_user = false;
static char *dlpath = PKGLIBDIR; static char *dlpath = PKGLIBDIR;
static char *user = NULL; static char *user = NULL;
static _stringlist *extraroles = NULL; static _stringlist *extraroles = NULL;
static _stringlist *extra_install = NULL;
static char *config_auth_datadir = NULL; static char *config_auth_datadir = NULL;
/* internal variables */ /* internal variables */
...@@ -282,8 +265,10 @@ stop_postmaster(void) ...@@ -282,8 +265,10 @@ stop_postmaster(void)
fflush(stderr); fflush(stderr);
snprintf(buf, sizeof(buf), snprintf(buf, sizeof(buf),
"\"%s/pg_ctl\" stop -D \"%s/data\" -s -m fast", "\"%s%spg_ctl\" stop -D \"%s/data\" -s -m fast",
bindir, temp_install); bindir ? bindir : "",
bindir ? "/" : "",
temp_instance);
r = system(buf); r = system(buf);
if (r != 0) if (r != 0)
{ {
...@@ -730,27 +715,6 @@ doputenv(const char *var, const char *val) ...@@ -730,27 +715,6 @@ doputenv(const char *var, const char *val)
putenv(s); putenv(s);
} }
/*
* Set the environment variable "pathname", prepending "addval" to its
* old value (if any).
*/
static void
add_to_path(const char *pathname, char separator, const char *addval)
{
char *oldval = getenv(pathname);
char *newval;
if (!oldval || !oldval[0])
{
/* no previous value */
newval = psprintf("%s=%s", pathname, addval);
}
else
newval = psprintf("%s=%s%c%s", pathname, addval, separator, oldval);
putenv(newval);
}
/* /*
* Prepare environment variables for running regression tests * Prepare environment variables for running regression tests
*/ */
...@@ -825,7 +789,7 @@ initialize_environment(void) ...@@ -825,7 +789,7 @@ initialize_environment(void)
putenv(new_pgoptions); putenv(new_pgoptions);
} }
if (temp_install) if (temp_instance)
{ {
/* /*
* Clear out any environment vars that might cause psql to connect to * Clear out any environment vars that might cause psql to connect to
...@@ -863,49 +827,6 @@ initialize_environment(void) ...@@ -863,49 +827,6 @@ initialize_environment(void)
sprintf(s, "%d", port); sprintf(s, "%d", port);
doputenv("PGPORT", s); doputenv("PGPORT", s);
} }
/*
* GNU make stores some flags in the MAKEFLAGS environment variable to
* pass arguments to its own children. If we are invoked by make,
* that causes the make invoked by us to think its part of the make
* task invoking us, and so it tries to communicate with the toplevel
* make. Which fails.
*
* Unset the variable to protect against such problems. We also reset
* MAKELEVEL to be certain the child doesn't notice the make above us.
*/
unsetenv("MAKEFLAGS");
unsetenv("MAKELEVEL");
/*
* Adjust path variables to point into the temp-install tree
*/
bindir = psprintf("%s/install/%s", temp_install, bindir);
libdir = psprintf("%s/install/%s", temp_install, libdir);
datadir = psprintf("%s/install/%s", temp_install, datadir);
/* psql will be installed into temp-install bindir */
psqldir = bindir;
/*
* Set up shared library paths to include the temp install.
*
* LD_LIBRARY_PATH covers many platforms. DYLD_LIBRARY_PATH works on
* Darwin, and maybe other Mach-based systems. LIBPATH is for AIX.
* Windows needs shared libraries in PATH (only those linked into
* executables, not dlopen'ed ones). Feel free to account for others
* as well.
*/
add_to_path("LD_LIBRARY_PATH", ':', libdir);
add_to_path("DYLD_LIBRARY_PATH", ':', libdir);
add_to_path("LIBPATH", ':', libdir);
#if defined(WIN32)
add_to_path("PATH", ';', libdir);
#elif defined(__CYGWIN__)
add_to_path("PATH", ':', libdir);
#endif
} }
else else
{ {
...@@ -1158,8 +1079,8 @@ psql_command(const char *database, const char *query,...) ...@@ -1158,8 +1079,8 @@ psql_command(const char *database, const char *query,...)
/* And now we can build and execute the shell command */ /* And now we can build and execute the shell command */
snprintf(psql_cmd, sizeof(psql_cmd), snprintf(psql_cmd, sizeof(psql_cmd),
"\"%s%spsql\" -X -c \"%s\" \"%s\"", "\"%s%spsql\" -X -c \"%s\" \"%s\"",
psqldir ? psqldir : "", bindir ? bindir : "",
psqldir ? "/" : "", bindir ? "/" : "",
query_escaped, query_escaped,
database); database);
...@@ -2051,21 +1972,18 @@ help(void) ...@@ -2051,21 +1972,18 @@ help(void)
printf(_(" --outputdir=DIR place output files in DIR (default \".\")\n")); printf(_(" --outputdir=DIR place output files in DIR (default \".\")\n"));
printf(_(" --schedule=FILE use test ordering schedule from FILE\n")); printf(_(" --schedule=FILE use test ordering schedule from FILE\n"));
printf(_(" (can be used multiple times to concatenate)\n")); printf(_(" (can be used multiple times to concatenate)\n"));
printf(_(" --temp-install=DIR create a temporary installation in DIR\n")); printf(_(" --temp-instance=DIR create a temporary instance in DIR\n"));
printf(_(" --use-existing use an existing installation\n")); printf(_(" --use-existing use an existing installation\n")); // XXX
printf(_("\n")); printf(_("\n"));
printf(_("Options for \"temp-install\" mode:\n")); printf(_("Options for \"temp-instance\" mode:\n"));
printf(_(" --extra-install=DIR additional directory to install (e.g., contrib)\n"));
printf(_(" --no-locale use C locale\n")); printf(_(" --no-locale use C locale\n"));
printf(_(" --port=PORT start postmaster on PORT\n")); printf(_(" --port=PORT start postmaster on PORT\n"));
printf(_(" --temp-config=FILE append contents of FILE to temporary config\n")); printf(_(" --temp-config=FILE append contents of FILE to temporary config\n"));
printf(_(" --top-builddir=DIR (relative) path to top level build directory\n"));
printf(_("\n")); printf(_("\n"));
printf(_("Options for using an existing installation:\n")); printf(_("Options for using an existing installation:\n"));
printf(_(" --host=HOST use postmaster running on HOST\n")); printf(_(" --host=HOST use postmaster running on HOST\n"));
printf(_(" --port=PORT use postmaster running at PORT\n")); printf(_(" --port=PORT use postmaster running at PORT\n"));
printf(_(" --user=USER connect as USER\n")); printf(_(" --user=USER connect as USER\n"));
printf(_(" --psqldir=DIR use psql in DIR (default: configured bindir)\n"));
printf(_("\n")); printf(_("\n"));
printf(_("The exit status is 0 if all tests passed, 1 if some tests failed, and 2\n")); printf(_("The exit status is 0 if all tests passed, 1 if some tests failed, and 2\n"));
printf(_("if the tests could not be run for some reason.\n")); printf(_("if the tests could not be run for some reason.\n"));
...@@ -2087,20 +2005,18 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2087,20 +2005,18 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
{"encoding", required_argument, NULL, 6}, {"encoding", required_argument, NULL, 6},
{"outputdir", required_argument, NULL, 7}, {"outputdir", required_argument, NULL, 7},
{"schedule", required_argument, NULL, 8}, {"schedule", required_argument, NULL, 8},
{"temp-install", required_argument, NULL, 9}, {"temp-instance", required_argument, NULL, 9},
{"no-locale", no_argument, NULL, 10}, {"no-locale", no_argument, NULL, 10},
{"top-builddir", required_argument, NULL, 11},
{"host", required_argument, NULL, 13}, {"host", required_argument, NULL, 13},
{"port", required_argument, NULL, 14}, {"port", required_argument, NULL, 14},
{"user", required_argument, NULL, 15}, {"user", required_argument, NULL, 15},
{"psqldir", required_argument, NULL, 16}, {"bindir", required_argument, NULL, 16},
{"dlpath", required_argument, NULL, 17}, {"dlpath", required_argument, NULL, 17},
{"create-role", required_argument, NULL, 18}, {"create-role", required_argument, NULL, 18},
{"temp-config", required_argument, NULL, 19}, {"temp-config", required_argument, NULL, 19},
{"use-existing", no_argument, NULL, 20}, {"use-existing", no_argument, NULL, 20},
{"launcher", required_argument, NULL, 21}, {"launcher", required_argument, NULL, 21},
{"load-extension", required_argument, NULL, 22}, {"load-extension", required_argument, NULL, 22},
{"extra-install", required_argument, NULL, 23},
{"config-auth", required_argument, NULL, 24}, {"config-auth", required_argument, NULL, 24},
{NULL, 0, NULL, 0} {NULL, 0, NULL, 0}
}; };
...@@ -2172,14 +2088,11 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2172,14 +2088,11 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
add_stringlist_item(&schedulelist, optarg); add_stringlist_item(&schedulelist, optarg);
break; break;
case 9: case 9:
temp_install = make_absolute_path(optarg); temp_instance = make_absolute_path(optarg);
break; break;
case 10: case 10:
nolocale = true; nolocale = true;
break; break;
case 11:
top_builddir = strdup(optarg);
break;
case 13: case 13:
hostname = strdup(optarg); hostname = strdup(optarg);
break; break;
...@@ -2191,9 +2104,11 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2191,9 +2104,11 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
user = strdup(optarg); user = strdup(optarg);
break; break;
case 16: case 16:
/* "--psqldir=" should mean to use PATH */ /* "--bindir=" means to use PATH */
if (strlen(optarg)) if (strlen(optarg))
psqldir = strdup(optarg); bindir = strdup(optarg);
else
bindir = NULL;
break; break;
case 17: case 17:
dlpath = strdup(optarg); dlpath = strdup(optarg);
...@@ -2213,9 +2128,6 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2213,9 +2128,6 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
case 22: case 22:
add_stringlist_item(&loadextension, optarg); add_stringlist_item(&loadextension, optarg);
break; break;
case 23:
add_stringlist_item(&extra_install, optarg);
break;
case 24: case 24:
config_auth_datadir = pstrdup(optarg); config_auth_datadir = pstrdup(optarg);
break; break;
...@@ -2244,7 +2156,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2244,7 +2156,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
exit(0); exit(0);
} }
if (temp_install && !port_specified_by_user) if (temp_instance && !port_specified_by_user)
/* /*
* To reduce chances of interference with parallel installations, use * To reduce chances of interference with parallel installations, use
...@@ -2270,83 +2182,45 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2270,83 +2182,45 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
unlimit_core_size(); unlimit_core_size();
#endif #endif
if (temp_install) if (temp_instance)
{ {
FILE *pg_conf; FILE *pg_conf;
_stringlist *sl;
/* /*
* Prepare the temp installation * Prepare the temp instance
*/ */
if (!top_builddir)
{
fprintf(stderr, _("--top-builddir must be specified when using --temp-install\n"));
exit(2);
}
if (directory_exists(temp_install)) if (directory_exists(temp_instance))
{ {
header(_("removing existing temp installation")); header(_("removing existing temp instance"));
if (!rmtree(temp_install, true)) if (!rmtree(temp_instance, true))
{ {
fprintf(stderr, _("\n%s: could not remove temp installation \"%s\"\n"), fprintf(stderr, _("\n%s: could not remove temp instance \"%s\"\n"),
progname, temp_install); progname, temp_instance);
exit(2); exit(2);
} }
} }
header(_("creating temporary installation")); header(_("creating temporary instance"));
/* make the temp install top directory */ /* make the temp instance top directory */
make_directory(temp_install); make_directory(temp_instance);
/* and a directory for log files */ /* and a directory for log files */
snprintf(buf, sizeof(buf), "%s/log", outputdir); snprintf(buf, sizeof(buf), "%s/log", temp_instance);
if (!directory_exists(buf)) if (!directory_exists(buf))
make_directory(buf); make_directory(buf);
/* "make install" */
#ifndef WIN32_ONLY_COMPILER
snprintf(buf, sizeof(buf),
"\"%s\" -C \"%s\" DESTDIR=\"%s/install\" install > \"%s/log/install.log\" 2>&1",
makeprog, top_builddir, temp_install, outputdir);
#else
snprintf(buf, sizeof(buf),
"perl \"%s/src/tools/msvc/install.pl\" \"%s/install\" >\"%s/log/install.log\" 2>&1",
top_builddir, temp_install, outputdir);
#endif
if (system(buf))
{
fprintf(stderr, _("\n%s: installation failed\nExamine %s/log/install.log for the reason.\nCommand was: %s\n"), progname, outputdir, buf);
exit(2);
}
for (sl = extra_install; sl != NULL; sl = sl->next)
{
#ifndef WIN32_ONLY_COMPILER
snprintf(buf, sizeof(buf),
"\"%s\" -C \"%s/%s\" DESTDIR=\"%s/install\" install >> \"%s/log/install.log\" 2>&1",
makeprog, top_builddir, sl->str, temp_install, outputdir);
#else
fprintf(stderr, _("\n%s: --extra-install option not supported on this platform\n"), progname);
exit(2);
#endif
if (system(buf))
{
fprintf(stderr, _("\n%s: installation failed\nExamine %s/log/install.log for the reason.\nCommand was: %s\n"), progname, outputdir, buf);
exit(2);
}
}
/* initdb */ /* initdb */
header(_("initializing database system")); header(_("initializing database system"));
snprintf(buf, sizeof(buf), snprintf(buf, sizeof(buf),
"\"%s/initdb\" -D \"%s/data\" -L \"%s\" --noclean --nosync%s%s > \"%s/log/initdb.log\" 2>&1", "\"%s%sinitdb\" -D \"%s/data\" --noclean --nosync%s%s > \"%s/log/initdb.log\" 2>&1",
bindir, temp_install, datadir, bindir ? bindir : "",
bindir ? "/" : "",
temp_instance,
debug ? " --debug" : "", debug ? " --debug" : "",
nolocale ? " --no-locale" : "", nolocale ? " --no-locale" : "",
outputdir); temp_instance);
if (system(buf)) if (system(buf))
{ {
fprintf(stderr, _("\n%s: initdb failed\nExamine %s/log/initdb.log for the reason.\nCommand was: %s\n"), progname, outputdir, buf); fprintf(stderr, _("\n%s: initdb failed\nExamine %s/log/initdb.log for the reason.\nCommand was: %s\n"), progname, outputdir, buf);
...@@ -2361,7 +2235,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2361,7 +2235,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
* failures, don't set max_prepared_transactions any higher than * failures, don't set max_prepared_transactions any higher than
* actually needed by the prepared_xacts regression test.) * actually needed by the prepared_xacts regression test.)
*/ */
snprintf(buf, sizeof(buf), "%s/data/postgresql.conf", temp_install); snprintf(buf, sizeof(buf), "%s/data/postgresql.conf", temp_instance);
pg_conf = fopen(buf, "a"); pg_conf = fopen(buf, "a");
if (pg_conf == NULL) if (pg_conf == NULL)
{ {
...@@ -2399,7 +2273,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2399,7 +2273,7 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
* Since we successfully used the same buffer for the much-longer * Since we successfully used the same buffer for the much-longer
* "initdb" command, this can't truncate. * "initdb" command, this can't truncate.
*/ */
snprintf(buf, sizeof(buf), "%s/data", temp_install); snprintf(buf, sizeof(buf), "%s/data", temp_instance);
config_sspi_auth(buf); config_sspi_auth(buf);
#elif !defined(HAVE_UNIX_SOCKETS) #elif !defined(HAVE_UNIX_SOCKETS)
#error Platform has no means to secure the test installation. #error Platform has no means to secure the test installation.
...@@ -2409,8 +2283,10 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2409,8 +2283,10 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
* Check if there is a postmaster running already. * Check if there is a postmaster running already.
*/ */
snprintf(buf2, sizeof(buf2), snprintf(buf2, sizeof(buf2),
"\"%s/psql\" -X postgres <%s 2>%s", "\"%s%spsql\" -X postgres <%s 2>%s",
bindir, DEVNULL, DEVNULL); bindir ? bindir : "",
bindir ? "/" : "",
DEVNULL, DEVNULL);
for (i = 0; i < 16; i++) for (i = 0; i < 16; i++)
{ {
...@@ -2441,12 +2317,14 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2441,12 +2317,14 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
*/ */
header(_("starting postmaster")); header(_("starting postmaster"));
snprintf(buf, sizeof(buf), snprintf(buf, sizeof(buf),
"\"%s/postgres\" -D \"%s/data\" -F%s " "\"%s%spostgres\" -D \"%s/data\" -F%s "
"-c \"listen_addresses=%s\" -k \"%s\" " "-c \"listen_addresses=%s\" -k \"%s\" "
"> \"%s/log/postmaster.log\" 2>&1", "> \"%s/log/postmaster.log\" 2>&1",
bindir, temp_install, debug ? " -d 5" : "", bindir ? bindir : "",
bindir ? "/" : "",
temp_instance, debug ? " -d 5" : "",
hostname ? hostname : "", sockdir ? sockdir : "", hostname ? hostname : "", sockdir ? sockdir : "",
outputdir); temp_instance);
postmaster_pid = spawn_process(buf); postmaster_pid = spawn_process(buf);
if (postmaster_pid == INVALID_PID) if (postmaster_pid == INVALID_PID)
{ {
...@@ -2560,23 +2438,23 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc ...@@ -2560,23 +2438,23 @@ regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc
/* /*
* Shut down temp installation's postmaster * Shut down temp installation's postmaster
*/ */
if (temp_install) if (temp_instance)
{ {
header(_("shutting down postmaster")); header(_("shutting down postmaster"));
stop_postmaster(); stop_postmaster();
} }
/* /*
* If there were no errors, remove the temp installation immediately to * If there were no errors, remove the temp instance immediately to
* conserve disk space. (If there were errors, we leave the installation * conserve disk space. (If there were errors, we leave the instance
* in place for possible manual investigation.) * in place for possible manual investigation.)
*/ */
if (temp_install && fail_count == 0 && fail_ignore_count == 0) if (temp_instance && fail_count == 0 && fail_ignore_count == 0)
{ {
header(_("removing temporary installation")); header(_("removing temporary instance"));
if (!rmtree(temp_install, true)) if (!rmtree(temp_instance, true))
fprintf(stderr, _("\n%s: could not remove temp installation \"%s\"\n"), fprintf(stderr, _("\n%s: could not remove temp instance \"%s\"\n"),
progname, temp_install); progname, temp_instance);
} }
fclose(logfile); fclose(logfile);
......
...@@ -43,12 +43,6 @@ extern char *inputdir; ...@@ -43,12 +43,6 @@ extern char *inputdir;
extern char *outputdir; extern char *outputdir;
extern char *launcher; extern char *launcher;
/*
* This should not be global but every module should be able to read command
* line parameters.
*/
extern char *psqldir;
extern const char *basic_diff_opts; extern const char *basic_diff_opts;
extern const char *pretty_diff_opts; extern const char *pretty_diff_opts;
......
...@@ -65,8 +65,8 @@ psql_start_test(const char *testname, ...@@ -65,8 +65,8 @@ psql_start_test(const char *testname,
snprintf(psql_cmd + offset, sizeof(psql_cmd) - offset, snprintf(psql_cmd + offset, sizeof(psql_cmd) - offset,
"\"%s%spsql\" -X -a -q -d \"%s\" < \"%s\" > \"%s\" 2>&1", "\"%s%spsql\" -X -a -q -d \"%s\" < \"%s\" > \"%s\" 2>&1",
psqldir ? psqldir : "", bindir ? bindir : "",
psqldir ? "/" : "", bindir ? "/" : "",
dblist->str, dblist->str,
infile, infile,
outfile); outfile);
......
...@@ -16,6 +16,7 @@ my $startdir = getcwd(); ...@@ -16,6 +16,7 @@ my $startdir = getcwd();
chdir "../../.." if (-d "../../../src/tools/msvc"); chdir "../../.." if (-d "../../../src/tools/msvc");
my $topdir = getcwd(); my $topdir = getcwd();
my $tmp_installdir = "$topdir/tmp_install";
require 'src/tools/msvc/config_default.pl'; require 'src/tools/msvc/config_default.pl';
require 'src/tools/msvc/config.pl' if (-f 'src/tools/msvc/config.pl'); require 'src/tools/msvc/config.pl' if (-f 'src/tools/msvc/config.pl');
...@@ -95,7 +96,7 @@ sub installcheck ...@@ -95,7 +96,7 @@ sub installcheck
my @args = ( my @args = (
"../../../$Config/pg_regress/pg_regress", "../../../$Config/pg_regress/pg_regress",
"--dlpath=.", "--dlpath=.",
"--psqldir=../../../$Config/psql", "--bindir=../../../$Config/psql",
"--schedule=${schedule}_schedule", "--schedule=${schedule}_schedule",
"--encoding=SQL_ASCII", "--encoding=SQL_ASCII",
"--no-locale"); "--no-locale");
...@@ -107,15 +108,19 @@ sub installcheck ...@@ -107,15 +108,19 @@ sub installcheck
sub check sub check
{ {
chdir $startdir;
InstallTemp();
chdir "${topdir}/src/test/regress";
my @args = ( my @args = (
"../../../$Config/pg_regress/pg_regress", "${tmp_installdir}/bin/pg_regress",
"--dlpath=.", "--dlpath=.",
"--psqldir=../../../$Config/psql", "--bindir=${tmp_installdir}/bin",
"--schedule=${schedule}_schedule", "--schedule=${schedule}_schedule",
"--encoding=SQL_ASCII", "--encoding=SQL_ASCII",
"--no-locale", "--no-locale",
"--temp-install=./tmp_check", "--temp-instance=./tmp_check");
"--top-builddir=\"$topdir\"");
push(@args, $maxconn) if $maxconn; push(@args, $maxconn) if $maxconn;
push(@args, $temp_config) if $temp_config; push(@args, $temp_config) if $temp_config;
system(@args); system(@args);
...@@ -129,18 +134,20 @@ sub ecpgcheck ...@@ -129,18 +134,20 @@ sub ecpgcheck
system("msbuild ecpg_regression.proj /p:config=$Config"); system("msbuild ecpg_regression.proj /p:config=$Config");
my $status = $? >> 8; my $status = $? >> 8;
exit $status if $status; exit $status if $status;
InstallTemp();
chdir "$topdir/src/interfaces/ecpg/test"; chdir "$topdir/src/interfaces/ecpg/test";
$ENV{PATH} = "${tmp_installdir}/bin;${tmp_installdir}/lib;$ENV{PATH}";
$schedule = "ecpg"; $schedule = "ecpg";
my @args = ( my @args = (
"../../../../$Config/pg_regress_ecpg/pg_regress_ecpg", "${tmp_installdir}/bin/pg_regress_ecpg",
"--psqldir=../../../$Config/psql", "--bindir=",
"--dbname=regress1,connectdb", "--dbname=regress1,connectdb",
"--create-role=connectuser,connectdb", "--create-role=connectuser,connectdb",
"--schedule=${schedule}_schedule", "--schedule=${schedule}_schedule",
"--encoding=SQL_ASCII", "--encoding=SQL_ASCII",
"--no-locale", "--no-locale",
"--temp-install=./tmp_chk", "--temp-instance=./tmp_chk");
"--top-builddir=\"$topdir\"");
push(@args, $maxconn) if $maxconn; push(@args, $maxconn) if $maxconn;
system(@args); system(@args);
$status = $? >> 8; $status = $? >> 8;
...@@ -149,12 +156,14 @@ sub ecpgcheck ...@@ -149,12 +156,14 @@ sub ecpgcheck
sub isolationcheck sub isolationcheck
{ {
chdir "../isolation"; chdir $startdir;
copy("../../../$Config/isolationtester/isolationtester.exe",
"../../../$Config/pg_isolation_regress"); InstallTemp();
chdir "${topdir}/src/test/isolation";
my @args = ( my @args = (
"../../../$Config/pg_isolation_regress/pg_isolation_regress", "${tmp_installdir}/bin/pg_isolation_regress",
"--psqldir=../../../$Config/psql", "--bindir=${tmp_installdir}/bin",
"--inputdir=.", "--inputdir=.",
"--schedule=./isolation_schedule"); "--schedule=./isolation_schedule");
push(@args, $maxconn) if $maxconn; push(@args, $maxconn) if $maxconn;
...@@ -165,7 +174,10 @@ sub isolationcheck ...@@ -165,7 +174,10 @@ sub isolationcheck
sub plcheck sub plcheck
{ {
chdir "../../pl"; chdir $startdir;
InstallTemp();
chdir "${topdir}/src/pl";
foreach my $pl (glob("*")) foreach my $pl (glob("*"))
{ {
...@@ -202,8 +214,8 @@ sub plcheck ...@@ -202,8 +214,8 @@ sub plcheck
"============================================================\n"; "============================================================\n";
print "Checking $lang\n"; print "Checking $lang\n";
my @args = ( my @args = (
"../../../$Config/pg_regress/pg_regress", "${tmp_installdir}/bin/pg_regress",
"--psqldir=../../../$Config/psql", "--bindir=${tmp_installdir}/bin",
"--dbname=pl_regression", @lang_args, @tests); "--dbname=pl_regression", @lang_args, @tests);
system(@args); system(@args);
my $status = $? >> 8; my $status = $? >> 8;
...@@ -233,8 +245,8 @@ sub subdircheck ...@@ -233,8 +245,8 @@ sub subdircheck
my @tests = fetchTests(); my @tests = fetchTests();
my @opts = fetchRegressOpts(); my @opts = fetchRegressOpts();
my @args = ( my @args = (
"$topdir/$Config/pg_regress/pg_regress", "${tmp_installdir}/bin/pg_regress",
"--psqldir=$topdir/$Config/psql", "--bindir=${tmp_installdir}/bin",
"--dbname=contrib_regression", @opts, @tests); "--dbname=contrib_regression", @opts, @tests);
system(@args); system(@args);
my $status = $? >> 8; my $status = $? >> 8;
...@@ -273,8 +285,8 @@ sub modulescheck ...@@ -273,8 +285,8 @@ sub modulescheck
sub standard_initdb sub standard_initdb
{ {
return ( return (
system('initdb', '-N') == 0 and system( system("${tmp_installdir}/bin/initdb", '-N') == 0 and system(
"$topdir/$Config/pg_regress/pg_regress", '--config-auth', "${tmp_installdir}/bin/pg_regress", '--config-auth',
$ENV{PGDATA}) == 0); $ENV{PGDATA}) == 0);
} }
...@@ -293,14 +305,13 @@ sub upgradecheck ...@@ -293,14 +305,13 @@ sub upgradecheck
$ENV{PGPORT} ||= 50432; $ENV{PGPORT} ||= 50432;
my $tmp_root = "$topdir/src/bin/pg_upgrade/tmp_check"; my $tmp_root = "$topdir/src/bin/pg_upgrade/tmp_check";
(mkdir $tmp_root || die $!) unless -d $tmp_root; (mkdir $tmp_root || die $!) unless -d $tmp_root;
my $tmp_install = "$tmp_root/install";
print "Setting up temp install\n\n"; InstallTemp();
Install($tmp_install, "all", $config);
# Install does a chdir, so change back after that # Install does a chdir, so change back after that
chdir $cwd; chdir $cwd;
my ($bindir, $libdir, $oldsrc, $newsrc) = my ($bindir, $libdir, $oldsrc, $newsrc) =
("$tmp_install/bin", "$tmp_install/lib", $topdir, $topdir); ("$tmp_installdir/bin", "$tmp_installdir/lib", $topdir, $topdir);
$ENV{PATH} = "$bindir;$ENV{PATH}"; $ENV{PATH} = "$bindir;$ENV{PATH}";
my $data = "$tmp_root/data"; my $data = "$tmp_root/data";
$ENV{PGDATA} = "$data.old"; $ENV{PGDATA} = "$data.old";
...@@ -435,6 +446,12 @@ sub GetTests ...@@ -435,6 +446,12 @@ sub GetTests
return ""; return "";
} }
sub InstallTemp
{
print "Setting up temp install\n\n";
Install("$tmp_installdir", "all", $config);
}
sub usage sub usage
{ {
print STDERR print STDERR
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment