2003-02-14 11:47:41 +02:00
|
|
|
#
|
|
|
|
# Test of replicating user variables
|
|
|
|
#
|
2003-01-30 21:39:54 +04:00
|
|
|
source include/master-slave.inc;
|
2004-10-26 19:30:01 +03:00
|
|
|
# Disable PS as the log positions differs
|
|
|
|
--disable_ps_protocol
|
|
|
|
|
2003-02-14 11:47:41 +02:00
|
|
|
|
2003-02-21 23:38:56 +01:00
|
|
|
# Clean up old slave's binlogs.
|
|
|
|
# The slave is started with --log-slave-updates
|
|
|
|
# and this test does SHOW BINLOG EVENTS on the slave's
|
|
|
|
# binlog. But previous tests can influence the current test's
|
|
|
|
# binlog (e.g. a temporary table in the previous test has not
|
|
|
|
# been explicitly deleted, or it has but the slave hasn't had
|
|
|
|
# enough time to catch it before STOP SLAVE,
|
|
|
|
# and at the beginning of the current
|
|
|
|
# test the slave immediately writes DROP TEMPORARY TABLE this_old_table).
|
|
|
|
# We wait for the slave to have written all he wants to the binlog
|
|
|
|
# (otherwise RESET MASTER may come too early).
|
|
|
|
save_master_pos;
|
|
|
|
connection slave;
|
|
|
|
sync_with_master;
|
|
|
|
reset master;
|
|
|
|
connection master;
|
|
|
|
|
2003-01-30 21:39:54 +04:00
|
|
|
create table t1(n char(30));
|
|
|
|
set @i1:=12345678901234, @i2:=-12345678901234, @i3:=0, @i4:=-1;
|
|
|
|
set @s1:='This is a test', @r1:=12.5, @r2:=-12.5;
|
|
|
|
set @n1:=null;
|
|
|
|
set @s2:='', @s3:='abc\'def', @s4:= 'abc\\def', @s5:= 'abc''def';
|
|
|
|
insert into t1 values (@i1), (@i2), (@i3), (@i4);
|
|
|
|
insert into t1 values (@r1), (@r2);
|
|
|
|
insert into t1 values (@s1), (@s2), (@s3), (@s4), (@s5);
|
|
|
|
insert into t1 values (@n1);
|
2003-10-02 10:31:37 +02:00
|
|
|
insert into t1 values (@n2); # not explicitely set before
|
2003-01-30 21:39:54 +04:00
|
|
|
insert into t1 values (@a:=0), (@a:=@a+1), (@a:=@a+1);
|
|
|
|
insert into t1 values (@a+(@b:=@a+1));
|
|
|
|
set @q:='abc';
|
|
|
|
insert t1 values (@q), (@q:=concat(@q, 'n1')), (@q:=concat(@q, 'n2'));
|
|
|
|
set @a:=5;
|
|
|
|
insert into t1 values (@a),(@a);
|
2003-10-02 10:31:37 +02:00
|
|
|
connection master1; # see if variable is reset in binlog when thread changes
|
|
|
|
insert into t1 values (@a),(@a),(@a*5);
|
|
|
|
select * from t1;
|
2003-01-30 21:39:54 +04:00
|
|
|
save_master_pos;
|
|
|
|
connection slave;
|
|
|
|
sync_with_master;
|
|
|
|
select * from t1;
|
2005-03-16 04:32:47 +03:00
|
|
|
--replace_column 2 # 5 #
|
|
|
|
show binlog events from 98;
|
2006-05-05 11:21:21 +03:00
|
|
|
#
|
|
|
|
# BUG19136: Crashing log-bin and uninitialized user variables in a derived table
|
|
|
|
# just to check nothing bad happens anymore
|
2006-05-07 16:02:55 +03:00
|
|
|
#
|
2003-01-30 21:39:54 +04:00
|
|
|
connection master;
|
2006-05-05 11:21:21 +03:00
|
|
|
insert into t1 select * FROM (select @var1 union select @var2) AS t2;
|
2003-01-30 21:39:54 +04:00
|
|
|
drop table t1;
|
|
|
|
save_master_pos;
|
2006-05-05 11:21:21 +03:00
|
|
|
|
2003-01-30 21:39:54 +04:00
|
|
|
connection slave;
|
|
|
|
sync_with_master;
|
|
|
|
stop slave;
|
2005-07-28 03:22:47 +03:00
|
|
|
|
|
|
|
# End of 4.1 tests
|