mirror of
				https://github.com/MariaDB/server.git
				synced 2025-11-04 04:46:15 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			200 lines
		
	
	
	
		
			5.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			200 lines
		
	
	
	
		
			5.2 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
#
 | 
						|
# Testing of potential problems in Aria with locking
 | 
						|
#
 | 
						|
 | 
						|
-- source include/have_maria.inc
 | 
						|
 | 
						|
drop table if exists t1,t2;
 | 
						|
 | 
						|
#
 | 
						|
# Test for Bug#973039
 | 
						|
# Assertion `share->in_trans == 0' failed in maria_close on DROP TABLE
 | 
						|
# under LOCK 
 | 
						|
# 
 | 
						|
 | 
						|
# Test DROP TABLE
 | 
						|
 | 
						|
CREATE TABLE t1 (i INT) ENGINE=Aria;
 | 
						|
CREATE TABLE t2 (i INT) ENGINE=Aria;
 | 
						|
LOCK TABLE t1 WRITE, t2 WRITE;
 | 
						|
# Also fails with FLUSH TABLE t1 and with REPAIR TABLE t1 USE_FRM
 | 
						|
DROP TABLE t1;
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP TABLE t2;
 | 
						|
 | 
						|
#Test FLUSH TABLE
 | 
						|
 | 
						|
CREATE TABLE t1 (i INT) ENGINE=Aria;
 | 
						|
CREATE TABLE t2 (i INT) ENGINE=Aria;
 | 
						|
LOCK TABLE t1 WRITE, t2 WRITE;
 | 
						|
FLUSH TABLE t1;
 | 
						|
select * from t1;
 | 
						|
unlock tables;
 | 
						|
drop table t1,t2;
 | 
						|
 | 
						|
# Test REPAIR ... USE_FRM and unlock tables last
 | 
						|
 | 
						|
CREATE TABLE t1 (i INT) ENGINE=Aria;
 | 
						|
CREATE TABLE t2 (i INT) ENGINE=Aria;
 | 
						|
LOCK TABLE t1 WRITE, t2 WRITE;
 | 
						|
repair table t1 use_frm;
 | 
						|
select * from t1;
 | 
						|
drop table t2;
 | 
						|
unlock tables;
 | 
						|
drop table t1;
 | 
						|
 | 
						|
#
 | 
						|
# MDEV-366: lock table twice with LOCK TABLES and then drop it
 | 
						|
#
 | 
						|
 | 
						|
CREATE TABLE t1 (i INT) ENGINE=Aria;
 | 
						|
LOCK TABLES t1 WRITE, t1 AS t1a WRITE;
 | 
						|
DROP TABLE t1;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo #  MDEV-8200 aria bug with insert select when select is a aria table
 | 
						|
--echo #  (wrong result or assertion failure:
 | 
						|
--echo # `table->file->stats.records > 0 || error')
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (f1 INT) ENGINE=Aria;
 | 
						|
SHOW CREATE TABLE t1;
 | 
						|
INSERT INTO t1 VALUES (1);
 | 
						|
CREATE TABLE t2 (f2 INT) ENGINE=MyISAM;
 | 
						|
CREATE TABLE tmp (f3 INT) engine=Aria;
 | 
						|
LOCK TABLE t2 WRITE, tmp WRITE, tmp AS tmp_alias WRITE, t1 WRITE;
 | 
						|
INSERT INTO tmp SELECT f1 FROM t1;
 | 
						|
INSERT INTO t2 SELECT f3 FROM tmp AS tmp_alias;
 | 
						|
select * from t2;
 | 
						|
unlock tables;
 | 
						|
DROP TABLE t1,t2,tmp;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # Same without transactional
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (f1 INT) transactional=0 ENGINE=Aria;
 | 
						|
SHOW CREATE TABLE t1;
 | 
						|
INSERT INTO t1 VALUES (2);
 | 
						|
CREATE TABLE t2 (f2 INT) ENGINE=MyISAM;
 | 
						|
CREATE TABLE tmp (f3 INT) transactional=0 engine=Aria;
 | 
						|
LOCK TABLE t2 WRITE, tmp WRITE, tmp AS tmp_alias WRITE, t1 WRITE;
 | 
						|
INSERT INTO tmp SELECT f1 FROM t1;
 | 
						|
INSERT INTO t2 SELECT f3 FROM tmp AS tmp_alias;
 | 
						|
select * from t2;
 | 
						|
unlock tables;
 | 
						|
DROP TABLE t1,t2,tmp;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # Using spatical keys (disables versioning)
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (f1 INT, c1 geometry NOT NULL, SPATIAL KEY i1 (c1)) transactional=1 ENGINE=Aria;
 | 
						|
SHOW CREATE TABLE t1;
 | 
						|
INSERT INTO t1 VALUES (3,
 | 
						|
PolygonFromText('POLYGON((-18.6086111000 -66.9327777000,
 | 
						|
                          -18.6055555000 -66.8158332999,
 | 
						|
                          -18.7186111000 -66.8102777000,
 | 
						|
                          -18.7211111000 -66.9269443999,
 | 
						|
                          -18.6086111000 -66.9327777000))'));
 | 
						|
CREATE TABLE t2 (f2 INT) ENGINE=MyISAM;
 | 
						|
