Commit 7b708ee3 authored by Sergei Petrunia's avatar Sergei Petrunia

MDEV-11329: MariaRocks: rocksdb.add_index_inplace fails

- Make ha_rocksdb::check_if_supported_inplace_alter() take into
  account the Alter_inplace_info::ALTER_PARTITIONED flag

- Adjust the testcase to work in MariaDB
parent 05a593df
...@@ -9656,7 +9656,8 @@ my_core::enum_alter_inplace_result ha_rocksdb::check_if_supported_inplace_alter( ...@@ -9656,7 +9656,8 @@ my_core::enum_alter_inplace_result ha_rocksdb::check_if_supported_inplace_alter(
if (ha_alter_info->handler_flags & if (ha_alter_info->handler_flags &
~(my_core::Alter_inplace_info::DROP_INDEX | ~(my_core::Alter_inplace_info::DROP_INDEX |
my_core::Alter_inplace_info::DROP_UNIQUE_INDEX | my_core::Alter_inplace_info::DROP_UNIQUE_INDEX |
my_core::Alter_inplace_info::ADD_INDEX)) my_core::Alter_inplace_info::ADD_INDEX |
my_core::Alter_inplace_info::ALTER_PARTITIONED))
{ {
DBUG_RETURN(my_core::HA_ALTER_INPLACE_NOT_SUPPORTED); DBUG_RETURN(my_core::HA_ALTER_INPLACE_NOT_SUPPORTED);
} }
......
...@@ -252,7 +252,7 @@ DROP INDEX kij ON t1; ...@@ -252,7 +252,7 @@ DROP INDEX kij ON t1;
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
Table Create Table Table Create Table
t1 CREATE TABLE `t1` ( t1 CREATE TABLE `t1` (
`i` int(11) NOT NULL DEFAULT '0', `i` int(11) NOT NULL,
`j` int(11) DEFAULT NULL, `j` int(11) DEFAULT NULL,
`k` int(11) DEFAULT NULL, `k` int(11) DEFAULT NULL,
PRIMARY KEY (`i`), PRIMARY KEY (`i`),
...@@ -282,10 +282,10 @@ INSERT INTO t1 (a, b) VALUES (2, 6); ...@@ -282,10 +282,10 @@ INSERT INTO t1 (a, b) VALUES (2, 6);
INSERT INTO t1 (a, b) VALUES (3, 7); INSERT INTO t1 (a, b) VALUES (3, 7);
# crash_during_online_index_creation # crash_during_online_index_creation
flush logs; flush logs;
SET SESSION debug="+d,crash_during_online_index_creation"; SET SESSION debug_dbug="+d,crash_during_online_index_creation";
ALTER TABLE t1 ADD INDEX kb(b), ALGORITHM=INPLACE; ALTER TABLE t1 ADD INDEX kb(b), ALGORITHM=INPLACE;
ERROR HY000: Lost connection to MySQL server during query ERROR HY000: Lost connection to MySQL server during query
SET SESSION debug="-d,crash_during_online_index_creation"; SET SESSION debug_dbug="-d,crash_during_online_index_creation";
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
Table Create Table Table Create Table
t1 CREATE TABLE `t1` ( t1 CREATE TABLE `t1` (
...@@ -301,14 +301,14 @@ DROP TABLE t1; ...@@ -301,14 +301,14 @@ DROP TABLE t1;
CREATE TABLE t1 (i INT, j INT, k INT, PRIMARY KEY (i), KEY(j)) ENGINE = ROCKSDB PARTITION BY KEY(i) PARTITIONS 4; CREATE TABLE t1 (i INT, j INT, k INT, PRIMARY KEY (i), KEY(j)) ENGINE = ROCKSDB PARTITION BY KEY(i) PARTITIONS 4;
# crash_during_index_creation_partition # crash_during_index_creation_partition
flush logs; flush logs;
SET SESSION debug="+d,crash_during_index_creation_partition"; SET SESSION debug_dbug="+d,crash_during_index_creation_partition";
ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE; ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE;
ERROR HY000: Lost connection to MySQL server during query ERROR HY000: Lost connection to MySQL server during query
SET SESSION debug="-d,crash_during_index_creation_partition"; SET SESSION debug_dbug="-d,crash_during_index_creation_partition";
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
Table Create Table Table Create Table
t1 CREATE TABLE `t1` ( t1 CREATE TABLE `t1` (
`i` int(11) NOT NULL DEFAULT '0', `i` int(11) NOT NULL,
`j` int(11) DEFAULT NULL, `j` int(11) DEFAULT NULL,
`k` int(11) DEFAULT NULL, `k` int(11) DEFAULT NULL,
PRIMARY KEY (`i`), PRIMARY KEY (`i`),
...@@ -336,17 +336,17 @@ DROP TABLE t1; ...@@ -336,17 +336,17 @@ DROP TABLE t1;
CREATE TABLE t1 (i INT, j INT, k INT, PRIMARY KEY (i), KEY(j)) ENGINE = ROCKSDB PARTITION BY KEY(i) PARTITIONS 4; CREATE TABLE t1 (i INT, j INT, k INT, PRIMARY KEY (i), KEY(j)) ENGINE = ROCKSDB PARTITION BY KEY(i) PARTITIONS 4;
# crash_during_index_creation_partition # crash_during_index_creation_partition
flush logs; flush logs;
SET SESSION debug="+d,myrocks_simulate_index_create_rollback"; SET SESSION debug_dbug="+d,myrocks_simulate_index_create_rollback";
# expected assertion failure from sql layer here for alter rollback # expected assertion failure from sql layer here for alter rollback
call mtr.add_suppression("Assertion `0' failed."); call mtr.add_suppression("Assertion `0' failed.");
call mtr.add_suppression("Attempting backtrace. You can use the following information to find out"); call mtr.add_suppression("Attempting backtrace. You can use the following information to find out");
ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE; ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE;
ERROR HY000: Lost connection to MySQL server during query ERROR HY000: Lost connection to MySQL server during query
SET SESSION debug="-d,myrocks_simulate_index_create_rollback"; SET SESSION debug_dbug="-d,myrocks_simulate_index_create_rollback";
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
Table Create Table Table Create Table
t1 CREATE TABLE `t1` ( t1 CREATE TABLE `t1` (
`i` int(11) NOT NULL DEFAULT '0', `i` int(11) NOT NULL,
`j` int(11) DEFAULT NULL, `j` int(11) DEFAULT NULL,
`k` int(11) DEFAULT NULL, `k` int(11) DEFAULT NULL,
PRIMARY KEY (`i`), PRIMARY KEY (`i`),
...@@ -358,7 +358,7 @@ ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE; ...@@ -358,7 +358,7 @@ ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE;
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
Table Create Table Table Create Table
t1 CREATE TABLE `t1` ( t1 CREATE TABLE `t1` (
`i` int(11) NOT NULL DEFAULT '0', `i` int(11) NOT NULL,
`j` int(11) DEFAULT NULL, `j` int(11) DEFAULT NULL,
`k` int(11) DEFAULT NULL, `k` int(11) DEFAULT NULL,
PRIMARY KEY (`i`), PRIMARY KEY (`i`),
...@@ -371,8 +371,11 @@ SELECT COUNT(*) FROM t1; ...@@ -371,8 +371,11 @@ SELECT COUNT(*) FROM t1;
COUNT(*) COUNT(*)
100 100
DROP TABLE t1; DROP TABLE t1;
set @tmp_rocksdb_strict_collation_check= @@rocksdb_strict_collation_check;
set global rocksdb_strict_collation_check=1;
CREATE TABLE t1 (a INT, b TEXT); CREATE TABLE t1 (a INT, b TEXT);
ALTER TABLE t1 ADD KEY kb(b(10)); ALTER TABLE t1 ADD KEY kb(b(10));
ERROR HY000: Unsupported collation on string indexed column test.t1.b Use binary collation (binary, latin1_bin, utf8_bin). ERROR HY000: Unsupported collation on string indexed column test.t1.b Use binary collation (binary, latin1_bin, utf8_bin).
ALTER TABLE t1 ADD PRIMARY KEY(a); ALTER TABLE t1 ADD PRIMARY KEY(a);
DROP TABLE t1; DROP TABLE t1;
set global rocksdb_strict_collation_check= @tmp_rocksdb_strict_collation_check;
[mysql]
no-defaults
[mysqld.1]
rocksdb_strict_collation_check=1
--source include/have_rocksdb.inc --source include/have_rocksdb.inc
--source include/have_debug.inc --source include/have_debug.inc
--source include/have_partition.inc
--disable_warnings --disable_warnings
drop table if exists t1; drop table if exists t1;
...@@ -181,14 +182,14 @@ INSERT INTO t1 (a, b) VALUES (3, 7); ...@@ -181,14 +182,14 @@ INSERT INTO t1 (a, b) VALUES (3, 7);
flush logs; flush logs;
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect --exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
SET SESSION debug="+d,crash_during_online_index_creation"; SET SESSION debug_dbug="+d,crash_during_online_index_creation";
--error 2013 --error 2013
ALTER TABLE t1 ADD INDEX kb(b), ALGORITHM=INPLACE; ALTER TABLE t1 ADD INDEX kb(b), ALGORITHM=INPLACE;
--enable_reconnect --enable_reconnect
--source include/wait_until_connected_again.inc --source include/wait_until_connected_again.inc
SET SESSION debug="-d,crash_during_online_index_creation"; SET SESSION debug_dbug="-d,crash_during_online_index_creation";
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
CHECK TABLE t1; CHECK TABLE t1;
...@@ -214,14 +215,14 @@ while ($i <= $max) { ...@@ -214,14 +215,14 @@ while ($i <= $max) {
flush logs; flush logs;
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect --exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
SET SESSION debug="+d,crash_during_index_creation_partition"; SET SESSION debug_dbug="+d,crash_during_index_creation_partition";
--error 2013 --error 2013
ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE; ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE;
--enable_reconnect --enable_reconnect
--source include/wait_until_connected_again.inc --source include/wait_until_connected_again.inc
SET SESSION debug="-d,crash_during_index_creation_partition"; SET SESSION debug_dbug="-d,crash_during_index_creation_partition";
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
...@@ -253,7 +254,7 @@ while ($i <= $max) { ...@@ -253,7 +254,7 @@ while ($i <= $max) {
flush logs; flush logs;
--exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect --exec echo "restart" > $MYSQLTEST_VARDIR/tmp/mysqld.1.expect
SET SESSION debug="+d,myrocks_simulate_index_create_rollback"; SET SESSION debug_dbug="+d,myrocks_simulate_index_create_rollback";
--echo # expected assertion failure from sql layer here for alter rollback --echo # expected assertion failure from sql layer here for alter rollback
call mtr.add_suppression("Assertion `0' failed."); call mtr.add_suppression("Assertion `0' failed.");
...@@ -266,7 +267,7 @@ ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE; ...@@ -266,7 +267,7 @@ ALTER TABLE t1 ADD INDEX kij(i,j), ALGORITHM=INPLACE;
--enable_reconnect --enable_reconnect
--source include/wait_until_connected_again.inc --source include/wait_until_connected_again.inc
SET SESSION debug="-d,myrocks_simulate_index_create_rollback"; SET SESSION debug_dbug="-d,myrocks_simulate_index_create_rollback";
SHOW CREATE TABLE t1; SHOW CREATE TABLE t1;
...@@ -280,6 +281,8 @@ SELECT COUNT(*) FROM t1; ...@@ -280,6 +281,8 @@ SELECT COUNT(*) FROM t1;
DROP TABLE t1; DROP TABLE t1;
# test failure in prepare phase (due to collation) # test failure in prepare phase (due to collation)
set @tmp_rocksdb_strict_collation_check= @@rocksdb_strict_collation_check;
set global rocksdb_strict_collation_check=1;
CREATE TABLE t1 (a INT, b TEXT); CREATE TABLE t1 (a INT, b TEXT);
--error 1105 --error 1105
...@@ -287,4 +290,5 @@ ALTER TABLE t1 ADD KEY kb(b(10)); ...@@ -287,4 +290,5 @@ ALTER TABLE t1 ADD KEY kb(b(10));
ALTER TABLE t1 ADD PRIMARY KEY(a); ALTER TABLE t1 ADD PRIMARY KEY(a);
DROP TABLE t1; DROP TABLE t1;
set global rocksdb_strict_collation_check= @tmp_rocksdb_strict_collation_check;
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment