mirror of
https://github.com/MariaDB/server.git
synced 2025-06-03 07:02:23 +03:00
Timing problem as sometimes table is marked as encrypted but sometimes we are not sure and table is just marked missing.
114 lines
3.1 KiB
Plaintext
114 lines
3.1 KiB
Plaintext
-- source include/have_innodb.inc
|
|
-- source include/have_file_key_management_plugin.inc
|
|
# embedded does not support restart
|
|
-- source include/not_embedded.inc
|
|
|
|
#
|
|
# MDEV-8588: Assertion failure in file ha_innodb.cc line 21140 if at least one encrypted
|
|
# table exists and encryption service is not available.
|
|
#
|
|
|
|
call mtr.add_suppression("InnoDB: The page .*");
|
|
call mtr.add_suppression("InnoDB: Cannot calculate statistics for table .* ");
|
|
call mtr.add_suppression("Plugin 'file_key_management' .*");
|
|
call mtr.add_suppression("mysqld: File .*");
|
|
|
|
--echo
|
|
--echo # Start server with keys2.txt
|
|
-- let $restart_parameters=--file-key-management-filename=$MYSQL_TEST_DIR/std_data/keys2.txt
|
|
-- source include/restart_mysqld.inc
|
|
|
|
--disable_warnings
|
|
SET GLOBAL innodb_file_format = `Barracuda`;
|
|
SET GLOBAL innodb_file_per_table = ON;
|
|
--enable_warnings
|
|
|
|
CREATE TABLE t1 (c VARCHAR(8)) ENGINE=InnoDB ENCRYPTED=YES ENCRYPTION_KEY_ID=2;
|
|
INSERT INTO t1 VALUES ('foobar');
|
|
ALTER TABLE t1 ADD COLUMN c2 INT;
|
|
INSERT INTO t1 VALUES ('foobar',2);
|
|
SELECT * FROM t1;
|
|
TRUNCATE TABLE t1;
|
|
SELECT * FROM t1;
|
|
INSERT INTO t1 VALUES ('foobar',1);
|
|
INSERT INTO t1 VALUES ('foobar',2);
|
|
FLUSH TABLE WITH READ LOCK;
|
|
SELECT * FROM t1;
|
|
|
|
--echo
|
|
--echo # Restart server with keysbad3.txt
|
|
-- let $restart_parameters=--file-key-management-filename=$MYSQL_TEST_DIR/std_data/keysbad3.txt
|
|
-- source include/restart_mysqld.inc
|
|
|
|
--disable_warnings
|
|
--error ER_GET_ERRMSG
|
|
SELECT * FROM t1;
|
|
--enable_warnings
|
|
|
|
-- let $restart_parameters=--file-key-management-filename=$MYSQL_TEST_DIR/std_data/keysbad3.txt
|
|
-- source include/restart_mysqld.inc
|
|
|
|
--disable_warnings
|
|
--replace_regex /tablespace [0-9]*/tablespace /
|
|
DROP TABLE t1;
|
|
--enable_warnings
|
|
|
|
#
|
|
# MDEV-8591: Database page corruption on disk or a failed space, Assertion failure in file buf0buf.cc
|
|
# line 2856 on querying a table using wrong default encryption key
|
|
#
|
|
|
|
--echo # Start server with keys3.txt
|
|
-- let $restart_parameters=--file-key-management-filename=$MYSQL_TEST_DIR/std_data/keys3.txt
|
|
-- source include/restart_mysqld.inc
|
|
|
|
SET GLOBAL innodb_default_encryption_key_id=5;
|
|
CREATE TABLE t2 (c VARCHAR(8), id int not null primary key, b int, key(b)) ENGINE=InnoDB ENCRYPTED=YES;
|
|
INSERT INTO t2 VALUES ('foobar',1,2);
|
|
|
|
--echo
|
|
--echo # Restart server with keys2.txt
|
|
-- let $restart_parameters=--file-key-management-filename=$MYSQL_TEST_DIR/std_data/keys2.txt
|
|
-- source include/restart_mysqld.inc
|
|
|
|
--disable_warnings
|
|
--error ER_GET_ERRMSG
|
|
SELECT * FROM t2;
|
|
|
|
--error ER_GET_ERRMSG
|
|
SELECT * FROM t2 where id = 1;
|
|
|
|
--error ER_GET_ERRMSG
|
|
SELECT * FROM t2 where b = 1;
|
|
|
|
--replace_regex /tablespace [0-9]*/tablespace /
|
|
--error ER_GET_ERRMSG
|
|
INSERT INTO t2 VALUES ('tmp',3,3);
|
|
|
|
--error ER_GET_ERRMSG
|
|
DELETE FROM t2 where b = 3;
|
|
|
|
--error ER_GET_ERRMSG
|
|
DELETE FROM t2 where id = 3;
|
|
|
|
--error ER_GET_ERRMSG
|
|
UPDATE t2 set b = b +1;
|
|
|
|
OPTIMIZE TABLE t2;
|
|
|
|
--error ER_GET_ERRMSG
|
|
ALTER TABLE t2 ADD COLUMN d INT;
|
|
|
|
ANALYZE TABLE t2;
|
|
|
|
--error ER_GET_ERRMSG
|
|
TRUNCATE TABLE t2;
|
|
|
|
DROP TABLE t2;
|
|
--enable_warnings
|
|
|
|
--echo
|
|
--echo # Start server with keys2.txt
|
|
-- let $restart_parameters=--file-key-management-filename=$MYSQL_TEST_DIR/std_data/keys2.txt
|
|
-- source include/restart_mysqld.inc
|