Commit b04c8575 authored by Brandon Nesterenko's avatar Brandon Nesterenko

MDEV-33500: rpl.rpl_parallel_sbm can fail on slow machines, e.g. MSAN/Valgrind builders

In an addition to test rpl.rpl_parallel_sbm added by MDEV-32265, the
test uses sleep statements alone to test Seconds_Behind_Master with
delayed replication. On slow running machines, the test can pass the
intended MASTER_DELAY duration and Seconds_Behind_Master can become
0, when the test expects the transaction to still be actively in a
delaying state.

This can be consistently reproduced by adding a sleep statement
before the call to

--let = query_get_value(SHOW SLAVE STATUS, Seconds_Behind_Master, 1)

to sleep past the delay end point.

This patch fixes this by locking the table which the delayed
transaction targets so Second_Behind_Master cannot be updated before
the test reads it for validation.
parent 1bbbb66e
...@@ -27,12 +27,19 @@ connection slave; ...@@ -27,12 +27,19 @@ connection slave;
# delaying a transaction; then when the reciprocal START SLAVE occurs, # delaying a transaction; then when the reciprocal START SLAVE occurs,
# if the event is still to be delayed, SBM should resume accordingly # if the event is still to be delayed, SBM should resume accordingly
include/stop_slave.inc include/stop_slave.inc
# Lock t1 on slave to ensure the event can't finish (and thereby update
# Seconds_Behind_Master) so slow running servers don't accidentally
# catch up to the master before checking SBM.
connection server_2;
LOCK TABLES t1 WRITE;
include/start_slave.inc include/start_slave.inc
connection slave; connection slave;
# Waiting for replica to resume the delay for the transaction # Waiting for replica to resume the delay for the transaction
# Sleeping 1s to increment SBM # Sleeping 1s to increment SBM
# Ensuring Seconds_Behind_Master increases after sleeping.. # Ensuring Seconds_Behind_Master increases after sleeping..
# ..done # ..done
connection server_2;
UNLOCK TABLES;
include/sync_with_master_gtid.inc include/sync_with_master_gtid.inc
# #
# Pt 2) If the worker threads have not entered an idle state, ensure # Pt 2) If the worker threads have not entered an idle state, ensure
......
...@@ -67,6 +67,13 @@ if (`SELECT $sbm_trx1_arrive > ($seconds_since_idling + 1)`) ...@@ -67,6 +67,13 @@ if (`SELECT $sbm_trx1_arrive > ($seconds_since_idling + 1)`)
--echo # if the event is still to be delayed, SBM should resume accordingly --echo # if the event is still to be delayed, SBM should resume accordingly
--source include/stop_slave.inc --source include/stop_slave.inc
--echo # Lock t1 on slave to ensure the event can't finish (and thereby update
--echo # Seconds_Behind_Master) so slow running servers don't accidentally
--echo # catch up to the master before checking SBM.
--connection server_2
LOCK TABLES t1 WRITE;
--source include/start_slave.inc --source include/start_slave.inc
--connection slave --connection slave
...@@ -86,6 +93,9 @@ if (`SELECT $sbm_trx1_after_1s_sleep <= $sbm_trx1_arrive`) ...@@ -86,6 +93,9 @@ if (`SELECT $sbm_trx1_after_1s_sleep <= $sbm_trx1_arrive`)
} }
--echo # ..done --echo # ..done
--connection server_2
UNLOCK TABLES;
--source include/sync_with_master_gtid.inc --source include/sync_with_master_gtid.inc
--echo # --echo #
......
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