mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
MDEV-13626 Merge InnoDB test cases from MySQL 5.7 (part 2)
Import the changes to innodb.innodb-index innodb.innodb-index-debug Note: As noted in MDEV-13613, due to the behaviour change in MDEV-11114, DROP COLUMN will not imply DROP/ADD PRIMARY/UNIQUE KEY, like it does in MySQL. The tests have been adjusted accordingly.
This commit is contained in:
@ -1,5 +1,7 @@
|
||||
-- source include/have_debug.inc
|
||||
-- source include/have_innodb.inc
|
||||
-- source include/count_sessions.inc
|
||||
-- source include/have_debug_sync.inc
|
||||
|
||||
let $MYSQLD_DATADIR= `select @@datadir`;
|
||||
|
||||
@ -42,13 +44,10 @@ SET DEBUG_DBUG = @saved_debug_dbug;
|
||||
DROP TABLE bug13861218;
|
||||
|
||||
--echo #
|
||||
--echo # Bug #21762319 ADDING INDEXES ON EMPTY TABLE IS SLOW
|
||||
--echo # WITH LARGE INNODB_SORT_BUFFER_SIZE.
|
||||
|
||||
call mtr.add_suppression("InnoDB: Cannot create temporary merge file");
|
||||
|
||||
# Table with large data which is greater than sort buffer
|
||||
--echo # Bug #17657223 EXCESSIVE TEMPORARY FILE USAGE IN ALTER TABLE
|
||||
--echo #
|
||||
|
||||
# Error during file creation in alter operation
|
||||
create table t480(a serial)engine=innodb;
|
||||
insert into t480
|
||||
values(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),(),
|
||||
@ -57,14 +56,74 @@ insert into t480 select 0 from t480;
|
||||
insert into t480 select 0 from t480;
|
||||
insert into t480 select 0 from t480;
|
||||
insert into t480 select 0 from t480;
|
||||
|
||||
# Error during file write in alter operation.
|
||||
create table t1(f1 int auto_increment not null,
|
||||
f2 char(200) not null, f3 char(200) not null,
|
||||
f4 char(200) not null,primary key(f1))engine=innodb;
|
||||
insert into t1 select NULL,'aaa','bbb','ccc' from t480;
|
||||
insert into t1 select NULL,'aaaa','bbbb','cccc' from t480;
|
||||
insert into t1 select NULL,'aaaaa','bbbbb','ccccc' from t480;
|
||||
insert into t1 select NULL,'aaaaaa','bbbbbb','cccccc' from t480;
|
||||
insert into t1 select NULL,'aaaaaaa','bbbbbbb','ccccccc' from t480;
|
||||
insert into t1 select NULL,'aaaaaaaa','bbbbbbbb','cccccccc' from t480;
|
||||
select count(*) from t1;
|
||||
drop table t1, t480;
|
||||
primary key(f1,f2,f3), key(f1))engine=innodb;
|
||||
insert into t1 select NULL,'aaa','bbb' from t480;
|
||||
insert into t1 select NULL,'aaaa','bbbb' from t480;
|
||||
insert into t1 select NULL,'aaaaa','bbbbb' from t480;
|
||||
insert into t1 select NULL,'aaaaaa','bbbbbb' from t480;
|
||||
SET DEBUG_DBUG = '+d,row_merge_write_failure';
|
||||
--error ER_TEMP_FILE_WRITE_FAILURE
|
||||
alter table t1 drop primary key,add primary key(f2,f1);
|
||||
SET DEBUG_DBUG = @saved_debug_dbug;
|
||||
drop table t1;
|
||||
|
||||
# Optimize table via inplace algorithm
|
||||
connect (con1,localhost,root);
|
||||
create table t1(k1 int auto_increment primary key,
|
||||
k2 char(200),k3 char(200))engine=innodb;
|
||||
insert into t1 values(NULL,'a','b'), (NULL,'aa','bb');
|
||||
SET DEBUG_SYNC= 'row_merge_after_scan
|
||||
SIGNAL opened WAIT_FOR flushed';
|
||||
send optimize table t1;
|
||||
connection default;
|
||||
SET DEBUG_SYNC= 'now WAIT_FOR opened';
|
||||
INSERT INTO t1 select NULL,'aaa','bbb' from t480;
|
||||
SET DEBUG_SYNC= 'now SIGNAL flushed';
|
||||
connection con1;
|
||||
--enable_info
|
||||
--echo /*con1 reap*/ Optimize table t1;
|
||||
reap;
|
||||
--disable_info
|
||||
SELECT COUNT(k1),k2,k3 FROM t1 GROUP BY k2,k3;
|
||||
drop table t1;
|
||||
|
||||
# Log file creation failure.
|
||||
create table t1(k1 int auto_increment primary key,
|
||||
k2 char(200),k3 char(200))engine=innodb;
|
||||
SET DEBUG_SYNC= 'row_merge_after_scan
|
||||
SIGNAL opened WAIT_FOR flushed';
|
||||
send ALTER TABLE t1 ADD COLUMN k4 int;
|
||||
connection default;
|
||||
SET DEBUG_SYNC= 'now WAIT_FOR opened';
|
||||
SET debug = '+d,row_log_tmpfile_fail';
|
||||
INSERT INTO t1 select NULL,'aaa','bbb' from t480;
|
||||
INSERT INTO t1 select NULL,'aaaa','bbbb' from t480;
|
||||
SET DEBUG_SYNC= 'now SIGNAL flushed';
|
||||
SET DEBUG_DBUG = @saved_debug_dbug;
|
||||
connection con1;
|
||||
--echo /*con1 reap*/ ALTER TABLE t1 ADD COLUMN k4 int;
|
||||
--error ER_OUT_OF_RESOURCES
|
||||
reap;
|
||||
SELECT COUNT(k1),k2,k3 FROM t1 GROUP BY k2,k3;
|
||||
disconnect con1;
|
||||
connection default;
|
||||
show create table t1;
|
||||
drop table t1;
|
||||
drop table t480;
|
||||
SET DEBUG_SYNC='RESET';
|
||||
--source include/wait_until_count_sessions.inc
|
||||
|
||||
--echo #
|
||||
--echo # BUG#21612714 ALTER TABLE SORTING SKIPPED WHEN CHANGE PK AND DROP
|
||||
--echo # LAST COLUMN OF OLD PK
|
||||
--echo #
|
||||
|
||||
SET DEBUG_DBUG = '+d,innodb_alter_table_pk_assert_no_sort';
|
||||
|
||||
--source suite/innodb/include/alter_table_pk_no_sort.inc
|
||||
|
||||
SET DEBUG_DBUG = @saved_debug_dbug;
|
||||
|
Reference in New Issue
Block a user