mirror of
				https://github.com/MariaDB/server.git
				synced 2025-10-25 18:38:00 +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 ....
mysql-test/t/unsafe_binlog_innodb-master.opt:
  Rename: mysql-test/t/innodb_unsafe_binlog-master.opt -> mysql-test/t/unsafe_binlog_innodb-master.opt
mysql-test/r/read_many_rows_innodb.result:
  Rename: mysql-test/r/innodb-big.result -> mysql-test/r/read_many_rows_innodb.result
mysql-test/t/cache_innodb-master.opt:
  Rename: mysql-test/t/innodb_cache-master.opt -> mysql-test/t/cache_innodb-master.opt
mysql-test/t/concurrent_innodb-master.opt:
  Rename: mysql-test/t/innodb_concurrent-master.opt -> mysql-test/t/concurrent_innodb-master.opt
BitKeeper/deleted/.del-index_merge.result:
  Delete: mysql-test/r/index_merge.result
BitKeeper/deleted/.del-index_merge_innodb.result:
  Delete: mysql-test/r/index_merge_innodb.result
BitKeeper/deleted/.del-index_merge_innodb2.result:
  Delete: mysql-test/r/index_merge_innodb2.result
BitKeeper/deleted/.del-index_merge_ror.result:
  Delete: mysql-test/r/index_merge_ror.result
BitKeeper/deleted/.del-index_merge_ror_cpk.result:
  Delete: mysql-test/r/index_merge_ror_cpk.result
mysql-test/r/index_merge_innodb.result:
  BitKeeper file /home/matthias/Arbeit/mysql-5.1-engines/src-1/mysql-test/r/index_merge_innodb.result
mysql-test/t/index_merge_innodb.test:
  BitKeeper file /home/matthias/Arbeit/mysql-5.1-engines/src-1/mysql-test/t/index_merge_innodb.test
mysql-test/t/index_merge_myisam.test:
  BitKeeper file /home/matthias/Arbeit/mysql-5.1-engines/src-1/mysql-test/t/index_merge_myisam.test
mysql-test/include/concurrent.inc:
  1. This file contains now the main testing code of the former t/innodb_concurrent.test.
  2. It is now sourced by t/concurrent_innodb.test.
mysql-test/include/deadlock.inc:
  1. This file contains now the main testing code of the former t/innodb-deadlock.test
  2. It is now sourced by t/deadlock_innodb.test.
mysql-test/include/handler.inc:
  1. This file contains now the main testing code of the former t/innodb_handler.test + t/handler.test.
  2. It is now sourced by t/handler_myisam.test and t/handler_innodb.test.
mysql-test/include/index_merge1.inc:
  1. This file contains now the main testing code of the former t/index_merge.test.
  2. It is now sourced by t/index_merge_myisam.test.
mysql-test/include/index_merge2.inc:
  1. This file contains now the main code of t/index_merge_innodb.test.
  2. It is sourced by t/index_merge_myisam.test and t/index_merge_innodb.test.
mysql-test/include/index_merge_2sweeps.inc:
  1. This file contains now the main code of the former t/index_merge_innodb2.test.
  2. It is sourced by t/index_merge_myisam.test and t/index_merge_innodb.test.
mysql-test/include/index_merge_ror.inc:
  1. This file contains now the main code of the former t/index_merge_ror.test.
  2. It is sourced by t/index_merge_myisam.test.
mysql-test/include/index_merge_ror_cpk.inc:
  1. This file contains now the main testing code of the former t/index_merge_ror_cpk.test.
  2. It is now sourced by t/index_merge_myisam.test and t/index_merge_innodb.test.
mysql-test/include/mix1.inc:
  1. This file contains now the main testing code of the t/innodb_mysql.test
  2. The name mix1.inc was used because the test contains subtests for different fields.
  3. It is sourced by t/innodb_mysql.test.
  4. Fixes:
      - Assign $other_engine_type instead of hardcoded MyISAM.
      - improve comment
      - remove redundant subtest
      - analyze table t4 instead of wrong table t1
      - remove not needed "eval set storage_engine = $engine_type;"
mysql-test/include/mix2.inc:
  1. This file is a copy of the main testing code of the t/innodb.test
     A copy has to be used, because t/innodb.test is to be maintained by INNOBASE only.
  2. The name mix2.inc was used because the test contains subtests for different fields.
  3. It is sourced by t/mix2_myisam.test.
  4. Fixes:
      - improved comment
      - additional "eval SET SESSION STORAGE_ENGINE = $other_engine_type;" at beginning of tests
      - assign $other_engine_type instead of hardcoded MyISAM or HEAP
      - assign $other_engine_type where it is needed to preserve test logics
      - correct logical bugs
      - improve(extend) "checksum table" test
