File: rpl_autoinc_func_invokes_trigger.test

package info (click to toggle)
percona-xtrabackup 2.2.3-2.1
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 293,260 kB
  • ctags: 146,881
  • sloc: cpp: 1,051,960; ansic: 570,217; java: 54,595; perl: 53,495; pascal: 44,194; sh: 27,826; yacc: 15,314; python: 12,142; xml: 7,848; sql: 4,125; makefile: 1,459; awk: 785; lex: 758
file content (55 lines) | stat: -rw-r--r-- 1,823 bytes parent folder | download | duplicates (2)
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
#
# This test verifies if concurrent transactions that call a 
# function which invokes a 'after/before insert action' trigger 
# that inserts more than one values into a table with autoinc 
# column will make the autoinc values become inconsistent on 
# master and slave.
#

connection master;
create table t1(a int) engine=innodb;
create table t2(i1 int not null auto_increment, a int, primary key(i1)) engine=innodb;
create table t3(i1 int not null auto_increment, a int, primary key(i1)) engine=innodb;
delimiter |;
CREATE FUNCTION f1_two_inserts_trigger() RETURNS INTEGER
BEGIN
   INSERT INTO t2(a) values(2),(3);
   INSERT INTO t2(a) values(2),(3);
   RETURN 1;
END |
eval create trigger tr11 $insert_action on t2 for each row begin
    insert into t3(a) values(new.a);
    insert into t3(a) values(new.a);
end |
delimiter ;|
begin;
let $binlog_start= query_get_value("SHOW MASTER STATUS", Position, 1);
insert into t1(a) values(f1_two_inserts_trigger());

connection master1;
#The default autocommit is set to 1, so the statement is auto committed
insert into t2(a) values(4),(5);

connection master;
commit;
insert into t1(a) values(f1_two_inserts_trigger());
--echo # To verify if insert/update in an autoinc column causes statement to be logged in row format
source include/show_binlog_events.inc;
commit;

connection master;
--source include/sync_slave_sql_with_master.inc
--echo #Test if the results are consistent on master and slave
--echo #for 'CALLS A FUNCTION which INVOKES A TRIGGER with $insert_action action'
let $diff_tables= master:t2, slave:t2;
source include/diff_tables.inc;
let $diff_tables= master:t3, slave:t3;
source include/diff_tables.inc;

connection master;
drop table t1;
drop table t2;
drop table t3;
drop function f1_two_inserts_trigger;
--source include/sync_slave_sql_with_master.inc