mirror of
https://github.com/MariaDB/server.git
synced 2025-02-01 19:41:47 +01:00
cc05440836
Some of the test cases reference to binlog position and these position numbers are written into result explicitly. It is difficult to maintain if log event format changes. There are a couple of cases explicit position number appears, we handle them in different ways A. 'CHANGE MASTER ...' with MASTER_LOG_POS or/and RELAY_LOG_POS options Use --replace_result to mask them. B. 'SHOW BINLOG EVENT ...' Replaced by show_binlog_events.inc or wait_for_binlog_event.inc. show_binlog_events.inc file's function is enhanced by given $binlog_file and $binlog_limit. C. 'SHOW SLAVE STATUS', 'show_slave_status.inc' and 'show_slave_status2.inc' For the test cases just care a few items in the result of 'SHOW SLAVE STATUS', only the items related to each test case are showed. 'show_slave_status.inc' is rebuild, only the given items in $status_items will be showed. 'check_slave_is_running.inc' and 'check_slave_no_error.inc' and 'check_slave_param.inc' are auxiliary files helping to show running status and error information easily.
51 lines
1.6 KiB
Text
51 lines
1.6 KiB
Text
# Verify that after CHANGE MASTER, replication (I/O thread and SQL
|
|
# thread) restart from where SQL thread left, not from where
|
|
# I/O thread left (some old bug fixed in 4.0.17)
|
|
|
|
source include/master-slave.inc;
|
|
|
|
connection master;
|
|
# Make SQL slave thread advance a bit
|
|
create table t1(n int);
|
|
sync_slave_with_master;
|
|
select * from t1;
|
|
# Now stop it and make I/O slave thread be ahead
|
|
stop slave sql_thread;
|
|
connection master;
|
|
insert into t1 values(1);
|
|
insert into t1 values(2);
|
|
save_master_pos;
|
|
let $slave_param= Read_Master_Log_Pos;
|
|
let $slave_param_value= query_get_value(SHOW MASTER STATUS, Position, 1);
|
|
connection slave;
|
|
source include/wait_for_slave_param.inc;
|
|
source include/stop_slave.inc;
|
|
|
|
let $read_pos= query_get_value(SHOW SLAVE STATUS, Read_Master_Log_Pos, 1);
|
|
let $exec_pos= query_get_value(SHOW SLAVE STATUS, Exec_Master_Log_Pos, 1);
|
|
if (`SELECT $read_pos = $exec_pos`)
|
|
{
|
|
source include/show_rpl_debug_info.inc;
|
|
echo 'Read_Master_Log_Pos: $read_pos' == 'Exec_Master_Log_Pos: $exec_pos';
|
|
die Failed because Read_Master_Log_Pos is equal to Exec_Master_Log_Pos;
|
|
}
|
|
change master to master_user='root';
|
|
let $read_pos= query_get_value(SHOW SLAVE STATUS, Read_Master_Log_Pos, 1);
|
|
let $exec_pos= query_get_value(SHOW SLAVE STATUS, Exec_Master_Log_Pos, 1);
|
|
if (`SELECT $read_pos <> $exec_pos`)
|
|
{
|
|
source include/show_rpl_debug_info.inc;
|
|
echo 'Read_Master_Log_Pos: $read_pos' <> 'Exec_Master_Log_Pos: $exec_pos';
|
|
die Failed because Read_Master_Log_Pos is not equal to Exec_Master_Log_Pos;
|
|
}
|
|
|
|
start slave;
|
|
sync_with_master;
|
|
select * from t1;
|
|
connection master;
|
|
drop table t1;
|
|
save_master_pos;
|
|
connection slave;
|
|
sync_with_master;
|
|
|
|
# End of 4.1 tests
|