mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +03:00 
			
		
		
		
	 aaa9ed3eff
			
		
	
	aaa9ed3eff
	
	
	
		
			
			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;
 |