mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 17:33:44 +01:00
216 lines
5.8 KiB
Text
216 lines
5.8 KiB
Text
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");
|
|
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
|