summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Dunstan <andrew@dunslane.net>2012-12-02 17:30:18 -0500
committerAndrew Dunstan <andrew@dunslane.net>2012-12-02 17:30:18 -0500
commitc8f666abde2af3060af41afe4b03ced2f62d94a9 (patch)
treec4f2cd840d84bbaf87ec08f3e76e338430b1711b
parent194bb37ebac43c5b5782dd32bcf45c64434a172d (diff)
Add mode where contrib installcheck runs each module in a separately named database.
Normally each module is tested in aq database named contrib_regression, which is dropped and recreated at the beginhning of each pg_regress run. This mode, enabled by adding USE_MODULE_DB=1 to the make command line, runs most modules in a database with the module name embedded in it. This will make testing pg_upgrade on clusters with the contrib modules a lot easier. Still to be done: adapt to the MSVC build system. Backpatch to 9.0, which is the earliest version it is reasonably possible to test upgrading from.
-rw-r--r--contrib/dblink/Makefile3
-rw-r--r--src/Makefile.global.in9
-rw-r--r--src/makefiles/pgxs.mk6
3 files changed, 17 insertions, 1 deletions
diff --git a/contrib/dblink/Makefile b/contrib/dblink/Makefile
index 519c73b68fe..ebdb3931dab 100644
--- a/contrib/dblink/Makefile
+++ b/contrib/dblink/Makefile
@@ -10,6 +10,9 @@ DATA = uninstall_dblink.sql
REGRESS = dblink
+# the db name is hard-coded in the tests
+override undefine USE_MODULE_DB
+
ifdef USE_PGXS
PG_CONFIG = pg_config
PGXS := $(shell $(PG_CONFIG) --pgxs)
diff --git a/src/Makefile.global.in b/src/Makefile.global.in
index 280578a4c39..6fe87f33c35 100644
--- a/src/Makefile.global.in
+++ b/src/Makefile.global.in
@@ -284,6 +284,15 @@ BZIP2 = bzip2
PL_TESTDB = pl_regression
CONTRIB_TESTDB = contrib_regression
+ifneq ($(MODULE_big),)
+ CONTRIB_TESTDB_MODULE = contrib_regression_$(MODULE_big)
+else
+ ifneq ($(MODULES),)
+ CONTRIB_TESTDB_MODULE = contrib_regression_$(MODULES)
+ else
+ CONTRIB_TESTDB_MODULE = contrib_regression
+ endif
+endif
# Installation.
diff --git a/src/makefiles/pgxs.mk b/src/makefiles/pgxs.mk
index 4f1ae191012..6b501f40c22 100644
--- a/src/makefiles/pgxs.mk
+++ b/src/makefiles/pgxs.mk
@@ -233,7 +233,11 @@ ifdef REGRESS
# Calling makefile can set REGRESS_OPTS, but this is the default:
ifndef REGRESS_OPTS
-REGRESS_OPTS = --dbname=$(CONTRIB_TESTDB)
+ ifdef USE_MODULE_DB
+ REGRESS_OPTS = --dbname=$(CONTRIB_TESTDB_MODULE)
+ else
+ REGRESS_OPTS = --dbname=$(CONTRIB_TESTDB)
+ endif
endif
# where to find psql for running the tests