mirror of
https://github.com/MariaDB/server.git
synced 2025-01-27 01:04:19 +01:00
d40f7056ae
mysql-test/include/have_outfile.inc: Use MYSQLTEST_VARDIR mysql-test/include/test_outfile.inc: Use MYSQLTEST_VARDIR mysql-test/mysql-test-run.pl: Create variable $MYSQLTEST_VARDIR that points to the vardir Don't create a symlink from var/ to the physical vardir if it's somewhere else Setup a symlink(or copy dir on windows) for std_data so it is available in the physical vardir Use "../tmp" as slave-load-tmpdir, since the server is started in var/master-data and slave in var/slave-data they will both find the dumps in "../tmp" mysql-test/mysql-test-run.sh: Export MYSQLTEST_VARDIR, always pointing at mysql-test/var mysql-test/r/backup.result: Use MYSQLTEST_VARDIR mysql-test/r/blackhole.result: Use "../std_data_ln" to find std_data files mysql-test/r/loaddata.result: Use "../std_data_ln" to find std_data files mysql-test/r/mysqlbinlog.result: Use "../std_data_ln" to find std_data files mysql-test/r/mysqltest.result: Use MYSQLTEST_VARDIR mysql-test/r/outfile.result: Use MYSQLTEST_VARDIR mysql-test/r/query_cache.result: Add missing drop function mysql-test/r/rpl000001.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl000004.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_innodb.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_loaddata.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_loaddata_rule_m.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_loaddata_rule_s.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_loaddatalocal.result: Use MYSQLTEST_VARDIR mysql-test/r/rpl_log.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_misc_functions.result: Use MYSQLTEST_VARDIR mysql-test/r/rpl_replicate_do.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_rewrite_db.result: Use "../std_data_ln" to find std_data files mysql-test/r/rpl_timezone.result: Use "../std_data_ln" to find std_data files mysql-test/r/symlink.result: Use MYSQLTEST_VARDIR mysql-test/r/trigger.result: Use "../std_data_ln" to find std_data files mysql-test/r/view.result: Use "../std_data_ln" to find std_data files mysql-test/r/warnings.result: Use "../std_data_ln" to find std_data files mysql-test/t/backup-master.sh: Use MYSQLTEST_VARDIR mysql-test/t/backup.test: Use MYSQLTEST_VARDIR mysql-test/t/blackhole.test: Use "../std_data_ln" to find std_data files mysql-test/t/ctype_ucs_binlog.test: Use MYSQLTEST_VARDIR mysql-test/t/im_daemon_life_cycle-im.opt: Use MYSQLTEST_VARDIR mysql-test/t/im_options_set.imtest: Use MYSQLTEST_VARDIR mysql-test/t/im_options_unset.imtest: Use MYSQLTEST_VARDIR mysql-test/t/loaddata.test: Use "../std_data_ln" to find std_data files mysql-test/t/myisam.test: Use MYSQLTEST_VARDIR mysql-test/t/mysqlbinlog.test: Use "../std_data_ln" to find std_data files mysql-test/t/mysqlbinlog2.test: Use MYSQLTEST_VARDIR mysql-test/t/mysqldump.test: Use MYSQLTEST_VARDIR mysql-test/t/mysqltest.test: Use MYSQLTEST_VARDIR mysql-test/t/ndb_autodiscover.test: Use MYSQLTEST_VARDIR mysql-test/t/outfile.test: Use MYSQLTEST_VARDIR mysql-test/t/query_cache.test: Add missing drop function mysql-test/t/repair.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl000001.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl000004.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl000009.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl000015-slave.sh: Use MYSQLTEST_VARDIR mysql-test/t/rpl000017-slave.sh: Use MYSQLTEST_VARDIR mysql-test/t/rpl_EE_error.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl_charset.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl_drop_db.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl_flush_log_loop-master.opt: Use MYSQLTEST_VARDIR mysql-test/t/rpl_flush_log_loop-master.sh: Use MYSQLTEST_VARDIR mysql-test/t/rpl_flush_log_loop-slave.opt: Use MYSQLTEST_VARDIR mysql-test/t/rpl_flush_log_loop-slave.sh: Use MYSQLTEST_VARDIR mysql-test/t/rpl_innodb.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_loaddata.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_loaddata_rule_m.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_loaddata_rule_s.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_loaddatalocal.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl_log.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_misc_functions-slave.sh: Use MYSQLTEST_VARDIR mysql-test/t/rpl_misc_functions.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl_replicate_do.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_rewrite_db.test: Use "../std_data_ln" to find std_data files mysql-test/t/rpl_rotate_logs-slave.sh: Use MYSQLTEST_VARDIR mysql-test/t/rpl_rotate_logs.test: Use MYSQLTEST_VARDIR mysql-test/t/rpl_timezone.test: Use MYSQLTEST_VARDIR mysql-test/t/show_check.test: Use MYSQLTEST_VARDIR mysql-test/t/sp-destruct.test: Use MYSQLTEST_VARDIR mysql-test/t/symlink.test: Use MYSQLTEST_VARDIR mysql-test/t/temp_table-master.opt: Use MYSQLTEST_VARDIR mysql-test/t/trigger-compat.test: Use MYSQLTEST_VARDIR mysql-test/t/trigger-grant.test: Use MYSQLTEST_VARDIR mysql-test/t/trigger.test: Use "../std_data_ln" to find std_data files mysql-test/t/type_varchar.test: Use MYSQLTEST_VARDIR mysql-test/t/user_var-binlog.test: Use MYSQLTEST_VARDIR mysql-test/t/view.test: Use "../std_data_ln" to find std_data files mysql-test/t/warnings.test: Use "../std_data_ln" to find std_data files mysql-test/include/sourced.inc: New BitKeeper file ``mysql-test/include/sourced.inc'' mysql-test/include/sourced1.inc: New BitKeeper file ``mysql-test/include/sourced1.inc''
173 lines
5.2 KiB
Text
173 lines
5.2 KiB
Text
# Replication of character sets.
|
|
# This test will fail if the server/client does not support enough charsets.
|
|
|
|
source include/master-slave.inc;
|
|
--disable_warnings
|
|
set timestamp=1000000000;
|
|
drop database if exists mysqltest2;
|
|
drop database if exists mysqltest3;
|
|
--enable_warnings
|
|
|
|
create database mysqltest2 character set latin2;
|
|
set @@character_set_server=latin5;
|
|
create database mysqltest3;
|
|
--disable_query_log
|
|
select "--- --master--" as "";
|
|
--enable_query_log
|
|
show create database mysqltest2;
|
|
show create database mysqltest3;
|
|
sync_slave_with_master;
|
|
--disable_query_log
|
|
select "--- --slave--" as "";
|
|
--enable_query_log
|
|
show create database mysqltest2;
|
|
show create database mysqltest3;
|
|
|
|
connection master;
|
|
set @@collation_server=armscii8_bin;
|
|
drop database mysqltest3;
|
|
create database mysqltest3;
|
|
--disable_query_log
|
|
select "--- --master--" as "";
|
|
--enable_query_log
|
|
show create database mysqltest3;
|
|
sync_slave_with_master;
|
|
--disable_query_log
|
|
select "--- --slave--" as "";
|
|
--enable_query_log
|
|
show create database mysqltest3;
|
|
|
|
connection master;
|
|
use mysqltest2;
|
|
create table t1 (a int auto_increment primary key, b varchar(100));
|
|
set character_set_client=cp850, collation_connection=latin2_croatian_ci;
|
|
insert into t1 (b) values(@@character_set_server);
|
|
insert into t1 (b) values(@@collation_server);
|
|
# character_set_database and collation_database are not tested as they
|
|
# needn't be replicated (Bar said in Jan 2005).
|
|
insert into t1 (b) values(@@character_set_client);
|
|
# collation_client does not exist
|
|
insert into t1 (b) values(@@character_set_connection);
|
|
insert into t1 (b) values(@@collation_connection);
|
|
--disable_query_log
|
|
select "--- --master--" as "";
|
|
--enable_query_log
|
|
select * from t1 order by a;
|
|
sync_slave_with_master;
|
|
--disable_query_log
|
|
select "--- --slave--" as "";
|
|
--enable_query_log
|
|
select * from mysqltest2.t1 order by a;
|
|
|
|
connection master;
|
|
set character_set_client=latin1, collation_connection=latin1_german1_ci;
|
|
truncate table t1;
|
|
insert into t1 (b) values(@@collation_connection);
|
|
insert into t1 (b) values(LEAST("Müller","Muffler"));
|
|
set collation_connection=latin1_german2_ci;
|
|
insert into t1 (b) values(@@collation_connection);
|
|
insert into t1 (b) values(LEAST("Müller","Muffler"));
|
|
--disable_query_log
|
|
select "--- --master--" as "";
|
|
--enable_query_log
|
|
select * from t1 order by a;
|
|
sync_slave_with_master;
|
|
--disable_query_log
|
|
select "--- --slave--" as "";
|
|
--enable_query_log
|
|
select * from mysqltest2.t1 order by a;
|
|
|
|
# Presently charset info is not logged with LOAD DATA but it will
|
|
# change in Jan 2005 when Dmitri pushes his new LOAD DATA,
|
|
# before 5.0.3 goes out. When done, LOAD DATA INFILE should be tested
|
|
# here.
|
|
|
|
# See if user var is prefixed with collation in binlog and replicated well.
|
|
# Note: replication of user variables is broken as far as derivation is
|
|
# concerned. That's because when we store a user variable in the binlog,
|
|
# we lose its derivation. So later on the slave, it's impossible to
|
|
# know if the collation was explicit or not, so we use DERIVATION_NONE,
|
|
# which provokes error messages (like 'Illegal mix of collation') when
|
|
# we replay the master's INSERT/etc statements.
|
|
connection master;
|
|
set @a= _cp850 'Müller' collate cp850_general_ci;
|
|
truncate table t1;
|
|
insert into t1 (b) values(collation(@a));
|
|
--disable_query_log
|
|
select "--- --master--" as "";
|
|
--enable_query_log
|
|
select * from t1 order by a;
|
|
sync_slave_with_master;
|
|
--disable_query_log
|
|
select "--- --slave--" as "";
|
|
--enable_query_log
|
|
select * from mysqltest2.t1 order by a;
|
|
|
|
connection master;
|
|
drop database mysqltest2;
|
|
drop database mysqltest3;
|
|
--replace_column 2 # 5 #
|
|
show binlog events from 98;
|
|
sync_slave_with_master;
|
|
|
|
# Check that we can change global.collation_server (since 5.0.3)
|
|
|
|
set global character_set_server=latin2;
|
|
set global character_set_server=latin1; # back
|
|
connection master;
|
|
set global character_set_server=latin2;
|
|
set global character_set_server=latin1; # back
|
|
|
|
# Check that SET ONE_SHOT is really one shot
|
|
|
|
set one_shot @@character_set_server=latin5;
|
|
set @@max_join_size=1000;
|
|
select @@character_set_server;
|
|
select @@character_set_server;
|
|
set @@character_set_server=latin5;
|
|
select @@character_set_server;
|
|
select @@character_set_server;
|
|
|
|
# ONE_SHOT on not charset/collation stuff is not allowed
|
|
-- error 1382
|
|
set one_shot max_join_size=10;
|
|
|
|
# Test of wrong character set numbers;
|
|
error 1115;
|
|
set character_set_client=9999999;
|
|
error 1273;
|
|
set collation_server=9999998;
|
|
|
|
# This one was contributed by Sergey Petrunia (BUG#3943)
|
|
|
|
use test;
|
|
CREATE TABLE t1 (c1 VARBINARY(255), c2 VARBINARY(255));
|
|
SET CHARACTER_SET_CLIENT=koi8r,
|
|
CHARACTER_SET_CONNECTION=cp1251,
|
|
CHARACTER_SET_RESULTS=koi8r;
|
|
INSERT INTO t1 (c1, c2) VALUES ('îÕ, ÚÁ ÒÙÂÁÌËÕ','îÕ, ÚÁ ÒÙÂÁÌËÕ');
|
|
select hex(c1), hex(c2) from t1;
|
|
sync_slave_with_master;
|
|
select hex(c1), hex(c2) from t1;
|
|
|
|
connection master;
|
|
# Let's have a look at generated SETs.
|
|
--replace_result $MYSQL_TEST_DIR MYSQL_TEST_DIR
|
|
--exec $MYSQL_BINLOG --short-form $MYSQLTEST_VARDIR/log/master-bin.000001
|
|
drop table t1;
|
|
sync_slave_with_master;
|
|
|
|
#
|
|
# BUG#6676: Derivation of variables must be correct on slave
|
|
#
|
|
connection master;
|
|
create table `t1` (
|
|
`pk` varchar(10) not null default '',
|
|
primary key (`pk`)
|
|
) engine=myisam default charset=latin1;
|
|
set @p=_latin1 'test';
|
|
update t1 set pk='test' where pk=@p;
|
|
drop table t1;
|
|
sync_slave_with_master;
|
|
|
|
# End of 4.1 tests
|