CREATE TABLE tmp (f3 INT, c1 geometry NOT NULL, SPATIAL KEY i1 (c1)) transactional=1 ENGINE=Aria;
 | 
						|
LOCK TABLE t2 WRITE, tmp WRITE, tmp AS tmp_alias WRITE, t1 WRITE;
 | 
						|
INSERT INTO tmp SELECT f1,c1 FROM t1;
 | 
						|
INSERT INTO t2 (f2) SELECT f3 FROM tmp AS tmp_alias;
 | 
						|
select * from t2;
 | 
						|
unlock tables;
 | 
						|
DROP TABLE t1,t2,tmp;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-10378 Assertion `trn' failed in virtual int ha_maria::start_stmt
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (f1 VARCHAR(3), f2 INT, pk INT, PRIMARY KEY (pk)) ENGINE=Aria;
 | 
						|
INSERT INTO t1 VALUES  ('foo',10,1), ('foo',1,2);
 | 
						|
LOCK TABLE t1 WRITE;
 | 
						|
--error ER_DUP_ENTRY
 | 
						|
ALTER TABLE t1 ADD UNIQUE KEY (f1);
 | 
						|
ALTER TABLE t1 ADD KEY (f2);
 | 
						|
DROP TABLE t1;
 | 
						|
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-10748 Server crashes in ha_maria::implicit_commit upon ALTER TABLE
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (a INT, b INT) ENGINE=Aria;
 | 
						|
SELECT * FROM t1;
 | 
						|
CREATE TABLE t2 (c INT) ENGINE=Aria;
 | 
						|
 
 | 
						|
LOCK TABLE t2 READ, t1 WRITE;
 | 
						|
--error ER_DUP_FIELDNAME
 | 
						|
ALTER TABLE t1 CHANGE b a INT;
 | 
						|
 
 | 
						|
# Cleanup
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP TABLE t1, t2;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-10748 Server crashes in ha_maria::implicit_commit upon ALTER TABLE
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (a INT) ENGINE=Aria;
 | 
						|
CREATE TABLE t2 (b INT) ENGINE=Aria;
 | 
						|
 | 
						|
LOCK TABLES t1 WRITE, t2 AS t2a WRITE, t2 WRITE;
 | 
						|
ALTER TABLE t2 CHANGE b c VARBINARY(30000), ALGORITHM=COPY;
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP TABLE t1, t2;
 | 
						|
 | 
						|
--echo # More complex test, from RQG
 | 
						|
 | 
						|
CREATE TABLE t1 (a INT) ENGINE=Aria;
 | 
						|
CREATE TABLE t2 (b INT) ENGINE=Aria;
 | 
						|
CREATE OR REPLACE VIEW v2 AS SELECT * FROM t2 ;
 | 
						|
 | 
						|
LOCK TABLES t1 WRITE, t2 AS t2a WRITE, v2 WRITE CONCURRENT, t2 WRITE;
 | 
						|
 | 
						|
ALTER TABLE t1 FORCE;
 | 
						|
--error ER_ALTER_OPERATION_NOT_SUPPORTED
 | 
						|
ALTER TABLE t2 CHANGE b c VARBINARY(30000), ALGORITHM=INPLACE;
 | 
						|
ALTER TABLE t2 CHANGE b c VARBINARY(30000), ALGORITHM=COPY;
 | 
						|
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP VIEW v2;
 | 
						|
DROP TABLE t1, t2;
 | 
						|
 | 
						|
--echo # End of 10.2 tests
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-14669 Assertion `file->trn == trn' failed in ha_maria::start_stmt
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (i INT) ENGINE=Aria;
 | 
						|
INSERT INTO t1 VALUES (1),(2);
 | 
						|
CREATE TABLE t2 (c CHAR(1)) ENGINE=Aria;
 | 
						|
INSERT INTO t2 VALUES ('a'),('b');
 | 
						|
--connect (con1,localhost,root,,test)
 | 
						|
LOCK TABLE t1 WRITE;
 | 
						|
OPTIMIZE TABLE t1;
 | 
						|
--connection default
 | 
						|
DELETE FROM t2 WHERE c < 1;
 | 
						|
--connection con1
 | 
						|
OPTIMIZE TABLE t1;
 | 
						|
# Cleanup
 | 
						|
--disconnect con1
 | 
						|
--connection default
 | 
						|
DROP TABLE t1, t2;
 | 
						|
 | 
						|
--echo #
 | 
						|
--echo # MDEV-22829 SIGSEGV in _ma_reset_history on LOCK
 | 
						|
--echo #
 | 
						|
 | 
						|
CREATE TABLE t1 (f1 INT) ENGINE=Aria;
 | 
						|
CREATE TABLE t2 (f2 INT) ENGINE=Aria;
 | 
						|
LOCK TABLES t2 WRITE, t1 WRITE;
 | 
						|
INSERT INTO t1 VALUES (1);
 | 
						|
--error ER_BAD_FIELD_ERROR
 | 
						|
CREATE TRIGGER ai AFTER INSERT ON t1 FOR EACH ROW UPDATE t1 SET v=1 WHERE b=new.a;
 | 
						|
UNLOCK TABLES;
 | 
						|
DROP TABLE t1, t2;
 |