• unknown's avatar
    fixes Bug #25305 (and several other similar test tailures with the same symptom) · 2c631fe8
    unknown authored
    - make tests wait until ndb connects properly
    
    
    mysql-test/extra/rpl_tests/rpl_commit_after_flush.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_delete_no_where.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_insert_ignore.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_log.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_multi_update2.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_multi_update3.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_relayrotate.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_001.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_UUID.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_basic.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_blob.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_charset.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_func003.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_sp003.test:
      make tests wait until ndb connects properly
    mysql-test/extra/rpl_tests/rpl_row_sp006.test:
      make tests wait until ndb connects properly
    mysql-test/include/have_multi_ndb.inc:
      make tests wait until ndb connects properly
    mysql-test/include/have_ndb.inc:
      make tests wait until ndb connects properly
    mysql-test/include/ndb_not_readonly.inc:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_commit_after_flush.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_delete_no_where.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_insert_ignore.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_multi_update2.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_multi_update3.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_2innodb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_2myisam.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_UUID.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_auto_inc.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_bank.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_basic.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_blob.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_blob2.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_charset.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_circular.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_circular_simplex.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_commit_afterflush.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_dd_advance.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_dd_basic.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_dd_partitions.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_ddl.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_delete_nowhere.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_do_db.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_do_table.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_extraCol.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_func003.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_idempotent.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_innodb2ndb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_innodb_trans.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_insert_ignore.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_load.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_log.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_multi.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_multi_update2.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_multi_update3.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_myisam2ndb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_relayrotate.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_rep_ignore.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_row_001.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_sp003.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_sp006.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_stm_innodb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_sync.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndb_trig004.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_ndbapi_multi.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_relayrotate.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_001.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_UUID.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_basic_2myisam.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_basic_3innodb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_basic_7ndb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_blob_innodb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_blob_myisam.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_charset.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_func003.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_log.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_log_innodb.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_sp003.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_row_sp006_InnoDB.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_stm_log.test:
      make tests wait until ndb connects properly
    mysql-test/t/rpl_truncate_7ndb.test:
      make tests wait until ndb connects properly
    mysql-test/include/ndb_master-slave.inc:
      New BitKeeper file ``mysql-test/include/ndb_master-slave.inc''
    2c631fe8
rpl_row_charset.test 5.35 KB
# Replication of character sets.
# This test will fail if the server/client does not support enough charsets.

--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;

select "--- --muller--" as "";
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("Mller","Muffler"));
set collation_connection=latin1_german2_ci;
insert into t1 (b) values(@@collation_connection);
insert into t1 (b) values(LEAST("Mller","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.


select "--- --INSERT--" as "";
connection master;
set @a= _cp850 'Mller' 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;
source include/show_binlog_events.inc;
sync_slave_with_master;

# Check that we can change global.collation_server (since 5.0.3)

select "--- --global--" as "";
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

select "--- --oneshot--" as "";
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)

select "--- --3943--" as "";
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 $MYSQLTEST_VARDIR MYSQL_TEST_DIR/var
#--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
#
select "--- --6676--" as "";
connection master;
eval create table `t1` (
  `pk` varchar(10) not null default '', 
  primary key (`pk`)
) engine=$engine_type default charset=latin1;
set @p=_latin1 'test';
update t1 set pk='test' where pk=@p;
drop table t1;
sync_slave_with_master;