mysql-test/include/query_cache.inc:
  1. This file contains now the main testing code of the former t/innodb_cache.test.
  2. It is now sourced by t/cache_innodb.test
mysql-test/include/read_many_rows.inc:
  1. This file contains now the main testing code of the former t/innodb_big.test.
  2. It is now sourced by t/read_many_rows_innodb.test.
mysql-test/include/rowid_order.inc:
  1. This file contains now the main testing code of t/rowid_order_innodb.test.
  2. It is now sourced by t/rowid_order_innodb.test.
mysql-test/include/unsafe_binlog.inc:
  1. This file contains now the main testing code of the former t/innodb_unsafe_binlog.test.
  2. It is now sourced by t/unsafe_binlog_innodb.test.
mysql-test/r/cache_innodb.result:
  Updated result
mysql-test/r/concurrent_innodb.result:
  Updated result
mysql-test/r/deadlock_innodb.result:
  Updated result
mysql-test/r/handler_innodb.result:
  Updated result
mysql-test/r/handler_myisam.result:
  Updated result
mysql-test/r/index_merge_myisam.result:
  Updated result
mysql-test/r/innodb_mysql.result:
  Updated result
mysql-test/r/mix2_myisam.result:
  Updated result
mysql-test/r/rowid_order_innodb.result:
  Updated result
mysql-test/r/unsafe_binlog_innodb.result:
  Updated result
mysql-test/t/cache_innodb.test:
  1. Renaming of t/innodb_cache.test to t/cache_innodb.test
  2. Main code is now sourced from include/query_cache.inc.
