mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-24 18:55:04 +08:00
08da2d282f
It runs the regression tests, runs pg_upgrade on the populated database, and compares the before and after dumps. While not actually a cross-version upgrade, this does detect omissions and bugs in the involved tools from time to time. It's also possible to do a cross-version upgrade by manually supplying parameters.
84 lines
3.0 KiB
Plaintext
84 lines
3.0 KiB
Plaintext
contrib/pg_upgrade/TESTING
|
|
|
|
The most effective way to test pg_upgrade, aside from testing on user
|
|
data, is by upgrading the PostgreSQL regression database.
|
|
|
|
This testing process first requires the creation of a valid regression
|
|
database dump. Such files contain most database features and are
|
|
specific to each major version of Postgres.
|
|
|
|
Here are the steps needed to create a regression database dump file:
|
|
|
|
1) Create and populate the regression database in the old cluster
|
|
This database can be created by running 'gmake installcheck' from
|
|
src/test/regression.
|
|
|
|
2) Use pg_dump to dump out the regression database. Use the new
|
|
cluster's pg_dump on the old database to minimize whitespace
|
|
differences in the diff.
|
|
|
|
3) Adjust the regression database dump file
|
|
|
|
a) Perform the load/dump twice
|
|
This fixes problems with the ordering of COPY columns for
|
|
inherited tables.
|
|
|
|
b) Change CREATE FUNCTION shared object paths to use '$libdir'
|
|
The old and new cluster will have different shared object paths.
|
|
|
|
c) Fix any wrapping format differences
|
|
Commands like CREATE TRIGGER and ALTER TABLE sometimes have
|
|
differences.
|
|
|
|
d) For pre-9.0, change CREATE OR REPLACE LANGUAGE to CREATE LANGUAGE
|
|
|
|
e) For pre-9.0, remove 'regex_flavor'
|
|
|
|
f) For pre-9.0, adjust extra_float_digits
|
|
Postgres 9.0 pg_dump uses extra_float_digits=-2 for pre-9.0
|
|
databases, and extra_float_digits=-3 for >= 9.0 databases.
|
|
It is necessary to modify 9.0 pg_dump to always use -3, and
|
|
modify the pre-9.0 old server to accept extra_float_digits=-3.
|
|
|
|
Once the dump is created, it can be repeatedly loaded into the old
|
|
database, upgraded, and dumped out of the new database, and then
|
|
compared to the original version. To test the dump file, perform these
|
|
steps:
|
|
|
|
1) Create the old and new clusters in different directories.
|
|
|
|
2) Copy the regression shared object files into the appropriate /lib
|
|
directory for old and new clusters.
|
|
|
|
3) Create the regression database in the old server.
|
|
|
|
4) Load the dump file created above into the regression database;
|
|
check for errors while loading.
|
|
|
|
5) Upgrade the old database to the new major version, as outlined in
|
|
the pg_upgrade manual section.
|
|
|
|
6) Use pg_dump to dump out the regression database in the new cluster.
|
|
|
|
7) Diff the regression database dump file with the regression dump
|
|
file loaded into the old server.
|
|
|
|
The shell script test.sh in this directory performs more or less this
|
|
procedure. You can invoke it by running
|
|
|
|
gmake check
|
|
|
|
or by running
|
|
|
|
gmake installcheck
|
|
|
|
if "gmake install" (or "gmake install-world") were done beforehand.
|
|
When invoked without arguments, it will run an upgrade from the
|
|
version in this source tree to a new instance of the same version. To
|
|
test an upgrade from a different version, invoke it like this:
|
|
|
|
gmake installcheck oldbindir=...otherversion/bin oldsrc=...somewhere/postgresql
|
|
|
|
In this case, you will have to manually eyeball the resulting dump
|
|
diff for version-specific differences, as explained above.
|