summaryrefslogtreecommitdiff
path: root/storage/tokudb/mysql-test/tokudb_bugs/t/xa-6.test
blob: c6c11f633e18d94082faa84e92b5952156931558 (plain)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
--source include/have_tokudb.inc
--source include/have_debug.inc
# Valgrind would report memory leaks on the intentional crashes
-- source include/not_valgrind.inc
# Embedded server does not support crashing
-- source include/not_embedded.inc
# Avoid CrashReporter popup on Mac
-- source include/not_crashrep.inc

--disable_warnings
drop table if exists t1;
--enable_warnings


# test that simple xa commands work with TokuDB
CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=tokudb;

xa begin 'a','ab';
insert into t1 values (1);
select * from t1;
xa end 'a','ab';
SET SESSION debug_dbug="d,tokudb_crash_prepare_before";
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect

--error 2013
xa prepare 'a','ab';

--enable_reconnect

--source include/wait_until_connected_again.inc

--error ER_XAER_NOTA
xa commit'a','ab';
drop table t1;

# this warning is expected, we want to test that
# a prepared transaction is around after we come back up
CALL mtr.add_suppression("Found 1 prepared XA transactions");

CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=tokudb;
xa begin 'a','ab';
insert into t1 values (1);
select * from t1;
xa end 'a','ab';
SET SESSION debug_dbug="d,tokudb_crash_prepare_after";
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect


--error 2013
xa prepare 'a','ab';


--enable_reconnect

--source include/wait_until_connected_again.inc

xa commit 'a','ab';
select * from t1;
drop table t1;

CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=tokudb;
xa begin 'a','ab';
insert into t1 values (1);
select * from t1;
xa end 'a','ab';
SET SESSION debug_dbug="d,tokudb_crash_prepare_after";
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect

--error 2013
xa prepare 'a','ab';


--enable_reconnect

--source include/wait_until_connected_again.inc

xa rollback 'a','ab';
select * from t1;
drop table t1;

CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=tokudb;
xa begin 'a','ab';
insert into t1 values (1);
select * from t1;
xa end 'a','ab';
SET SESSION debug_dbug="d,tokudb_crash_commit_before";
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect

xa prepare 'a','ab';
--error 2013
xa commit 'a','ab';

--enable_reconnect

--source include/wait_until_connected_again.inc

xa commit 'a','ab';
select * from t1;
drop table t1;

CREATE TABLE t1 (a INT PRIMARY KEY) ENGINE=tokudb;
xa begin 'a','ab';
insert into t1 values (1);
select * from t1;
xa end 'a','ab';
SET SESSION debug_dbug="d,tokudb_crash_commit_before";
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect


xa prepare 'a','ab';
--error 2013
xa commit 'a','ab';

--enable_reconnect

--source include/wait_until_connected_again.inc

xa rollback 'a','ab';
select * from t1;
drop table t1;