Commit c63913ca authored by Tom Lane's avatar Tom Lane

Improve inefficient regexes in vacuumdb TAP test.

The regexes used in 102_vacuumdb_stages.pl to check the postmaster log
for expected output contained several places with ".*.*", which is
underdetermined and can cause exponential runtime growth in Perl's regex
matcher (since it's not bright enough not to waste time seeing whether
different splits of the same substring would allow a match).  We were
fortunate that the amount of text in the postmaster log was generally not
enough to make the runtime go to the moon; although commit 6271fceb had
been on the hairy edge of an obvious problem, thanks to its increasing the
default log verbosity to DEBUG1.  Experimentation shows that anyone who
tried to run this test case with an even higher log verbosity would have
been in for serious pain.  But even at default logging level, fixing this
saves several hundred ms on my workstation, more on slower buildfarm
members.

Remove the extra ".*"s, restoring more-or-less-linear matching speed.
Back-patch to 9.4 where the test case was added, mostly in case anyone
tries to do related debugging in a back branch.

Discussion: https://postgr.es/m/32459.1525657786@sss.pgh.pa.us
parent dec10340
...@@ -10,26 +10,26 @@ $node->start; ...@@ -10,26 +10,26 @@ $node->start;
$node->issues_sql_like( $node->issues_sql_like(
[ 'vacuumdb', '--analyze-in-stages', 'postgres' ], [ 'vacuumdb', '--analyze-in-stages', 'postgres' ],
qr/.*statement:\ SET\ default_statistics_target=1;\ SET\ vacuum_cost_delay=0; qr/statement:\ SET\ default_statistics_target=1;\ SET\ vacuum_cost_delay=0;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ SET\ default_statistics_target=10;\ RESET\ vacuum_cost_delay; .*statement:\ SET\ default_statistics_target=10;\ RESET\ vacuum_cost_delay;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ RESET\ default_statistics_target; .*statement:\ RESET\ default_statistics_target;
.*statement:\ ANALYZE/sx, .*statement:\ ANALYZE/sx,
'analyze three times'); 'analyze three times');
$node->issues_sql_like( $node->issues_sql_like(
[ 'vacuumdb', '--analyze-in-stages', '--all' ], [ 'vacuumdb', '--analyze-in-stages', '--all' ],
qr/.*statement:\ SET\ default_statistics_target=1;\ SET\ vacuum_cost_delay=0; qr/statement:\ SET\ default_statistics_target=1;\ SET\ vacuum_cost_delay=0;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ SET\ default_statistics_target=1;\ SET\ vacuum_cost_delay=0; .*statement:\ SET\ default_statistics_target=1;\ SET\ vacuum_cost_delay=0;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ SET\ default_statistics_target=10;\ RESET\ vacuum_cost_delay; .*statement:\ SET\ default_statistics_target=10;\ RESET\ vacuum_cost_delay;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ SET\ default_statistics_target=10;\ RESET\ vacuum_cost_delay; .*statement:\ SET\ default_statistics_target=10;\ RESET\ vacuum_cost_delay;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ RESET\ default_statistics_target; .*statement:\ RESET\ default_statistics_target;
.*statement:\ ANALYZE.* .*statement:\ ANALYZE
.*statement:\ RESET\ default_statistics_target; .*statement:\ RESET\ default_statistics_target;
.*statement:\ ANALYZE/sx, .*statement:\ ANALYZE/sx,
'analyze more than one database in stages'); 'analyze more than one database in stages');
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