mariadb/mysql-test/main/lowercase_table_grant.test
Vladislav Vaintroub e0cc096503 Fix some testcases, to enable mtr --mysqld=--lower_case_table_name=0
Add include/have_lowercase{0,1}.inc where test case require it.
Reason: lower_case_table_names setting in the corresponding .opt files
is insufficient, if it is overwritten with --mysqld setting in MTR.
2025-10-07 21:46:28 +03:00

32 lines
1,003 B
Text

# Don't test with embedded server
-- source include/not_embedded.inc
-- source include/have_lowercase1.inc
# Test of grants when lower_case_table_names is on
use mysql;
set sql_mode="";
# mixed-case database name for testing
create database MYSQLtest;
# check that database name gets forced to lowercase
grant all on MySQLtest.* to mysqltest_1@localhost;
show grants for mysqltest_1@localhost;
# now force it to mixed case, but see that it is lowercased in the acl cache
select * from db where user = 'mysqltest_1';
update db set db = 'MYSQLtest' where db = 'mysqltest' and user = 'mysqltest_1' and host = 'localhost';
flush privileges;
show grants for mysqltest_1@localhost;
select * from db where user = 'mysqltest_1';
# clear out the user we created
#
# can't use REVOKE because of the mixed-case database name
delete from db where db = 'MYSQLtest' and user = 'mysqltest_1' and host = 'localhost';
flush privileges;
drop user mysqltest_1@localhost;
drop database MYSQLtest;
# End of 4.1 tests