mirror of
https://github.com/MariaDB/server.git
synced 2025-10-24 07:13:33 +03:00

WL#3397 Refactoring storage engine test cases (for falcon) It contains also fixes according to code review. Contents: Testcases which were in history dedicated to InnoDB or MyISAM only. Modifications: 1. Shift the main testing code into include/<testing field>.inc Introduce $variables which can be used to omit tests for features which are not supported by certain storage engines. 2. The storage engine to be tested is assigned within the toplevel script (t/<whatever>_<engine>.test) via variable $engine_type and the the main testing code is sourced from include/<testing field>.inc 3. Some toplevel testscripts have to be renamed to - avoid immediate or future namespace clashes - show via filename which storage engine is tested 4. Minor code cleanup like remove trailing spaces, some additional comments ....
115 lines
2.1 KiB
Plaintext
115 lines
2.1 KiB
Plaintext
# Establish connection con1 (user=root)
|
|
# Establish connection con2 (user=root)
|
|
drop table if exists t1,t2;
|
|
# Switch to connection con1
|
|
create table t1 (id integer, x integer) engine = InnoDB;
|
|
insert into t1 values(0, 0);
|
|
set autocommit=0;
|
|
SELECT * from t1 where id = 0 FOR UPDATE;
|
|
id x
|
|
0 0
|
|
# Switch to connection con2
|
|
set autocommit=0;
|
|
update t1 set x=2 where id = 0;
|
|
# Switch to connection con1
|
|
update t1 set x=1 where id = 0;
|
|
select * from t1;
|
|
id x
|
|
0 1
|
|
commit;
|
|
# Switch to connection con2
|
|
commit;
|
|
# Switch to connection con1
|
|
select * from t1;
|
|
id x
|
|
0 2
|
|
commit;
|
|
drop table t1;
|
|
# Switch to connection con1
|
|
create table t1 (id integer, x integer) engine = InnoDB;
|
|
create table t2 (b integer, a integer) engine = InnoDB;
|
|
insert into t1 values(0, 0), (300, 300);
|
|
insert into t2 values(0, 10), (1, 20), (2, 30);
|
|
commit;
|
|
set autocommit=0;
|
|
select * from t2;
|
|
b a
|
|
0 10
|
|
1 20
|
|
2 30
|
|
update t2 set a=100 where b=(SELECT x from t1 where id = b FOR UPDATE);
|
|
select * from t2;
|
|
b a
|
|
0 100
|
|
1 20
|
|
2 30
|
|
select * from t1;
|
|
id x
|
|
0 0
|
|
300 300
|
|
# Switch to connection con2
|
|
set autocommit=0;
|
|
update t1 set x=2 where id = 0;
|
|
# Switch to connection con1
|
|
update t1 set x=1 where id = 0;
|
|
select * from t1;
|
|
id x
|
|
0 1
|
|
300 300
|
|
commit;
|
|
# Switch to connection con2
|
|
commit;
|
|
# Switch to connection con1
|
|
select * from t1;
|
|
id x
|
|
0 2
|
|
300 300
|
|
commit;
|
|
drop table t1, t2;
|
|
create table t1 (id integer, x integer) engine = InnoDB;
|
|
create table t2 (b integer, a integer) engine = InnoDB;
|
|
insert into t1 values(0, 0), (300, 300);
|
|
insert into t2 values(0, 0), (1, 20), (2, 30);
|
|
commit;
|
|
# Switch to connection con1
|
|
select a,b from t2 UNION SELECT id, x from t1 FOR UPDATE;
|
|
a b
|
|
0 0
|
|
20 1
|
|
30 2
|
|
300 300
|
|
select * from t2;
|
|
b a
|
|
0 0
|
|
1 20
|
|
2 30
|
|
select * from t1;
|
|
id x
|
|
0 0
|
|
300 300
|
|
# Switch to connection con2
|
|
update t2 set a=2 where b = 0;
|
|
select * from t2;
|
|
b a
|
|
0 2
|
|
1 20
|
|
2 30
|
|
update t1 set x=2 where id = 0;
|
|
# Switch to connection con1
|
|
update t1 set x=1 where id = 0;
|
|
select * from t1;
|
|
id x
|
|
0 1
|
|
300 300
|
|
commit;
|
|
# Switch to connection con2
|
|
commit;
|
|
# Switch to connection con1
|
|
select * from t1;
|
|
id x
|
|
0 2
|
|
300 300
|
|
commit;
|
|
# Switch to connection default + disconnect con1 and con2
|
|
drop table t1, t2;
|