File: xa-6.test

package info (click to toggle)
mariadb-10.0 10.0.16-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 416,512 kB
  • sloc: cpp: 1,351,103; ansic: 803,086; perl: 59,621; pascal: 32,136; sh: 25,156; yacc: 14,897; xml: 5,194; sql: 4,651; cs: 4,647; makefile: 4,113; python: 2,526; ruby: 2,496; lex: 1,427; asm: 295; awk: 54; php: 22; sed: 16
file content (117 lines) | stat: -rw-r--r-- 2,509 bytes parent folder | download
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
--source include/have_tokudb.inc
--source include/have_debug.inc

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

# Ensure that all tables are properly closed before we start simulating
# crashes
FLUSH TABLES;

# 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="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="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="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="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="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;