binlog_multi_engine.test 3.16 KB
Newer Older
1 2 3 4 5
# Test to test how logging is done depending on the capabilities of
# the engines. Unfortunately, we don't have a good row-only logging
# engine, and NDB does not really cut is since it is also
# self-logging. I'm using it nevertheless.

6 7
source include/have_blackhole.inc;
source include/have_ndb.inc;
tomas@poseidon.mysql.com's avatar
tomas@poseidon.mysql.com committed
8
source include/have_log_bin.inc;
9

10 11
call mtr.add_suppression("Unsafe statement binlogged in statement format since BINLOG_FORMAT = STATEMENT");

12 13 14 15
CREATE TABLE t1m (m INT, n INT) ENGINE=MYISAM;
CREATE TABLE t1b (b INT, c INT) ENGINE=BLACKHOLE;
CREATE TABLE t1n (e INT, f INT) ENGINE=NDB;

16 17
RESET MASTER;

18 19 20
SET SESSION BINLOG_FORMAT=STATEMENT;

INSERT INTO t1b VALUES (1,1), (1,2), (2,1), (2,2);
21
INSERT INTO t1m VALUES (1,1), (1,2), (2,1), (2,2);
22 23

UPDATE t1m, t1b SET m = 2, b = 3 WHERE n = c;
24

25 26
# Here and below we need to wait when some event appears in binlog
# to avoid unsrted mixing local events and from NDB
27
let $wait_binlog_event= COMMIT;
28
source include/wait_for_binlog_event.inc;
29 30
let $event= query_get_value(SHOW BINLOG EVENTS, Info, 9);
--echo The last event before the COMMIT is $event
31

32 33 34
echo *** Please look in binlog_multi_engine.test if you have a diff here ****;
START TRANSACTION;
INSERT INTO t1n VALUES (1,1), (1,2), (2,1), (2,2);
35 36
UPDATE t1m, t1n SET m = 2, e = 3 WHERE n = f;
UPDATE t1n, t1b SET e = 2, b = 3 WHERE f = c;
37
COMMIT;
38

39 40 41
let $wait_binlog_event= COMMIT;
source include/wait_for_binlog_event.inc;

42 43 44 45
TRUNCATE t1m;
TRUNCATE t1b;
TRUNCATE t1n;

46 47 48
let $wait_binlog_event= t1n;
source include/wait_for_binlog_event.inc;

49 50 51 52
source include/show_binlog_events.inc;

RESET MASTER;

53 54 55
SET SESSION BINLOG_FORMAT=MIXED;

INSERT INTO t1b VALUES (1,1), (1,2), (2,1), (2,2);
56 57
INSERT INTO t1m VALUES (1,1), (1,2), (2,1), (2,2);

58
let $wait_binlog_event= COMMIT;
59
source include/wait_for_binlog_event.inc;
60 61
let $event= query_get_value(SHOW BINLOG EVENTS, Info, 6);
--echo The last event before the COMMIT is $event
62

63 64
INSERT INTO t1n VALUES (1,1), (1,2), (2,1), (2,2);

65 66 67
let $wait_binlog_event= COMMIT;
source include/wait_for_binlog_event.inc;

68
UPDATE t1m, t1b SET m = 2, b = 3 WHERE n = c;
69
error ER_BINLOG_MULTIPLE_ENGINES_AND_SELF_LOGGING_ENGINE;
70
UPDATE t1m, t1n SET m = 2, e = 3 WHERE n = f;
71 72 73 74 75 76 77

# Not possible to test this since NDB writes its own binlog, which
# might cause it to be out of sync with the results from MyISAM.
# This will generate an error once BUG#28722 is fixed.

#UPDATE t1m, t1n SET m = 2, e = 3 WHERE n = f;

78 79 80 81
TRUNCATE t1m;
TRUNCATE t1b;
TRUNCATE t1n;

82 83 84 85
source include/show_binlog_events.inc;

RESET MASTER;

86 87 88
SET SESSION BINLOG_FORMAT=ROW;

INSERT INTO t1m VALUES (1,1), (1,2), (2,1), (2,2);
89

90 91 92
INSERT INTO t1b VALUES (1,1), (1,2), (2,1), (2,2);
INSERT INTO t1n VALUES (1,1), (1,2), (2,1), (2,2);

93
error ER_BINLOG_MULTIPLE_ENGINES_AND_SELF_LOGGING_ENGINE;
94
UPDATE t1m, t1n SET m = 2, e = 3 WHERE n = f;
95 96 97 98 99 100 101

# Not possible to test this since NDB writes its own binlog, which
# might cause it to be out of sync with the results from MyISAM.
# This will generate an error once BUG#28722 is fixed.

#UPDATE t1m, t1n SET m = 2, e = 3 WHERE n = f;

102
error ER_BINLOG_MULTIPLE_ENGINES_AND_SELF_LOGGING_ENGINE;
103 104
UPDATE t1n, t1b SET e = 2, b = 3 WHERE f = c;

105 106 107 108
source include/show_binlog_events.inc;

RESET MASTER;

109
DROP TABLE t1m, t1b, t1n;
110