mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 04:53:01 +01:00
3cc49bbe74
commit is specific for 5.0 to eliminated non-deterministic tests. Those tests run only in 5.1 env where there is a necessary devices such as processlist table of info_schema. mysql-test/r/binlog_killed.result: results changed mysql-test/t/binlog_killed.test: removing non-deterministic part of the test mysql-test/t/binlog_killed_simulate.test: adding the guard same as for 5.1 version
66 lines
2 KiB
Text
66 lines
2 KiB
Text
-- source include/have_debug.inc
|
|
#
|
|
# bug#27571 asynchronous setting mysql_$query()'s local error and
|
|
# Query_log_event::error_code
|
|
#
|
|
|
|
--disable_warnings
|
|
drop table if exists t1,t2;
|
|
--enable_warnings
|
|
|
|
#
|
|
# Checking that killing upon successful row-loop does not affect binlogging
|
|
#
|
|
|
|
create table t1 (a int) engine=MyISAM;
|
|
insert into t1 set a=1;
|
|
reset master;
|
|
|
|
update t1 set a=2 /* will be "killed" after work has been done */;
|
|
|
|
# a proof the query is binlogged with no error
|
|
|
|
--exec $MYSQL_BINLOG --start-position=98 $MYSQLTEST_VARDIR/log/master-bin.000001 > $MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
eval select
|
|
(@a:=load_file("$MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog"))
|
|
is not null;
|
|
--replace_result $MYSQL_TEST_DIR MYSQL_TEST_DIR
|
|
let $error_code= `select @a like "%#%error_code=0%" /* must return 1 */`;
|
|
eval select $error_code /* must return 1 as query completed before got killed*/;
|
|
|
|
# cleanup for the sub-case
|
|
system rm $MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog;
|
|
|
|
|
|
#
|
|
# Checking that killing inside of row-loop for LOAD DATA into
|
|
# non-transactional table affects binlogging
|
|
#
|
|
|
|
create table t2 (a int, b int) ENGINE=MyISAM;
|
|
reset master;
|
|
--error ER_QUERY_INTERRUPTED
|
|
load data infile '../std_data_ln/rpl_loaddata.dat' into table t2 /* will be "killed" in the middle */;
|
|
|
|
|
|
# a proof the query is binlogged with an error
|
|
|
|
source include/show_binlog_events.inc;
|
|
|
|
--exec $MYSQL_BINLOG --start-position=98 $MYSQLTEST_VARDIR/log/master-bin.000001 > $MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
eval select
|
|
(@a:=load_file("$MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog"))
|
|
is not null;
|
|
--replace_result $MYSQL_TEST_DIR MYSQL_TEST_DIR
|
|
let $error_code= `select @a like "%#%error_code=0%" /* must return 0*/`;
|
|
eval select $error_code /* must return 0 to mean the killed query is in */;
|
|
|
|
# cleanup for the sub-case
|
|
system rm $MYSQLTEST_VARDIR/tmp/binlog_killed_bug27571.binlog;
|
|
|
|
|
|
drop table t1,t2;
|
|
|
|
--echo end of the tests
|