mirror of
https://github.com/MariaDB/server.git
synced 2025-01-23 23:34:34 +01:00
b55468d713
mysql-test/include/wait_for_slave_io_to_stop.inc: Updated previous commit to include Magnus's change request from review. In addition, I moved it from the mysql-5.1 to mysql-5.1-maint clone. We now have 3 new replications tools and one tool that has been refactored. 1) include/wait_for_slave_to_stop.inc replaces the old mysqltest.c wait_for_slave_to_stop. NEW: 2) include/wait_for_slave_sql_to_stop.inc is for when you are expecting the slave to get an SQL error and waiting for the SQL Thread to stop. 3) include/wait_for_slave_io_to_stop.inc is used for test that you expect sometype of IO error and the IO Thread to stop. 4) include/wait_for_slave_to_start.inc for waiting for the slave to completely start before moving forward in the test. All 4 tests have a built in loop that will stop the test if any of the tools take too long. mysql-test/include/wait_for_slave_sql_to_stop.inc: Updated previous commit to include Magnus's change request from review. In addition, I moved it from the mysql-5.1 to mysql-5.1-maint clone. We now have 3 new replications tools and one tool that has been refactored. 1) include/wait_for_slave_to_stop.inc replaces the old mysqltest.c wait_for_slave_to_stop. NEW: 2) include/wait_for_slave_sql_to_stop.inc is for when you are expecting the slave to get an SQL error and waiting for the SQL Thread to stop. 3) include/wait_for_slave_io_to_stop.inc is used for test that you expect sometype of IO error and the IO Thread to stop. 4) include/wait_for_slave_to_start.inc for waiting for the slave to completely start before moving forward in the test. All 4 tests have a built in loop that will stop the test if any of the tools take too long. mysql-test/include/wait_for_slave_to_start.inc: Updated previous commit to include Magnus's change request from review. In addition, I moved it from the mysql-5.1 to mysql-5.1-maint clone. We now have 3 new replications tools and one tool that has been refactored. 1) include/wait_for_slave_to_stop.inc replaces the old mysqltest.c wait_for_slave_to_stop. NEW: 2) include/wait_for_slave_sql_to_stop.inc is for when you are expecting the slave to get an SQL error and waiting for the SQL Thread to stop. 3) include/wait_for_slave_io_to_stop.inc is used for test that you expect sometype of IO error and the IO Thread to stop. 4) include/wait_for_slave_to_start.inc for waiting for the slave to completely start before moving forward in the test. All 4 tests have a built in loop that will stop the test if any of the tools take too long. mysql-test/include/wait_for_slave_to_stop.inc: Updated previous commit to include Magnus's change request from review. In addition, I moved it from the mysql-5.1 to mysql-5.1-maint clone. We now have 3 new replications tools and one tool that has been refactored. 1) include/wait_for_slave_to_stop.inc replaces the old mysqltest.c wait_for_slave_to_stop. NEW: 2) include/wait_for_slave_sql_to_stop.inc is for when you are expecting the slave to get an SQL error and waiting for the SQL Thread to stop. 3) include/wait_for_slave_io_to_stop.inc is used for test that you expect sometype of IO error and the IO Thread to stop. 4) include/wait_for_slave_to_start.inc for waiting for the slave to completely start before moving forward in the test. All 4 tests have a built in loop that will stop the test if any of the tools take too long. mysql-test/t/rpl_critical_errors.test: Updated to use new tool(s) mysql-test/t/rpl_dual_pos_advance.test: Updated to use new tool(s) mysql-test/t/rpl_known_bugs_detection.test: Updated to use new tool(s) mysql-test/t/rpl_rotate_logs.test: Updated to use new tool(s) mysql-test/t/rpl_row_inexist_tbl.test: Updated to use new tool(s) mysql-test/extra/rpl_tests/rpl_extraSlave_Col.test: Updated to use new tool(s) mysql-test/extra/rpl_tests/rpl_loaddata.test: Updated to use new tool(s) mysql-test/extra/rpl_tests/rpl_row_tabledefs.test: Updated to use new tool(s) mysql-test/extra/rpl_tests/rpl_stm_000001.test: Updated to use new tool(s) mysql-test/extra/rpl_tests/rpl_stm_EE_err2.test: Updated to use new tool(s)
66 lines
1.7 KiB
Text
66 lines
1.7 KiB
Text
# Test for BUG#26551
|
|
#
|
|
|
|
# This test is unfortunately very fragile and very dependent on the
|
|
# load of the computer. The test is therefore disabled normally. It is
|
|
# entered here to demonstrate how to check that the bug is actually
|
|
# solved.
|
|
|
|
--echo Turn on parsing to run this test
|
|
|
|
disable_parsing;
|
|
|
|
source include/master-slave.inc;
|
|
|
|
connection master;
|
|
CREATE TABLE t1 (data LONGBLOB) ENGINE=MYISAM;
|
|
CREATE TABLE t2 (data LONGBLOB) ENGINE=MYISAM;
|
|
|
|
INSERT INTO t1 (data) VALUES (repeat('a',1024*1024));
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
INSERT INTO t1 SELECT * FROM t1;
|
|
sync_slave_with_master;
|
|
|
|
connection master;
|
|
send INSERT INTO t2 SELECT * FROM t1;
|
|
|
|
connection master1;
|
|
|
|
# This sleep is picked so that the query above has started to insert
|
|
# some rows into t2. If it hasn't the slave will not stop below.
|
|
sleep 4;
|
|
|
|
# SHOW PROCESSLIST;
|
|
|
|
# Code for the 5.1 server to get the thread id of the thread executing
|
|
# the query above.
|
|
#
|
|
#SET @id = 0;
|
|
#SELECT id INTO @id
|
|
# FROM information_schema.processlist
|
|
# WHERE info LIKE 'INSERT INTO t2%';
|
|
|
|
# This is the connection that is executing the INSERT INTO t2...
|
|
KILL QUERY 2;
|
|
|
|
connection slave;
|
|
|
|
# Here the slave will only stop if the query above actually started
|
|
# inserting some rows into t2. Otherwise, it will hang forever.
|
|
--source include/wait_for_slave_to_stop.inc
|
|
|
|
# The following should be 0
|
|
SELECT COUNT(*) FROM t2;
|
|
|
|
# ... and there the error code should be 1317 (ER_QUERY_INTERRUPTED)
|
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
|
--replace_column 1 # 7 # 8 # 9 # 20 # 22 # 23 # 33 #
|
|
query_vertical SHOW SLAVE STATUS;
|
|
|
|
enable_parsing;
|