]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Apply filters to dump files all the time in 002_pg_upgrade.pl
authorMichael Paquier <michael@paquier.xyz>
Wed, 6 Dec 2023 00:55:05 +0000 (09:55 +0900)
committerMichael Paquier <michael@paquier.xyz>
Wed, 6 Dec 2023 00:55:05 +0000 (09:55 +0900)
This commit removes the restriction that would not apply filters to the
dumps used for comparison in the TAP test of pg_upgrade when using the
same base version for the old and new nodes.

The previous logic would fail on Windows if loading a dump while using
the same set of binaries for the old and new nodes, as the library
dependencies updated in the old dump would append CRLFs to the dump
file as it is treated as a text file.  The dump filtering logic replaces
all CRLFs (\r\n) by LFs (\n), which is able to prevent this issue.

When the old and new versions of the binaries are the same,
AdjustUpgrade removes all blank lines, removes version-based comments
generated by pg_dump and replaces CRLFs by LFs.

Reported-by: Alexander Lakhin
Discussion: https://postgr.es/m/60d434b9-53d9-9ea1-819b-efebdcf44e41@gmail.com
Backpatch-through: 15

src/bin/pg_upgrade/t/002_pg_upgrade.pl

index 6b0f42cecf810d85ff81dda200abefbd2eea8f0c..700afd5d79e9286be42824d30bd4ca16aed1b8dc 100644 (file)
@@ -364,15 +364,9 @@ push(@dump_command, '--extra-float-digits', '0')
   if ($oldnode->pg_version < 12);
 $newnode->command_ok(\@dump_command, 'dump after running pg_upgrade');
 
-# No need to apply filters on the dumps if working on the same version
-# for the old and new nodes.
-my $dump1_filtered = $dump1_file;
-my $dump2_filtered = $dump2_file;
-if ($oldnode->pg_version != $newnode->pg_version)
-{
-       $dump1_filtered = filter_dump(1, $oldnode->pg_version, $dump1_file);
-       $dump2_filtered = filter_dump(0, $oldnode->pg_version, $dump2_file);
-}
+# Filter the contents of the dumps.
+my $dump1_filtered = filter_dump(1, $oldnode->pg_version, $dump1_file);
+my $dump2_filtered = filter_dump(0, $oldnode->pg_version, $dump2_file);
 
 # Compare the two dumps, there should be no differences.
 my $compare_res = compare($dump1_filtered, $dump2_filtered);