mysql-test/t/concurrent_innodb.test:
  1. Renaming of t/innodb_concurrent.test to t/concurrent_innodb.test
  2. Main code is now sourced from include/concurrent.inc.
     Attention: This test fails even in the old version. (BUG#21579).
                --> added to t/disabled.def
mysql-test/t/deadlock_innodb.test:
  1. Renaming of t/innodb_deadlock.test to t/deadlock_innodb.test
  2. Main code is now sourced from include/deadlock.inc.
mysql-test/t/disabled.def:
  Add the test concurrent_innodb because of 
  BUG#21579 2006-08-11 mleich innodb_concurrent random failures with varying differences
mysql-test/t/handler_innodb.test:
  1. Renaming of t/innodb_handler.test to t/handler_innodb.test
  2. Main code is now sourced from include/handler.inc.
     include/handler.inc = united code of former t/handler.test and t/innodb_handler.test
mysql-test/t/handler_myisam.test:
  1. Renaming of t/handler.test to t/handler_myisam.test
  2. Main code is now sourced from include/handler.inc.
     include/handler.inc = united code of former t/handler.test and t/handler_innodb.test.
mysql-test/t/innodb_mysql.test:
  1. Main code is now sourced from include/mix1.inc.
  2. Test was not renamed because t/innodb.test refers to it.
mysql-test/t/mix2_myisam.test:
  New test: MyISAM variant of mix2 ( = t/innodb.test)
mysql-test/t/read_many_rows_innodb.test:
  1. Renaming of t/innodb_big.test to t/read_many_rows_innodb.test
  2. Main code is now sourced from include/read_many_rows.inc.
mysql-test/t/rowid_order_innodb.test:
  Main code is now sourced from t/rowid_order.inc.
mysql-test/t/unsafe_binlog_innodb.test:
  1. Renaming of t/innodb_unsafe_binlog.test to t/unsafe_binlog_innodb.test
  2. Main code is now sourced from include/unsafe_binlog.inc.
		
	
		
			
				
	
	
		
			266 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			266 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| # include/unsafe_binlog.inc
 | |
| #
 | |
| # The variable
 | |
| #     $engine_type       -- storage engine to be tested
 | |
| # has to be set before sourcing this script.
 | |
| #
 | |
| # Notes:
 | |
| # 1. This test uses at least in case of InnoDB options
 | |
| #     innodb_locks_unsafe_for_binlog = true
 | |
| #     innodb_lock_timeout = 5
 | |
| # 2. The comments/expectations refer to InnoDB.
 | |
| #    They might be not valid for other storage engines.
 | |
| #
 | |
| # Last update:
 | |
| # 2006-08-02 ML test refactored
 | |
| #               old name was innodb_unsafe_binlog.test
 | |
| #               main code went into include/unsafe_binlog.inc
 | |
| #
 | |
| 
 | |
| #
 | |
| # Test cases for bug#15650
 | |
| #      DELETE with LEFT JOIN crashes server with innodb_locks_unsafe_for_binlog
 | |
| #
 | |
| 
 | |
| --disable_warnings
 | |
| drop table if exists t1,t2;
 | |
| --enable_warnings
 | |
| eval create table t1 (id int not null, f_id int not null, f int not null,
 | |
| primary key(f_id, id)) engine = $engine_type;
 | |
| eval create table t2 (id int not null,s_id int not null,s varchar(200),
 | |
| primary key(id)) engine = $engine_type;
 | |
| INSERT INTO t1 VALUES (8, 1, 3);
 | |
| INSERT INTO t1 VALUES (1, 2, 1);
 | |
| INSERT INTO t2 VALUES (1, 0, '');
 | |
| INSERT INTO t2 VALUES (8, 1, '');
 | |
| commit;
 | |
| DELETE ml.* FROM t1 AS ml LEFT JOIN t2 AS mm ON (mm.id=ml.id)
 | |
| WHERE mm.id IS NULL;
 | |
| select ml.* from t1 as ml left join t2 as mm on (mm.id=ml.id)
 | |
| where mm.id is null lock in share mode;
 | |
| drop table t1,t2;
 | |
| 
 | |
| #
 | |
| # Test case for unlock row bug where unlock releases all locks granted for
 | |
| # a row. Only the latest lock should be released.
 | |
| #
 | |
| 
 | |
| connect (a,localhost,root,,);
 | |
| connect (b,localhost,root,,);
 | |
| connection a;
 | |
| eval create table t1(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t1 values(1,1),(2,2),(3,1),(4,2),(5,1),(6,2),(7,3);
 | |
| commit;
 | |
| set autocommit = 0;
 | |
| select * from t1 lock in share mode;
 | |
| update t1 set b = 5 where b = 1;
 | |
| connection b;
 | |
| set autocommit = 0;
 | |
| #
 | |
| # S-lock to records (2,2),(4,2), and (6,2) should not be released in a update
 | |
| #
 | |
| --error 1205
 | |
| select * from t1 where a = 2 and b = 2 for update;
 | |
| connection a;
 | |
| commit;
 | |
| connection b;
 | |
| commit;
 | |
| drop table t1;
 | |
| connection default;
 | |
| disconnect a;
 | |
| disconnect b;
 | |
| 
 | |
| #
 | |
| # unlock row test
 | |
| #
 | |
| 
 | |
| connect (a,localhost,root,,);
 | |
| connect (b,localhost,root,,);
 | |
| connection a;
 | |
| eval create table t1(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t1 values(1,1),(2,2),(3,1),(4,2),(5,1),(6,2),(7,3);
 | |
| commit;
 | |
| set autocommit = 0;
 | |
| update t1 set b = 5 where b = 1;
 | |
| connection b;
 | |
| set autocommit = 0;
 | |
| #
 | |
| # X-lock to record (7,3) should be released in a update
 | |
| #
 | |
| select * from t1 where a = 7 and b = 3 for update;
 | |
| commit;
 | |
| connection a;
 | |
| commit;
 | |
| drop table t1;
 | |
| connection default;
 | |
| disconnect a;
 | |
| disconnect b;
 | |
| 
 | |
| 
 | |
| #
 | |
| # Consistent read should be used in following selects
 | |
| #
 | |
| # 1) INSERT INTO ... SELECT
 | |
| # 2) UPDATE ... = ( SELECT ...)
 | |
| # 3) CREATE ... SELECT
 | |
| 
 | |
| connect (a,localhost,root,,);
 | |
| connect (b,localhost,root,,);
 | |
| connection a;
 | |
| eval create table t1(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t1 values (1,2),(5,3),(4,2);
 | |
| eval create table t2(d int not null, e int, primary key(d)) engine = $engine_type;
 | |
| insert into t2 values (8,6),(12,1),(3,1);
 | |
| commit;
 | |
| set autocommit = 0;
 | |
| select * from t2 for update;
 | |
| connection b;
 | |
| set autocommit = 0;
 | |
| insert into t1 select * from t2;
 | |
| update t1 set b = (select e from t2 where a = d);
 | |
| eval create table t3(d int not null, e int, primary key(d)) engine = $engine_type
 | |
| select * from t2;
 | |
| commit;
 | |
| connection a;
 | |
| commit;
 | |
| connection default;
 | |
| disconnect a;
 | |
| disconnect b;
 | |
| drop table t1, t2, t3;
 | |
| 
 | |
| #
 | |
| # Consistent read should not be used if
 | |
| #
 | |
| # (a) isolation level is serializable OR
 | |
| # (b) select ... lock in share mode OR
 | |
| # (c) select ... for update
 | |
| #
 | |
| # in following queries:
 | |
| #
 | |
| # 1) INSERT INTO ... SELECT
 | |
| # 2) UPDATE ... = ( SELECT ...)
 | |
| # 3) CREATE ... SELECT
 | |
| 
 | |
| connect (a,localhost,root,,);
 | |
| connect (b,localhost,root,,);
 | |
| connect (c,localhost,root,,);
 | |
| connect (d,localhost,root,,);
 | |
| eval SET SESSION STORAGE_ENGINE = $engine_type;
 | |
| connect (e,localhost,root,,);
 | |
| connect (f,localhost,root,,);
 | |
| connect (g,localhost,root,,);
 | |
| eval SET SESSION STORAGE_ENGINE = $engine_type;
 | |
| connect (h,localhost,root,,);
 | |
| connect (i,localhost,root,,);
 | |
| connect (j,localhost,root,,);
 | |
| eval SET SESSION STORAGE_ENGINE = $engine_type;
 | |
| connection a;
 | |
| eval create table t1(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t1 values (1,2),(5,3),(4,2);
 | |
| eval create table t2(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t2 values (8,6),(12,1),(3,1);
 | |
| eval create table t3(d int not null, b int, primary key(d)) engine = $engine_type;
 | |
| insert into t3 values (8,6),(12,1),(3,1);
 | |
| eval create table t5(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t5 values (1,2),(5,3),(4,2);
 | |
| eval create table t6(d int not null, e int, primary key(d)) engine = $engine_type;
 | |
| insert into t6 values (8,6),(12,1),(3,1);
 | |
| eval create table t8(a int not null, b int, primary key(a)) engine = $engine_type;
 | |
| insert into t8 values (1,2),(5,3),(4,2);
 | |
| eval create table t9(d int not null, e int, primary key(d)) engine = $engine_type;
 | |
| insert into t9 values (8,6),(12,1),(3,1);
 | |
| commit;
 | |
| set autocommit = 0;
 | |
| select * from t2 for update;
 | |
| connection b;
 | |
| set autocommit = 0;
 | |
| SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
 | |
| --send
 | |
| insert into t1 select * from t2;
 | |
| connection c;
 | |
| set autocommit = 0;
 | |
| SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
 | |
| --send
 | |
| update t3 set b = (select b from t2 where a = d);
 | |
| connection d;
 | |
| set autocommit = 0;
 | |
| SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
 | |
| --send
 | |
| create table t4(a int not null, b int, primary key(a)) select * from t2;
 | |
| connection e;
 | |
| set autocommit = 0;
 | |
| --send
 | |
| insert into t5 (select * from t2 lock in share mode);
 | |
| connection f;
 | |
| set autocommit = 0;
 | |
| --send
 | |
| update t6 set e = (select b from t2 where a = d lock in share mode);
 | |
| connection g;
 | |
| set autocommit = 0;
 | |
| --send
 | |
| create table t7(a int not null, b int, primary key(a)) select * from t2 lock in share mode;
 | |
| connection h;
 | |
| set autocommit = 0;
 | |
| --send
 | |
| insert into t8 (select * from t2 for update);
 | |
| connection i;
 | |
| set autocommit = 0;
 | |
| --send
 | |
| update t9 set e = (select b from t2 where a = d for update);
 | |
| connection j;
 | |
| set autocommit = 0;
 | |
| --send
 | |
| create table t10(a int not null, b int, primary key(a)) select * from t2 for update;
 | |
| 
 | |
| connection b;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection c;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection d;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection e;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection f;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection g;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection h;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection i;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection j;
 | |
| --error 1205
 | |
| reap;
 | |
| 
 | |
| connection a;
 | |
| commit;
 | |
| 
 | |
| connection default;
 | |
| disconnect a;
 | |
| disconnect b;
 | |
| disconnect c;
 | |
| disconnect d;
 | |
| disconnect e;
 | |
| disconnect f;
 | |
| disconnect g;
 | |
| disconnect h;
 | |
| disconnect i;
 | |
| disconnect j;
 | |
| drop table t1, t2, t3, t5, t6, t8, t9;
 |