mirror of
https://github.com/MariaDB/server.git
synced 2026-05-16 03:47:17 +02:00
Merged from mysql-wsrep-bugs following:
GCF-1058 MTR test galera.MW-86 fails on repeated runs
Wait for the sync point sync.wsrep_apply_cb to be reached before
executing the test and clearing the debug flag sync.wsrep_apply_cb.
The race scenario:
Intended behavior:
node2: set sync.wsrep_apply_cb in order to start waiting in the background INSERT
node1: INSERT start
node2 (background): INSERT start
node1: INSERT end
node2: send signal to background INSERT: "stop waiting and continue executing"
node2: clear sync.wsrep_apply_cb as no longer needed
node2 (background): consume the signal
node2 (background): INSERT end
node2: DROP TABLE
node2: check no pending signals are left - ok
What happens occasionally (unexpected):
node2: set sync.wsrep_apply_cb in order to start waiting in the background INSERT
node1: INSERT start
node2 (background): INSERT start
node1: INSERT end
// The background INSERT still has _not_ reached the place where it starts
// waiting for the signal:
// DBUG_EXECUTE_IF("sync.wsrep_apply_cb", "now wait_for...");
node2: send signal to background INSERT: "stop waiting and continue executing"
node2: clear sync.wsrep_apply_cb as no longer needed
// The background INSERT reaches DBUG_EXECUTE_IF("sync.wsrep_apply_cb", ...)
// but sync.wsrep_apply_cb has already been cleared and the "wait" code is not
// executed. The signal remains unconsumed.
node2 (background): INSERT end
node2: DROP TABLE
node2: check no pending signals are left - failure, signal.wsrep_apply_cb is
pending (not consumed)
Remove MW-360 test case as it is not intended for MariaDB (uses
MySQL GTID).
128 lines
2.7 KiB
Text
128 lines
2.7 KiB
Text
#
|
|
# SHOW commands now obey wsrep_sync_wait = 8 (WSREP_SYNC_WAIT_BEFORE_SHOW)
|
|
#
|
|
--source include/galera_cluster.inc
|
|
--source include/have_binlog_format_row.inc
|
|
--source include/have_debug_sync.inc
|
|
|
|
--connection node_2
|
|
# Make sure no signals have been leftover from previous tests to surprise us.
|
|
SELECT @@debug_sync;
|
|
|
|
SET SESSION wsrep_sync_wait = 8;
|
|
SET GLOBAL debug = "+d,sync.wsrep_apply_cb";
|
|
|
|
--connection node_1
|
|
CREATE TABLE t_wait8 (f1 INTEGER) ENGINE=InnoDB;
|
|
# This will complete in node_1 but will start a background apply in node_2
|
|
# which will stop because of sync.wsrep_apply_cb we set above.
|
|
INSERT INTO t_wait8 VALUES (1);
|
|
|
|
--connection node_2
|
|
|
|
--let $wsrep_provider_options_orig = `SELECT @@wsrep_provider_options`
|
|
SET GLOBAL wsrep_provider_options = "repl.causal_read_timeout=PT0.1S";
|
|
|
|
SET SESSION debug_sync = "now WAIT_FOR sync.wsrep_apply_cb_reached";
|
|
|
|
--disable_result_log
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW BINARY LOGS;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW BINLOG EVENTS;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW COLUMNS FROM t1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE DATABASE db1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE EVENT e1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE FUNCTION f1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE PROCEDURE p1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE TABLE t1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE TRIGGER tr1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW CREATE VIEW v1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW DATABASES;
|
|
|
|
--error 0
|
|
SHOW ENGINE InnoDB STATUS;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW FUNCTION CODE f1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW FUNCTION STATUS;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW GRANTS FOR 'root'@'localhost';
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW INDEX FROM t1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW OPEN TABLES;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW PROCEDURE CODE p1;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW PROCEDURE STATUS;
|
|
|
|
--error 0
|
|
SHOW PRIVILEGES;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW STATUS LIKE 'wsrep_cluster_size';
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW TABLE STATUS;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW TABLES;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW TRIGGERS;
|
|
|
|
--error ER_LOCK_WAIT_TIMEOUT
|
|
SHOW GLOBAL VARIABLES LIKE 'foo_bar';
|
|
|
|
--error 0
|
|
SHOW WARNINGS;
|
|
|
|
--enable_result_log
|
|
|
|
--disable_query_log
|
|
--eval SET GLOBAL wsrep_provider_options = "$wsrep_provider_options_orig"
|
|
--enable_query_log
|
|
|
|
# Unblock the background INSERT and remove the sync point.
|
|
SET GLOBAL debug = "-d,sync.wsrep_apply_cb";
|
|
SET DEBUG_SYNC = "now SIGNAL signal.wsrep_apply_cb";
|
|
|
|
SET SESSION wsrep_sync_wait = default;
|
|
|
|
# This will wait for the background INSERT to complete before we quit
|
|
# from the test.
|
|
DROP TABLE t_wait8;
|
|
|
|
SET GLOBAL debug = NULL;
|
|
SET debug_sync='RESET';
|
|
|
|
# Make sure no pending signals are leftover to surprise subsequent tests.
|
|
SELECT @@debug_sync;
|