mirror of
https://github.com/MariaDB/server.git
synced 2025-09-02 09:41:40 +03:00
The bug case is similar to one fixed earlier bug_49536. Deadlock involving LOCK_log appears to be possible because the purge running thread is holding LOCK_log whereas there is no sense of doing that and which fact was exploited by the earlier bug fixes. Fixed with small reengineering of rotate_and_purge(), adding two new methods and setting up a policy to execute those instead of the former rotate_and_purge(RP_LOCK_LOG_IS_ALREADY_LOCKED). The policy for using rotate(), purge() is that if the caller acquires LOCK_log itself, it should call rotate(), release the mutex and run purge(). Side effect of this patch is refining error message of bug@11747416 to print the whole path.
70 lines
1.8 KiB
Plaintext
70 lines
1.8 KiB
Plaintext
#
|
|
# Bug#11747416 : 32228 A disk full makes binary log corrupt.
|
|
#
|
|
#
|
|
# The test demonstrates reading from binlog error propagation to slave
|
|
# and reporting there.
|
|
# Conditions for the bug include a crash at time of the last event to
|
|
# the binlog was written partly. With the fixes the event is not sent out
|
|
# any longer, but rather the dump thread sends out a sound error message.
|
|
#
|
|
# Crash is not simulated. A binlog with partly written event in its end is installed
|
|
# and replication is started from it.
|
|
#
|
|
|
|
--source include/master-slave.inc
|
|
--source include/have_binlog_format_mixed.inc
|
|
#
|
|
# Bug#13050593 swallows `\' from Last_IO_Error
|
|
# todo: uncomment the filter once the bug is fixed.
|
|
#
|
|
--source include/not_windows.inc
|
|
|
|
call mtr.add_suppression("Error in Log_event::read_log_event()");
|
|
|
|
--connection master
|
|
--let $datadir= `SELECT @@datadir`
|
|
|
|
--let $rpl_server_number= 1
|
|
--source include/rpl_stop_server.inc
|
|
|
|
--remove_file $datadir/master-bin.000001
|
|
--copy_file $MYSQL_TEST_DIR/std_data/bug11747416_32228_binlog.000001 $datadir/master-bin.000001
|
|
|
|
--let $rpl_server_number= 1
|
|
--source include/rpl_start_server.inc
|
|
|
|
--source include/wait_until_connected_again.inc
|
|
|
|
# evidence of the partial binlog
|
|
--error ER_ERROR_WHEN_EXECUTING_COMMAND
|
|
show binlog events;
|
|
|
|
--connection slave
|
|
call mtr.add_suppression("Slave I/O: Got fatal error 1236 from master when reading data from binary log");
|
|
stop slave;
|
|
reset slave;
|
|
start slave;
|
|
|
|
# ER_MASTER_FATAL_ERROR_READING_BINLOG 1236
|
|
--let $slave_param=Last_IO_Errno
|
|
--let $slave_param_value=1236
|
|
--source include/wait_for_slave_param.inc
|
|
|
|
--let $status_items= Last_IO_Errno, Last_IO_Error
|
|
--source include/show_slave_status.inc
|
|
|
|
#
|
|
# Cleanup
|
|
#
|
|
|
|
--connection master
|
|
reset master;
|
|
|
|
--connection slave
|
|
stop slave;
|
|
reset slave;
|
|
drop table t; # table was created from binlog. it does not exist on master.
|
|
|
|
--echo End of the tests
|