mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
Merge 10.3 into 10.4
This commit is contained in:
141
mysql-test/suite/rpl/include/rpl_lower_case_table_names.test
Normal file
141
mysql-test/suite/rpl/include/rpl_lower_case_table_names.test
Normal file
@@ -0,0 +1,141 @@
|
||||
# BUG#37656
|
||||
#
|
||||
# This test aims at checking whether lower_case_table_names=1 option works
|
||||
# for database names and table names.
|
||||
#
|
||||
# This test checks the following (when lower_case_table_names=1 is set on slave):
|
||||
# (i) creating a database on upper case on master results in lower case
|
||||
# database name on slave
|
||||
# (ii) creating tables with upper case names on master results in lower case
|
||||
# table names on slave
|
||||
# (iii) loading data infile into capitalized table name on master replicates to
|
||||
# lower case table name on slave
|
||||
# (iv) Propagating changes from upper case table names on into correspondent
|
||||
# lower case table names on slave works.
|
||||
|
||||
|
||||
# setup: create database and tables
|
||||
-- echo ******** [ MASTER ] ********
|
||||
-- let $dbname_upper= BUG_37656
|
||||
-- let $dbname_lower= `SELECT LOWER('$dbname_upper')`
|
||||
-- eval CREATE DATABASE $dbname_upper
|
||||
-- eval use $dbname_upper
|
||||
|
||||
# assert: database names are in upper case in master and lower
|
||||
# case in slave
|
||||
-- eval show databases like '$dbname_upper'
|
||||
sync_slave_with_master;
|
||||
-- echo ******** [ SLAVE ] ********
|
||||
--eval show databases like '$dbname_lower'
|
||||
|
||||
-- connection master
|
||||
-- echo ******** [ MASTER ] ********
|
||||
CREATE TABLE T1 (a int);
|
||||
-- eval CREATE TABLE T2 (b int) ENGINE=$engine
|
||||
CREATE TABLE T3 (txt TEXT);
|
||||
|
||||
# assert: that tables exist on master with upper case names
|
||||
show tables;
|
||||
|
||||
# assert: that tables exist on slave but with lower case names
|
||||
-- sync_slave_with_master
|
||||
-- echo ******** [ SLAVE ] ********
|
||||
-- eval use $dbname_lower
|
||||
show tables;
|
||||
|
||||
# action: lets create t1 for asserting below that t1 does not get changes
|
||||
# from master (slave configured with --replicate-ignore-db=$dbname_lower.t1)
|
||||
CREATE TABLE t1 (a INT);
|
||||
|
||||
# action: fill data into tables
|
||||
-- connection master
|
||||
-- echo ******** [ MASTER ] ********
|
||||
-- eval use $dbname_upper
|
||||
INSERT INTO T1 VALUES (1);
|
||||
INSERT INTO T2 VALUES (1);
|
||||
if (`SELECT @@session.binlog_format != 'ROW'`)
|
||||
{
|
||||
-- eval LOAD DATA INFILE '../../std_data/words.dat' INTO TABLE $dbname_upper.T3
|
||||
}
|
||||
|
||||
if (`SELECT @@session.binlog_format = 'ROW'`)
|
||||
{
|
||||
use test;
|
||||
-- eval INSERT INTO $dbname_upper.T1 VALUES (2)
|
||||
-- eval INSERT INTO $dbname_upper.T2 VALUES (2)
|
||||
-- eval LOAD DATA INFILE '../../std_data/words.dat' INTO TABLE $dbname_upper.T3
|
||||
}
|
||||
# assert: lower case tables on lower case database on slave
|
||||
# get updates from upper case tables on upper case
|
||||
# database on master
|
||||
-- sync_slave_with_master
|
||||
-- echo ******** [ SLAVE ] ********
|
||||
|
||||
# assert: changes for slave's t1 were filterd out
|
||||
if (`SELECT count(*) != 0 FROM t1`)
|
||||
{
|
||||
-- echo UNEXPECTED DATA on $dbname_lower.t1 as table is filtered by replicate-ignore-table rules
|
||||
}
|
||||
|
||||
-- let $diff_tables=master:$dbname_upper.T2, slave:$dbname_lower.t2
|
||||
-- source include/diff_tables.inc
|
||||
|
||||
-- let $diff_tables=master:$dbname_upper.T3, slave:$dbname_lower.t3
|
||||
-- source include/diff_tables.inc
|
||||
|
||||
# clean up
|
||||
-- connection master
|
||||
-- echo ******** [ MASTER ] ********
|
||||
-- eval DROP DATABASE $dbname_upper
|
||||
-- sync_slave_with_master
|
||||
|
||||
|
||||
#
|
||||
# BUG#50653: drop procedure implicitely treats db name in a case sensitive way
|
||||
#
|
||||
|
||||
-- connection master
|
||||
|
||||
-- let $dbname= B50653
|
||||
-- let $procname= b50653_proc
|
||||
|
||||
-- eval CREATE DATABASE $dbname
|
||||
-- eval USE $dbname
|
||||
-- eval CREATE PROCEDURE $procname() BEGIN SELECT 1; END
|
||||
|
||||
if (`SELECT count(*) = 1 FROM mysql.proc WHERE name like '$dbname'`)
|
||||
{
|
||||
-- die Procedure not created on MASTER
|
||||
}
|
||||
|
||||
-- sync_slave_with_master
|
||||
if (`SELECT count(*) = 1 FROM mysql.proc WHERE name like '$dbname'`)
|
||||
{
|
||||
-- die Procedure not created on SLAVE
|
||||
}
|
||||
|
||||
-- connection master
|
||||
-- eval DROP PROCEDURE $procname
|
||||
|
||||
if (`SELECT count(*) FROM mysql.proc WHERE name like '$dbname'`)
|
||||
{
|
||||
-- die Procedure not dropped on MASTER
|
||||
}
|
||||
|
||||
-- sync_slave_with_master
|
||||
if (`SELECT count(*) FROM mysql.proc WHERE name like '$dbname'`)
|
||||
{
|
||||
-- die Procedure not dropped on SLAVE
|
||||
}
|
||||
|
||||
-- let $last_error = query_get_value("SHOW SLAVE STATUS", Last_SQL_Errno, 1)
|
||||
if ($last_error)
|
||||
{
|
||||
-- die UNEXPECTED SLAVE SQL error: $last_error
|
||||
}
|
||||
|
||||
-- connection master
|
||||
-- eval DROP DATABASE $dbname
|
||||
-- sync_slave_with_master
|
||||
|
||||
-- source include/rpl_end.inc
|
19
mysql-test/suite/rpl/r/rpl_15919.result
Normal file
19
mysql-test/suite/rpl/r/rpl_15919.result
Normal file
@@ -0,0 +1,19 @@
|
||||
include/master-slave.inc
|
||||
[connection master]
|
||||
connection master;
|
||||
create table RPL(a int);
|
||||
insert into RPL values(1);
|
||||
connection slave;
|
||||
select * from rpl;
|
||||
a
|
||||
1
|
||||
insert into RPL values(3);
|
||||
insert into rpl values(4);
|
||||
select * from rpl;
|
||||
a
|
||||
1
|
||||
3
|
||||
4
|
||||
connection master;
|
||||
drop table RPL;
|
||||
include/rpl_end.inc
|
38
mysql-test/suite/rpl/r/rpl_lcase_tblnames_rewrite_db.result
Normal file
38
mysql-test/suite/rpl/r/rpl_lcase_tblnames_rewrite_db.result
Normal file
@@ -0,0 +1,38 @@
|
||||
include/master-slave.inc
|
||||
[connection master]
|
||||
SET SQL_LOG_BIN=0;
|
||||
CREATE DATABASE B37656;
|
||||
SET SQL_LOG_BIN=1;
|
||||
connection slave;
|
||||
CREATE DATABASE BUG37656;
|
||||
### action: show that database on slave is created in lowercase
|
||||
SHOW DATABASES LIKE '%37656';
|
||||
Database (%37656)
|
||||
bug37656
|
||||
connection master;
|
||||
USE B37656;
|
||||
CREATE TABLE T1 (a int);
|
||||
INSERT INTO T1 VALUES (1);
|
||||
### assertion: master contains capitalized case table
|
||||
SHOW TABLES;
|
||||
Tables_in_B37656
|
||||
T1
|
||||
connection slave;
|
||||
use bug37656;
|
||||
### assertion: slave contains lowered case table
|
||||
SHOW TABLES;
|
||||
Tables_in_bug37656
|
||||
t1
|
||||
### assertion: master and slave tables do not differ
|
||||
include/diff_tables.inc [master:B37656.T1, slave:bug37656.t1]
|
||||
connection master;
|
||||
SET SQL_LOG_BIN=0;
|
||||
DROP DATABASE B37656;
|
||||
SET SQL_LOG_BIN=1;
|
||||
SHOW DATABASES LIKE '%37656';
|
||||
Database (%37656)
|
||||
connection slave;
|
||||
DROP DATABASE BUG37656;
|
||||
SHOW DATABASES LIKE '%37656';
|
||||
Database (%37656)
|
||||
include/rpl_end.inc
|
60
mysql-test/suite/rpl/r/rpl_row_lcase_tblnames.result
Normal file
60
mysql-test/suite/rpl/r/rpl_row_lcase_tblnames.result
Normal file
@@ -0,0 +1,60 @@
|
||||
include/master-slave.inc
|
||||
[connection master]
|
||||
******** [ MASTER ] ********
|
||||
CREATE DATABASE BUG_37656;
|
||||
use BUG_37656;
|
||||
show databases like 'BUG_37656';
|
||||
Database (BUG_37656)
|
||||
BUG_37656
|
||||
connection slave;
|
||||
******** [ SLAVE ] ********
|
||||
show databases like 'bug_37656';
|
||||
Database (bug_37656)
|
||||
bug_37656
|
||||
connection master;
|
||||
******** [ MASTER ] ********
|
||||
CREATE TABLE T1 (a int);
|
||||
CREATE TABLE T2 (b int) ENGINE=InnoDB;
|
||||
CREATE TABLE T3 (txt TEXT);
|
||||
show tables;
|
||||
Tables_in_BUG_37656
|
||||
T1
|
||||
T2
|
||||
T3
|
||||
connection slave;
|
||||
******** [ SLAVE ] ********
|
||||
use bug_37656;
|
||||
show tables;
|
||||
Tables_in_bug_37656
|
||||
t2
|
||||
t3
|
||||
CREATE TABLE t1 (a INT);
|
||||
connection master;
|
||||
******** [ MASTER ] ********
|
||||
use BUG_37656;
|
||||
INSERT INTO T1 VALUES (1);
|
||||
INSERT INTO T2 VALUES (1);
|
||||
use test;
|
||||
INSERT INTO BUG_37656.T1 VALUES (2);
|
||||
INSERT INTO BUG_37656.T2 VALUES (2);
|
||||
LOAD DATA INFILE '../../std_data/words.dat' INTO TABLE BUG_37656.T3;
|
||||
connection slave;
|
||||
******** [ SLAVE ] ********
|
||||
include/diff_tables.inc [master:BUG_37656.T2, slave:bug_37656.t2]
|
||||
include/diff_tables.inc [master:BUG_37656.T3, slave:bug_37656.t3]
|
||||
connection master;
|
||||
******** [ MASTER ] ********
|
||||
DROP DATABASE BUG_37656;
|
||||
connection slave;
|
||||
connection master;
|
||||
CREATE DATABASE B50653;
|
||||
USE B50653;
|
||||
CREATE PROCEDURE b50653_proc() BEGIN SELECT 1; END;
|
||||
connection slave;
|
||||
connection master;
|
||||
DROP PROCEDURE b50653_proc;
|
||||
connection slave;
|
||||
connection master;
|
||||
DROP DATABASE B50653;
|
||||
connection slave;
|
||||
include/rpl_end.inc
|
57
mysql-test/suite/rpl/r/rpl_stm_lcase_tblnames.result
Normal file
57
mysql-test/suite/rpl/r/rpl_stm_lcase_tblnames.result
Normal file
@@ -0,0 +1,57 @@
|
||||
include/master-slave.inc
|
||||
[connection master]
|
||||
******** [ MASTER ] ********
|
||||
CREATE DATABASE BUG_37656;
|
||||
use BUG_37656;
|
||||
show databases like 'BUG_37656';
|
||||
Database (BUG_37656)
|
||||
BUG_37656
|
||||
connection slave;
|
||||
******** [ SLAVE ] ********
|
||||
show databases like 'bug_37656';
|
||||
Database (bug_37656)
|
||||
bug_37656
|
||||
connection master;
|
||||
******** [ MASTER ] ********
|
||||
CREATE TABLE T1 (a int);
|
||||
CREATE TABLE T2 (b int) ENGINE=InnoDB;
|
||||
CREATE TABLE T3 (txt TEXT);
|
||||
show tables;
|
||||
Tables_in_BUG_37656
|
||||
T1
|
||||
T2
|
||||
T3
|
||||
connection slave;
|
||||
******** [ SLAVE ] ********
|
||||
use bug_37656;
|
||||
show tables;
|
||||
Tables_in_bug_37656
|
||||
t2
|
||||
t3
|
||||
CREATE TABLE t1 (a INT);
|
||||
connection master;
|
||||
******** [ MASTER ] ********
|
||||
use BUG_37656;
|
||||
INSERT INTO T1 VALUES (1);
|
||||
INSERT INTO T2 VALUES (1);
|
||||
LOAD DATA INFILE '../../std_data/words.dat' INTO TABLE BUG_37656.T3;
|
||||
connection slave;
|
||||
******** [ SLAVE ] ********
|
||||
include/diff_tables.inc [master:BUG_37656.T2, slave:bug_37656.t2]
|
||||
include/diff_tables.inc [master:BUG_37656.T3, slave:bug_37656.t3]
|
||||
connection master;
|
||||
******** [ MASTER ] ********
|
||||
DROP DATABASE BUG_37656;
|
||||
connection slave;
|
||||
connection master;
|
||||
CREATE DATABASE B50653;
|
||||
USE B50653;
|
||||
CREATE PROCEDURE b50653_proc() BEGIN SELECT 1; END;
|
||||
connection slave;
|
||||
connection master;
|
||||
DROP PROCEDURE b50653_proc;
|
||||
connection slave;
|
||||
connection master;
|
||||
DROP DATABASE B50653;
|
||||
connection slave;
|
||||
include/rpl_end.inc
|
@@ -12916,10 +12916,6 @@ ROLLBACK;
|
||||
SET AUTOCOMMIT=1;
|
||||
connection slave;
|
||||
include/diff_tables.inc [master:t1, slave:t1]
|
||||
Warnings:
|
||||
Warning 1287 '<select expression> INTO <destination>;' is deprecated and will be removed in a future release. Please use 'SELECT <select list> INTO <destination> FROM...' instead
|
||||
Warnings:
|
||||
Warning 1287 '<select expression> INTO <destination>;' is deprecated and will be removed in a future release. Please use 'SELECT <select list> INTO <destination> FROM...' instead
|
||||
connection master;
|
||||
DROP TABLE `t1`;
|
||||
connection slave;
|
||||
|
1
mysql-test/suite/rpl/t/rpl_15919-slave.opt
Normal file
1
mysql-test/suite/rpl/t/rpl_15919-slave.opt
Normal file
@@ -0,0 +1 @@
|
||||
--lower_case_table_names=1
|
18
mysql-test/suite/rpl/t/rpl_15919.test
Normal file
18
mysql-test/suite/rpl/t/rpl_15919.test
Normal file
@@ -0,0 +1,18 @@
|
||||
--source include/have_case_sensitive_file_system.inc
|
||||
--source include/have_innodb.inc
|
||||
--source include/master-slave.inc
|
||||
|
||||
--connection master
|
||||
create table RPL(a int);
|
||||
insert into RPL values(1);
|
||||
|
||||
--sync_slave_with_master
|
||||
select * from rpl;
|
||||
insert into RPL values(3);
|
||||
insert into rpl values(4);
|
||||
select * from rpl;
|
||||
|
||||
--connection master
|
||||
drop table RPL;
|
||||
|
||||
--source include/rpl_end.inc
|
@@ -0,0 +1 @@
|
||||
--lower-case-table-names=1 "--replicate-rewrite-db=b37656->bug37656"
|
60
mysql-test/suite/rpl/t/rpl_lcase_tblnames_rewrite_db.test
Normal file
60
mysql-test/suite/rpl/t/rpl_lcase_tblnames_rewrite_db.test
Normal file
@@ -0,0 +1,60 @@
|
||||
# BUG#37656
|
||||
#
|
||||
# DESCRIPTION
|
||||
#
|
||||
#
|
||||
# This test case is tests whether replication works properly when
|
||||
# slave is configured with --lower-case-table-names=1 and replication
|
||||
# rewrite rules are in effect.
|
||||
#
|
||||
# It checks four issues:
|
||||
#
|
||||
# (i) master contains capitalized table name
|
||||
#
|
||||
# (ii) slave contains lowered case table name
|
||||
#
|
||||
# (iii) master and slave tables do not differ
|
||||
#
|
||||
-- source include/master-slave.inc
|
||||
-- source include/not_windows.inc
|
||||
|
||||
SET SQL_LOG_BIN=0;
|
||||
CREATE DATABASE B37656;
|
||||
SET SQL_LOG_BIN=1;
|
||||
|
||||
-- connection slave
|
||||
CREATE DATABASE BUG37656;
|
||||
|
||||
-- echo ### action: show that database on slave is created in lowercase
|
||||
SHOW DATABASES LIKE '%37656';
|
||||
|
||||
-- connection master
|
||||
USE B37656;
|
||||
CREATE TABLE T1 (a int);
|
||||
INSERT INTO T1 VALUES (1);
|
||||
|
||||
-- echo ### assertion: master contains capitalized case table
|
||||
SHOW TABLES;
|
||||
|
||||
-- sync_slave_with_master
|
||||
|
||||
use bug37656;
|
||||
|
||||
-- echo ### assertion: slave contains lowered case table
|
||||
SHOW TABLES;
|
||||
|
||||
-- echo ### assertion: master and slave tables do not differ
|
||||
let $diff_tables= master:B37656.T1, slave:bug37656.t1;
|
||||
|
||||
-- source include/diff_tables.inc
|
||||
|
||||
-- connection master
|
||||
SET SQL_LOG_BIN=0;
|
||||
DROP DATABASE B37656;
|
||||
SET SQL_LOG_BIN=1;
|
||||
SHOW DATABASES LIKE '%37656';
|
||||
|
||||
-- connection slave
|
||||
DROP DATABASE BUG37656;
|
||||
SHOW DATABASES LIKE '%37656';
|
||||
--source include/rpl_end.inc
|
1
mysql-test/suite/rpl/t/rpl_row_lcase_tblnames-slave.opt
Normal file
1
mysql-test/suite/rpl/t/rpl_row_lcase_tblnames-slave.opt
Normal file
@@ -0,0 +1 @@
|
||||
--replicate-do-db=bug_37656 --replicate-ignore-table=buG_37656.T1 --replicate-do-table=bUg_37656.T2 --replicate-do-table=bUg_37656.T3 --lower-case-table-names=1
|
12
mysql-test/suite/rpl/t/rpl_row_lcase_tblnames.test
Normal file
12
mysql-test/suite/rpl/t/rpl_row_lcase_tblnames.test
Normal file
@@ -0,0 +1,12 @@
|
||||
# BUG#37656
|
||||
#
|
||||
# For details look into extra/rpl_tests/rpl_lower_case_table_names.test
|
||||
#
|
||||
|
||||
-- source include/master-slave.inc
|
||||
-- source include/have_innodb.inc
|
||||
-- source include/not_windows.inc
|
||||
-- source include/have_binlog_format_row.inc
|
||||
|
||||
-- let $engine=InnoDB
|
||||
-- source include/rpl_lower_case_table_names.test
|
1
mysql-test/suite/rpl/t/rpl_stm_lcase_tblnames-slave.opt
Normal file
1
mysql-test/suite/rpl/t/rpl_stm_lcase_tblnames-slave.opt
Normal file
@@ -0,0 +1 @@
|
||||
--replicate-do-db=bug_37656 --replicate-ignore-table=bug_37656.t1 --replicate-do-table=bug_37656.t2 --replicate-do-table=bug_37656.t3 --lower-case-table-names=1
|
12
mysql-test/suite/rpl/t/rpl_stm_lcase_tblnames.test
Normal file
12
mysql-test/suite/rpl/t/rpl_stm_lcase_tblnames.test
Normal file
@@ -0,0 +1,12 @@
|
||||
# BUG#37656
|
||||
#
|
||||
# For details look into extra/rpl_tests/rpl_lower_case_table_names.test
|
||||
#
|
||||
|
||||
-- source include/master-slave.inc
|
||||
-- source include/have_innodb.inc
|
||||
-- source include/not_windows.inc
|
||||
-- source include/have_binlog_format_mixed_or_statement.inc
|
||||
|
||||
-- let $engine=InnoDB
|
||||
-- source include/rpl_lower_case_table_names.test
|
Reference in New Issue
Block a user