include/master-slave.inc [connection master] connection master; connection slave; call mtr.add_suppression("Can.t find record in .t[12].* error.* 1032"); call mtr.add_suppression("Cannot delete or update a parent row: a foreign key constraint fails .* error.* 1451"); call mtr.add_suppression("Cannot add or update a child row: a foreign key constraint fails .* error.* 1452"); call mtr.add_suppression("Duplicate entry .1. for key .PRIMARY.* error.* 1062"); call mtr.add_suppression("Can't find record in 't1'"); call mtr.add_suppression("Can't find record in 't2'"); connection slave; set @old_slave_exec_mode= @@global.slave_exec_mode; set @@global.slave_exec_mode= IDEMPOTENT; connection master; create table ti1 (b int primary key) engine = innodb; create table ti2 (a int primary key, b int, foreign key (b) references ti1(b)) engine = innodb; set foreign_key_checks=1 /* ensure the check */; insert into ti1 values (1),(2),(3); insert into ti2 set a=2, b=2; connection slave; select * from ti1 order by b /* must be (1),(2),(3) */; b 1 2 3 insert into ti2 set a=1, b=1; select * from ti2 order by b /* must be (1,1) (2,2) */; a b 1 1 2 2 connection master; set @save_binlog_format= @@session.binlog_format; set @@session.binlog_format= row; delete from ti1 where b=1; select * from ti1 order by b /* must be (2),(3) */; b 2 3 connection slave; select * from ti1 order by b /* must stays as were on master (1),(2),(3) */; b 1 2 3 delete from ti1 where b=3; connection master; insert into ti2 set a=3, b=3; connection slave; select * from ti2 order by b /* must be (1,1),(2,2) - not inserted */; a b 1 1 2 2 connection slave; set global slave_exec_mode='IDEMPOTENT'; set global slave_exec_mode='STRICT'; set global slave_exec_mode='IDEMPOTENT,STRICT'; ERROR 42000: Variable 'slave_exec_mode' can't be set to the value of 'IDEMPOTENT,STRICT' select @@global.slave_exec_mode /* must be STRICT */; @@global.slave_exec_mode STRICT *** foreign keys errors as above now forces to stop connection master; set foreign_key_checks=0; drop table ti2, ti1; create table ti1 (b int primary key) engine = innodb; create table ti2 (a int primary key, b int, foreign key (b) references ti1(b)) engine = innodb; set foreign_key_checks=1 /* ensure the check */; insert into ti1 values (1),(2),(3); insert into ti2 set a=2, b=2; connection slave; select * from ti1 order by b /* must be (1),(2),(3) */; b 1 2 3 *** conspire future problem insert into ti2 set a=1, b=1; select * from ti2 order by b /* must be (1,1) (2,2) */; a b 1 1 2 2 connection master; delete from ti1 where b=1 /* offending delete event */; select * from ti1 order by b /* must be (2),(3) */; b 2 3 *** slave must stop (Trying to delete a referenced foreing key) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1451 select * from ti1 order by b /* must be (1),(2),(3) - not deleted */; b 1 2 3 set foreign_key_checks= 0; delete from ti2 where b=1; set foreign_key_checks= 1; set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; set global slave_exec_mode='STRICT'; connection master; connection slave; *** conspire the following insert failure *** conspire future problem delete from ti1 where b=3; connection master; insert into ti2 set a=3, b=3 /* offending write event */; *** slave must stop (Trying to insert an invalid foreign key) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1452 select * from ti2 order by b /* must be (2,2) */; a b 2 2 set foreign_key_checks= 0; insert into ti1 set b=3; set foreign_key_checks= 1; set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; set global slave_exec_mode='STRICT'; connection master; connection slave; select * from ti2 order by b /* must be (2,2),(3,3) */; a b 2 2 3 3 *** other errors *** conspiring query insert into ti1 set b=1; connection master; insert into ti1 set b=1 /* offending write event */; *** slave must stop (Trying to insert a dupliacte key) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1062 set foreign_key_checks= 0; delete from ti1 where b=1; set foreign_key_checks= 1; set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; set global slave_exec_mode='STRICT'; connection master; CREATE TABLE t1 (a INT PRIMARY KEY); CREATE TABLE t2 (a INT); INSERT INTO t1 VALUES (-1),(-2),(-3); INSERT INTO t2 VALUES (-1),(-2),(-3); connection slave; DELETE FROM t1 WHERE a = -2; DELETE FROM t2 WHERE a = -2; connection master; DELETE FROM t1 WHERE a = -2; *** slave must stop (Key was not found) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1032 set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; set global slave_exec_mode='STRICT'; connection master; DELETE FROM t2 WHERE a = -2; *** slave must stop (Key was not found) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1032 set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; set global slave_exec_mode='STRICT'; UPDATE t1 SET a = 1 WHERE a = -1; UPDATE t2 SET a = 1 WHERE a = -1; connection master; UPDATE t1 SET a = 1 WHERE a = -1; *** slave must stop (Key was not found) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1032 set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; set global slave_exec_mode='STRICT'; connection master; UPDATE t2 SET a = 1 WHERE a = -1; *** slave must stop (Key was not found) connection slave; include/wait_for_slave_sql_to_stop.inc Last_SQL_Error 1032 set global slave_exec_mode='IDEMPOTENT'; start slave sql_thread; connection master; connection slave; SET @@global.slave_exec_mode= @old_slave_exec_mode; connection master; drop table t1,t2,ti2,ti1; connection slave; set @@global.slave_exec_mode= @old_slave_exec_mode; *** end of tests include/rpl_end.inc