rpl_bug41902.test 1.56 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
# Test for Bug #41902 MYSQL_BIN_LOG::reset_logs() doesn't call my_error()
#                     in face of an error
#

source include/have_debug.inc;
source include/master-slave.inc;

-- disable_query_log
CALL mtr.add_suppression("Failed to locate old binlog or relay log files");
CALL mtr.add_suppression('MYSQL_BIN_LOG::purge_logs was called with file ..master-bin.000001 not listed in the index.');
-- enable_query_log
--source include/sync_slave_sql_with_master.inc

#
# test checks that 
# a. there is no crash when find_log_pos() returns with an error
#    that tests expect to receive;
# b. in the case of multiple error messages the first error message is 
#    reported to the user and others are available as warnings.
#

connection slave;
stop slave;

SET @@debug="d,simulate_find_log_pos_error";

--error ER_UNKNOWN_TARGET_BINLOG
reset slave;
show warnings;

SET @@debug="";
reset slave;
change master to master_host='dummy';

SET @@debug="d,simulate_find_log_pos_error";

--error ER_UNKNOWN_TARGET_BINLOG
change master to master_host='dummy';

SET @@debug="";
reset slave;
change master to master_host='dummy';

connection master;
SET @@debug="d,simulate_find_log_pos_error";
--error ER_UNKNOWN_TARGET_BINLOG
reset master;

SET @@debug="";
reset master;

SET @@debug="d,simulate_find_log_pos_error";
--error ER_UNKNOWN_TARGET_BINLOG
purge binary logs to 'master-bin.000001';

SET @@debug="";
purge binary logs to 'master-bin.000001';

--echo ==== clean up ====
--connection slave
CHANGE MASTER TO MASTER_HOST = '127.0.0.1';
--let $rpl_only_running_threads= 1
--source include/rpl_end.inc