diff options
Diffstat (limited to 'mysql-test/suite/sys_vars/t/thread_pool_stall_limit_grant.test')
-rw-r--r-- | mysql-test/suite/sys_vars/t/thread_pool_stall_limit_grant.test | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/mysql-test/suite/sys_vars/t/thread_pool_stall_limit_grant.test b/mysql-test/suite/sys_vars/t/thread_pool_stall_limit_grant.test new file mode 100644 index 00000000000..ae0ed8a785b --- /dev/null +++ b/mysql-test/suite/sys_vars/t/thread_pool_stall_limit_grant.test @@ -0,0 +1,58 @@ +# uint global +--source include/not_embedded.inc +--source include/not_aix.inc + +SET @global=@@global.thread_pool_stall_limit; + +--echo # +--echo # MDEV-21961 Bind CONNECTION ADMIN to a number of global system variables +--echo # + +--echo # Test that "SET thread_pool_stall_limit" is not allowed without CONNECTION ADMIN or SUPER + +CREATE USER user1@localhost; +GRANT ALL PRIVILEGES ON *.* TO user1@localhost; +REVOKE CONNECTION ADMIN, SUPER ON *.* FROM user1@localhost; +--connect(user1,localhost,user1,,) +--connection user1 +--error ER_SPECIFIC_ACCESS_DENIED_ERROR +SET GLOBAL thread_pool_stall_limit=400; +--error ER_GLOBAL_VARIABLE +SET thread_pool_stall_limit=400; +--error ER_GLOBAL_VARIABLE +SET SESSION thread_pool_stall_limit=400; +--disconnect user1 +--connection default +DROP USER user1@localhost; + +--echo # Test that "SET thread_pool_stall_limit" is allowed with CONNECTION ADMIN + +CREATE USER user1@localhost; +GRANT CONNECTION ADMIN ON *.* TO user1@localhost; +--connect(user1,localhost,user1,,) +--connection user1 +SET GLOBAL thread_pool_stall_limit=400; +--error ER_GLOBAL_VARIABLE +SET thread_pool_stall_limit=400; +--error ER_GLOBAL_VARIABLE +SET SESSION thread_pool_stall_limit=400; +--disconnect user1 +--connection default +DROP USER user1@localhost; + +--echo # Test that "SET thread_pool_stall_limit" is allowed with SUPER + +CREATE USER user1@localhost; +GRANT SUPER ON *.* TO user1@localhost; +--connect(user1,localhost,user1,,) +--connection user1 +SET GLOBAL thread_pool_stall_limit=400; +--error ER_GLOBAL_VARIABLE +SET thread_pool_stall_limit=400; +--error ER_GLOBAL_VARIABLE +SET SESSION thread_pool_stall_limit=400; +--disconnect user1 +--connection default +DROP USER user1@localhost; + +SET @@global.thread_pool_stall_limit=@global; |