diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 18:00:34 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-04 18:00:34 +0000 |
commit | 3f619478f796eddbba6e39502fe941b285dd97b1 (patch) | |
tree | e2c7b5777f728320e5b5542b6213fd3591ba51e2 /mysql-test/main/flush_notembedded.test | |
parent | Initial commit. (diff) | |
download | mariadb-upstream.tar.xz mariadb-upstream.zip |
Adding upstream version 1:10.11.6.upstream/1%10.11.6upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | mysql-test/main/flush_notembedded.test | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/mysql-test/main/flush_notembedded.test b/mysql-test/main/flush_notembedded.test new file mode 100644 index 00000000..193ac026 --- /dev/null +++ b/mysql-test/main/flush_notembedded.test @@ -0,0 +1,67 @@ +source include/not_embedded.inc; +source include/have_perfschema.inc; + +--echo # +--echo # MDEV-15888 Implement FLUSH TABLES tbl_name [, tbl_name] ... WITH READ LOCK for views. +--echo # + +--echo # +--echo # privilege checks with views +--echo # +create database mysqltest1; +create table mysqltest1.t1 (a int); +create user u1@localhost; +grant reload on *.* to u1@localhost; +grant select on mysqltest1.* to u1@localhost; +grant all on test.* to u1@localhost; +connect u1,localhost,u1; +error ER_DBACCESS_DENIED_ERROR; +flush tables mysqltest1.t1 for export; +create view v as select * from mysqltest1.t1; +create view v2 as select * from v; +create view v3 as select * from (select * from mysqltest1.t1) x; +error ER_DBACCESS_DENIED_ERROR; +flush tables v for export; +error ER_DBACCESS_DENIED_ERROR; +flush tables v2 for export; +error ER_DBACCESS_DENIED_ERROR; +flush tables v3 for export; +disconnect u1; +connection default; +drop database mysqltest1; +drop view v, v2, v3; +drop user u1@localhost; + +--echo # +--echo # MDEV-25906: SIGSEGV in flush_tables_with_read_lock on FTWRL or FTFE | SIGSEGV in ha_maria::extra +--echo # +CREATE VIEW v0 AS SELECT * FROM information_schema.columns; # Aria +CREATE VIEW v1 AS SELECT * FROM information_schema.collations; # Heap +CREATE VIEW v2 AS SELECT * FROM performance_schema.accounts; + +--disable_abort_on_error +--echo # +--echo # first try to flush tables directly +--echo # +FLUSH TABLE information_schema.collations WITH READ LOCK; +FLUSH TABLE performance_schema.accounts WITH READ LOCK; +FLUSH TABLE information_schema.colums WITH READ LOCK; +FLUSH TABLE information_schema.collations FOR EXPORT; +FLUSH TABLE performance_schema.accounts FOR EXPORT; +FLUSH TABLE information_schema.colums FOR EXPORT; + +--echo # +--echo # and now via views +--echo # +FLUSH TABLE v0 WITH READ LOCK; +FLUSH TABLE v1 WITH READ LOCK; +FLUSH TABLE v2 WITH READ LOCK; +FLUSH TABLE v0 FOR EXPORT; +FLUSH TABLE v1 FOR EXPORT; +FLUSH TABLE v2 FOR EXPORT; +--enable_abort_on_error +DROP VIEW v0, v1, v2; + +--echo # +--echo # End of 10.6 tests +--echo # |