Commit 5136967f authored by Andres Freund's avatar Andres Freund

Fix timing issue in deadlock recovery conflict test.

Per buildfarm members longfin and skink.

Discussion: https://postgr.es/m/20220413002626.udl7lll7f3o7nre7@alap3.anarazel.de
Backpatch: 10-
parent f74496dd
...@@ -231,6 +231,14 @@ check_conflict_stat("lock"); ...@@ -231,6 +231,14 @@ check_conflict_stat("lock");
$sect = "startup deadlock"; $sect = "startup deadlock";
$expected_conflicts++; $expected_conflicts++;
# Want to test recovery deadlock conflicts, not buffer pin conflicts. Without
# changing max_standby_streaming_delay it'd be timing dependent what we hit
# first
$node_standby->adjust_conf('postgresql.conf', 'max_standby_streaming_delay',
"${PostgreSQL::Test::Utils::timeout_default}s");
$node_standby->restart();
reconnect_and_clear();
# Generate a few dead rows, to later be cleaned up by vacuum. Then acquire a # Generate a few dead rows, to later be cleaned up by vacuum. Then acquire a
# lock on another relation in a prepared xact, so it's held continuously by # lock on another relation in a prepared xact, so it's held continuously by
# the startup process. The standby psql will block acquiring that lock while # the startup process. The standby psql will block acquiring that lock while
...@@ -286,6 +294,9 @@ check_conflict_stat("deadlock"); ...@@ -286,6 +294,9 @@ check_conflict_stat("deadlock");
# clean up for next tests # clean up for next tests
$node_primary->safe_psql($test_db, qq[ROLLBACK PREPARED 'lock';]); $node_primary->safe_psql($test_db, qq[ROLLBACK PREPARED 'lock';]);
$node_standby->adjust_conf('postgresql.conf', 'max_standby_streaming_delay', '50ms');
$node_standby->restart();
reconnect_and_clear();
# Check that expected number of conflicts show in pg_stat_database. Needs to # Check that expected number of conflicts show in pg_stat_database. Needs to
......
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