mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
38376746e3
This is not a fix to the bug. It only adds debug info, so that we can analyze the bug better next time it happens. Please revert the patch after the bug is fixed.
73 lines
2.2 KiB
Text
73 lines
2.2 KiB
Text
--source include/master-slave.inc
|
|
--source include/have_debug.inc
|
|
|
|
--echo **** On Master ****
|
|
CREATE TABLE t1 (a INT);
|
|
|
|
INSERT INTO t1 VALUES (1),(2),(3);
|
|
SELECT * FROM t1;
|
|
|
|
# This will generate an incident log event and store it in the binary
|
|
# log before the replace statement.
|
|
REPLACE INTO t1 VALUES (4);
|
|
--save_master_pos
|
|
SELECT * FROM t1;
|
|
|
|
connection slave;
|
|
--wait_for_slave_to_stop
|
|
|
|
# The 4 should not be inserted into the table, since the incident log
|
|
# event should have stop the slave.
|
|
--echo **** On Slave ****
|
|
#### BEGIN DEBUG INFO ADDED BY SVEN 2008-07-18 -- SEE BUG#38077 ####
|
|
let $tables= query_get_value(SHOW TABLES, Tables_in_test, 1);
|
|
if (`SELECT '$tables' != 't1'`)
|
|
{
|
|
--echo **** TEST CASE BUG! PRINTING DEBUG INFO! ****
|
|
--echo **** Dear developer, if you see this in the output of a test
|
|
--echo **** case run, please add all the information below as a
|
|
--echo **** comment to BUG#38077. If it's a pushbuild failure, please
|
|
--echo **** include a link to the push page.
|
|
--echo **** Thank you! /Sven
|
|
SHOW BINLOG EVENTS;
|
|
--echo **** master binlog ****
|
|
--error 0,1
|
|
--exec $MYSQL_BINLOG --hexdump $MYSQLTEST_VARDIR/log/master-bin.000001
|
|
--echo **** slave binlog ****
|
|
--error 0,1
|
|
--exec $MYSQL_BINLOG --hexdump $MYSQLTEST_VARDIR/log/slave-bin.000001
|
|
--echo **** slave status ****
|
|
query_vertical SHOW SLAVE STATUS;
|
|
--echo **** slave's master status ****
|
|
SHOW MASTER STATUS;
|
|
--echo **** slave binlog events ****
|
|
--echo [on master]
|
|
connection master;
|
|
--echo **** master status ****
|
|
SHOW MASTER STATUS;
|
|
--echo **** master binlog events ****
|
|
SHOW BINLOG EVENTS;
|
|
exit;
|
|
}
|
|
#### END DEBUG INFO ####
|
|
SELECT * FROM t1;
|
|
|
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
|
--replace_column 1 # 6 # 7 # 8 # 9 # 22 # 23 # 33 #
|
|
--query_vertical SHOW SLAVE STATUS
|
|
|
|
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
|
|
START SLAVE;
|
|
--sync_with_master
|
|
|
|
# Now, we should have inserted the row into the table and the slave
|
|
# should be running. We should also have rotated to a new binary log.
|
|
|
|
SELECT * FROM t1;
|
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
|
--replace_column 1 # 6 # 7 # 8 # 9 # 22 # 23 # 33 #
|
|
--query_vertical SHOW SLAVE STATUS
|
|
|
|
connection master;
|
|
DROP TABLE t1;
|
|
--sync_slave_with_master
|