2006-02-22 22:03:55 +01:00
|
|
|
|
##################################################################
|
|
|
|
|
# Author: JBM #
|
|
|
|
|
# Date: 2006-02-22 #
|
|
|
|
|
# Purpose: To test changes to mysqlbinlog for row based bin logs #
|
|
|
|
|
# We are using .opt file since we need small binlog size #
|
|
|
|
|
##################################################################
|
|
|
|
|
# Include Section
|
|
|
|
|
# Make sure that we have row based bin log
|
|
|
|
|
-- source include/have_binlog_format_row.inc
|
|
|
|
|
# Embedded server doesn't support binlogging
|
|
|
|
|
-- source include/not_embedded.inc
|
|
|
|
|
-- source include/master-slave.inc
|
2007-04-25 21:33:18 +02:00
|
|
|
|
# This test requires the cp932 charset compiled in
|
|
|
|
|
-- source include/have_cp932.inc
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# Setup Section
|
|
|
|
|
# we need this for getting fixed timestamps inside of this test
|
2006-02-22 23:11:42 +01:00
|
|
|
|
|
|
|
|
|
--disable_query_log
|
|
|
|
|
select "---Setup Section --" as "";
|
|
|
|
|
--enable_query_log
|
|
|
|
|
|
2006-02-22 22:03:55 +01:00
|
|
|
|
set timestamp=1000000000;
|
|
|
|
|
|
|
|
|
|
--disable_warnings
|
|
|
|
|
DROP TABLE IF EXISTS t1,t2,t3;
|
|
|
|
|
--enable_warnings
|
|
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
|
CREATE TABLE t1(word VARCHAR(20));
|
|
|
|
|
CREATE TABLE t2(id INT AUTO_INCREMENT NOT NULL PRIMARY KEY);
|
|
|
|
|
CREATE TABLE t3(c1 INT NOT NULL PRIMARY KEY, c2 LONGBLOB, c3 TIMESTAMP, c4 TEXT, c5 FLOAT);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Test Section
|
|
|
|
|
# Lets start by putting some data into the tables.
|
|
|
|
|
|
|
|
|
|
--disable_query_log
|
|
|
|
|
INSERT INTO t1 VALUES ("abirvalg");
|
|
|
|
|
LOAD DATA INFILE '../std_data_ln/words.dat' INTO TABLE t1;
|
|
|
|
|
LOAD DATA INFILE '../std_data_ln/words.dat' INTO TABLE t1;
|
|
|
|
|
LOAD DATA INFILE '../std_data_ln/words.dat' INTO TABLE t1;
|
|
|
|
|
LOAD DATA INFILE '../std_data_ln/words.dat' INTO TABLE t1;
|
|
|
|
|
LOAD DATA INFILE '../std_data_ln/words.dat' INTO TABLE t1;
|
|
|
|
|
|
|
|
|
|
# d1 length 3000
|
|
|
|
|
set @d1 = 'dd1';
|
|
|
|
|
set @d1 = concat(@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1);
|
|
|
|
|
set @d1 = concat(@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1);
|
|
|
|
|
set @d1 = concat(@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1,@d1);
|
|
|
|
|
|
|
|
|
|
let $count=500;
|
|
|
|
|
while ($count)
|
|
|
|
|
{
|
|
|
|
|
INSERT INTO t2 VALUES (NULL);
|
|
|
|
|
eval INSERT INTO t3 VALUES ($count,@d1,'20060222000000','Tested in Texas',$count*2.2);
|
|
|
|
|
dec $count;
|
|
|
|
|
}
|
|
|
|
|
--enable_query_log
|
|
|
|
|
|
2006-02-22 23:11:42 +01:00
|
|
|
|
|
|
|
|
|
--disable_query_log
|
|
|
|
|
select "---Test1 check table load --" as "";
|
|
|
|
|
--enable_query_log
|
|
|
|
|
|
2006-02-22 22:03:55 +01:00
|
|
|
|
# Lets Check the tables on the Master
|
|
|
|
|
SELECT COUNT(*) from t1;
|
|
|
|
|
SELECT COUNT(*) from t2;
|
|
|
|
|
SELECT COUNT(*) from t3;
|
|
|
|
|
SELECT * FROM t1 ORDER BY word LIMIT 5;
|
|
|
|
|
SELECT * FROM t2 ORDER BY id LIMIT 5;
|
|
|
|
|
SELECT c1, c3, c4, c5 FROM t3 ORDER BY c1 LIMIT 5;
|
|
|
|
|
|
|
|
|
|
# Should have the same on the slave;
|
|
|
|
|
|
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
SELECT COUNT(*) from t1;
|
|
|
|
|
SELECT COUNT(*) from t2;
|
|
|
|
|
SELECT COUNT(*) from t3;
|
|
|
|
|
SELECT * FROM t1 ORDER BY word LIMIT 5;
|
|
|
|
|
SELECT * FROM t2 ORDER BY id LIMIT 5;
|
|
|
|
|
SELECT c1, c3, c4, c5 FROM t3 ORDER BY c1 LIMIT 5;
|
|
|
|
|
|
|
|
|
|
# Okay time to get busy, back to master
|
|
|
|
|
|
|
|
|
|
connection master;
|
|
|
|
|
|
|
|
|
|
# simple query to show more in second binlog
|
|
|
|
|
insert into t1 values ("Alas");
|
|
|
|
|
flush logs;
|
|
|
|
|
|
|
|
|
|
# delimiters are for easier debugging in future
|
|
|
|
|
--disable_query_log
|
2006-02-22 23:11:42 +01:00
|
|
|
|
select "--- Test 1 Dump binlog to file --" as "";
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--enable_query_log
|
|
|
|
|
|
|
|
|
|
#
|
|
|
|
|
# Prepare local temporary file to recreate what we have currently.
|
|
|
|
|
|
|
|
|
|
--exec $MYSQL_BINLOG $MYSQLTEST_VARDIR/log/master-bin.000001 > $MYSQLTEST_VARDIR/tmp/master.sql
|
|
|
|
|
|
|
|
|
|
--exec $MYSQL_BINLOG $MYSQLTEST_VARDIR/log/master-bin.000002 >> $MYSQLTEST_VARDIR/tmp/master.sql
|
|
|
|
|
|
|
|
|
|
# Now that we have our file, lets get rid of the current database.
|
|
|
|
|
# Cleanup the master and the slave and try to recreate.
|
2006-02-22 23:11:42 +01:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test 1 delete tables, clean master and slave --" as "";
|
|
|
|
|
--enable_query_log
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
DROP TABLE t2;
|
|
|
|
|
DROP TABLE t3;
|
|
|
|
|
|
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
#we expect STOP SLAVE to produce a warning as the slave is stopped
|
|
|
|
|
#(the server was started with skip-slave-start)
|
|
|
|
|
--disable_warnings
|
|
|
|
|
stop slave;
|
|
|
|
|
--enable_warnings
|
|
|
|
|
--require r/slave-stopped.result
|
|
|
|
|
show status like 'Slave_running';
|
|
|
|
|
connection master;
|
|
|
|
|
reset master;
|
|
|
|
|
connection slave;
|
|
|
|
|
reset slave;
|
|
|
|
|
start slave;
|
|
|
|
|
--require r/slave-running.result
|
|
|
|
|
show status like 'Slave_running';
|
|
|
|
|
connection master;
|
|
|
|
|
|
|
|
|
|
# We should be clean at this point, now we will run in the file from above.
|
2006-02-22 23:11:42 +01:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test 1 Load from Dump binlog file --" as "";
|
|
|
|
|
--enable_query_log
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
--exec $MYSQL -e "source $MYSQLTEST_VARDIR/tmp/master.sql"
|
|
|
|
|
|
2006-02-22 23:11:42 +01:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test 1 Check Load Results --" as "";
|
|
|
|
|
--enable_query_log
|
|
|
|
|
|
2006-02-22 22:03:55 +01:00
|
|
|
|
# Lets Check the tables on the Master
|
|
|
|
|
SELECT COUNT(*) from t1;
|
|
|
|
|
SELECT COUNT(*) from t2;
|
|
|
|
|
SELECT COUNT(*) from t3;
|
|
|
|
|
SELECT * FROM t1 ORDER BY word LIMIT 5;
|
|
|
|
|
SELECT * FROM t2 ORDER BY id LIMIT 5;
|
|
|
|
|
SELECT c1, c3, c4, c5 FROM t3 ORDER BY c1 LIMIT 5;
|
|
|
|
|
|
|
|
|
|
# Should have the same on the slave;
|
|
|
|
|
|
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
SELECT COUNT(*) from t1;
|
|
|
|
|
SELECT COUNT(*) from t2;
|
|
|
|
|
SELECT COUNT(*) from t3;
|
|
|
|
|
SELECT * FROM t1 ORDER BY word LIMIT 5;
|
|
|
|
|
SELECT * FROM t2 ORDER BY id LIMIT 5;
|
|
|
|
|
SELECT c1, c3, c4, c5 FROM t3 ORDER BY c1 LIMIT 5;
|
|
|
|
|
connection master;
|
|
|
|
|
|
|
|
|
|
# We should be gold by the time, so I will get rid of our file.
|
|
|
|
|
|
|
|
|
|
--exec rm $MYSQLTEST_VARDIR/tmp/master.sql
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# this test for position option
|
2007-03-29 20:31:09 +02:00
|
|
|
|
# By setting this position to 413, we should only get the create of t3
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--disable_query_log
|
2006-02-22 23:11:42 +01:00
|
|
|
|
select "--- Test 2 position test --" as "";
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--enable_query_log
|
|
|
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
2007-03-29 21:38:03 +02:00
|
|
|
|
--exec $MYSQL_BINLOG --short-form --local-load=$MYSQLTEST_VARDIR/tmp/ --position=416 $MYSQLTEST_VARDIR/log/master-bin.000001
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# These are tests for remote binlog.
|
|
|
|
|
# They should return the same as previous test.
|
|
|
|
|
|
|
|
|
|
--disable_query_log
|
2006-02-22 23:11:42 +01:00
|
|
|
|
select "--- Test 3 First Remote test --" as "";
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--enable_query_log
|
|
|
|
|
|
|
|
|
|
# This is broken now
|
|
|
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
|
|
|
--exec $MYSQL_BINLOG --short-form --local-load=$MYSQLTEST_VARDIR/tmp/ --read-from-remote-server --user=root --host=127.0.0.1 --port=$MASTER_MYPORT master-bin.000001
|
|
|
|
|
|
|
|
|
|
# This part is disabled due to bug #17654
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test 4 Second Remote test --" as "";
|
|
|
|
|
--enable_query_log
|
|
|
|
|
--exec $MYSQL_BINLOG --read-from-remote-server --user=root --host=127.0.0.1 --port=$MASTER_MYPORT master-bin.000001 > $MYSQLTEST_VARDIR/tmp/remote.sql
|
|
|
|
|
|
|
|
|
|
--exec $MYSQL_BINLOG --read-from-remote-server --user=root --host=127.0.0.1 --port=$MASTER_MYPORT master-bin.000002 >> $MYSQLTEST_VARDIR/tmp/remote.sql
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# Now that we have our file, lets get rid of the current database.
|
|
|
|
|
# Cleanup the master and the slave and try to recreate.
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
DROP TABLE t1;
|
|
|
|
|
DROP TABLE t2;
|
|
|
|
|
DROP TABLE t3;
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
sync_slave_with_master;
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
#we expect STOP SLAVE to produce a warning as the slave is stopped
|
|
|
|
|
#(the server was started with skip-slave-start)
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
--disable_warnings
|
|
|
|
|
stop slave;
|
|
|
|
|
--enable_warnings
|
|
|
|
|
--require r/slave-stopped.result
|
|
|
|
|
show status like 'Slave_running';
|
|
|
|
|
connection master;
|
|
|
|
|
reset master;
|
|
|
|
|
connection slave;
|
|
|
|
|
reset slave;
|
|
|
|
|
start slave;
|
|
|
|
|
--require r/slave-running.result
|
|
|
|
|
show status like 'Slave_running';
|
|
|
|
|
connection master;
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# We should be clean at this point, now we will run in the file from above.
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
--exec $MYSQL -e "source $MYSQLTEST_VARDIR/tmp/remote.sql"
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# Lets Check the tables on the Master
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
SELECT COUNT(*) from t1;
|
|
|
|
|
SELECT COUNT(*) from t2;
|
|
|
|
|
SELECT COUNT(*) from t3;
|
|
|
|
|
SELECT * FROM t1 ORDER BY word LIMIT 5;
|
|
|
|
|
SELECT * FROM t2 ORDER BY id LIMIT 5;
|
|
|
|
|
SELECT c1, c3, c4, c5 FROM t3 ORDER BY c1 LIMIT 5;
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# Should have the same on the slave;
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
SELECT COUNT(*) from t1;
|
|
|
|
|
SELECT COUNT(*) from t2;
|
|
|
|
|
SELECT COUNT(*) from t3;
|
|
|
|
|
SELECT * FROM t1 ORDER BY word LIMIT 5;
|
|
|
|
|
SELECT * FROM t2 ORDER BY id LIMIT 5;
|
|
|
|
|
SELECT c1, c3, c4, c5 FROM t3 ORDER BY c1 LIMIT 5;
|
|
|
|
|
connection master;
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# We should be gold by the time, so I will get rid of our file.
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
--exec rm $MYSQLTEST_VARDIR/tmp/remote.sql
|
2006-02-22 22:03:55 +01:00
|
|
|
|
################### End Bug 17654 ######################
|
|
|
|
|
|
|
|
|
|
# LOAD DATA
|
|
|
|
|
--disable_query_log
|
2006-02-22 23:11:42 +01:00
|
|
|
|
select "--- Test 5 LOAD DATA --" as "";
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--enable_query_log
|
|
|
|
|
--replace_result $MYSQLTEST_VARDIR MYSQLTEST_VARDIR
|
|
|
|
|
--exec $MYSQL_BINLOG --short-form --local-load=$MYSQLTEST_VARDIR/tmp/ --read-from-remote-server --user=root --host=127.0.0.1 --port=$MASTER_MYPORT master-bin.000002
|
|
|
|
|
|
|
|
|
|
# Bug#7853 (mysqlbinlog does not accept input from stdin)
|
|
|
|
|
|
|
|
|
|
--disable_query_log
|
2006-02-22 23:11:42 +01:00
|
|
|
|
select "--- Test 6 reading stdin --" as "";
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--enable_query_log
|
|
|
|
|
--replace_result $MYSQL_TEST_DIR MYSQL_TEST_DIR
|
|
|
|
|
--exec $MYSQL_BINLOG --short-form - < $MYSQLTEST_VARDIR/log/master-bin.000001
|
|
|
|
|
|
2006-02-22 23:11:42 +01:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test 7 reading stdin w/position --" as "";
|
|
|
|
|
--enable_query_log
|
2006-02-22 22:03:55 +01:00
|
|
|
|
--replace_result $MYSQL_TEST_DIR MYSQL_TEST_DIR
|
2007-03-29 21:38:03 +02:00
|
|
|
|
--exec $MYSQL_BINLOG --short-form --position=416 - < $MYSQLTEST_VARDIR/log/master-bin.000001
|
2006-02-22 22:03:55 +01:00
|
|
|
|
|
|
|
|
|
# Bug#16217 (mysql client did not know how not switch its internal charset)
|
2006-02-22 23:11:42 +01:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test 8 switch internal charset --" as "";
|
|
|
|
|
--enable_query_log
|
2006-02-22 22:03:55 +01:00
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
|
|
|
|
#we expect STOP SLAVE to produce a warning as the slave is stopped
|
|
|
|
|
#(the server was started with skip-slave-start)
|
|
|
|
|
|
|
|
|
|
--disable_warnings
|
|
|
|
|
stop slave;
|
|
|
|
|
--enable_warnings
|
|
|
|
|
--require r/slave-stopped.result
|
|
|
|
|
show status like 'Slave_running';
|
|
|
|
|
connection master;
|
|
|
|
|
reset master;
|
|
|
|
|
connection slave;
|
|
|
|
|
reset slave;
|
|
|
|
|
start slave;
|
|
|
|
|
--require r/slave-running.result
|
|
|
|
|
show status like 'Slave_running';
|
|
|
|
|
connection master;
|
|
|
|
|
|
|
|
|
|
create table t4 (f text character set utf8);
|
|
|
|
|
create table t5 (f text character set cp932);
|
|
|
|
|
--exec $MYSQL --default-character-set=utf8 test -e "insert into t4 values(_utf8'ソ')"
|
|
|
|
|
--exec $MYSQL --default-character-set=cp932 test -e "insert into t5 values(_cp932'<27>\');"
|
|
|
|
|
flush logs;
|
|
|
|
|
rename table t4 to t04, t5 to t05;
|
|
|
|
|
--exec $MYSQL_BINLOG $MYSQLTEST_VARDIR/log/master-bin.000001 | $MYSQL --default-character-set=utf8
|
|
|
|
|
# original and recovered data must be equal
|
|
|
|
|
select HEX(f) from t04;
|
|
|
|
|
select HEX(f) from t4;
|
|
|
|
|
select HEX(f) from t05;
|
|
|
|
|
select HEX(f) from t5;
|
|
|
|
|
|
|
|
|
|
# slave should have same
|
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
select HEX(f) from t04;
|
|
|
|
|
select HEX(f) from t4;
|
|
|
|
|
select HEX(f) from t05;
|
|
|
|
|
select HEX(f) from t5;
|
|
|
|
|
|
2006-02-22 23:11:42 +01:00
|
|
|
|
--disable_query_log
|
|
|
|
|
select "--- Test cleanup --" as "";
|
|
|
|
|
--enable_query_log
|
2006-02-22 22:03:55 +01:00
|
|
|
|
# clean up
|
|
|
|
|
connection master;
|
|
|
|
|
sync_slave_with_master;
|
|
|
|
|
|
2007-05-22 10:50:32 -04:00
|
|
|
|
connection master;
|
|
|
|
|
|
|
|
|
|
# BUG#17654 also test mysqlbinlog to ensure it can read the binlog from a remote server
|
|
|
|
|
# and ensure that the results are the same as if read from a file (the same file).
|
|
|
|
|
|
|
|
|
|
--disable_warnings
|
|
|
|
|
DROP TABLE IF EXISTS t1;
|
|
|
|
|
--enable_warnings
|
|
|
|
|
|
|
|
|
|
CREATE TABLE t1 (a INT NOT NULL KEY, b INT);
|
|
|
|
|
|
|
|
|
|
INSERT INTO t1 VALUES(1,1);
|
|
|
|
|
|
|
|
|
|
SELECT * FROM t1;
|
|
|
|
|
|
|
|
|
|
FLUSH LOGS;
|
|
|
|
|
|
|
|
|
|
--exec $MYSQL_BINLOG --read-from-remote-server --user=root --host=127.0.0.1 --port=$MASTER_MYPORT master-bin.000001 > $MYSQLTEST_VARDIR/tmp/remote.sql
|
|
|
|
|
--exec $MYSQL_BINLOG $MYSQLTEST_VARDIR/log/master-bin.000001 > $MYSQLTEST_VARDIR/tmp/local.sql
|
|
|
|
|
|
|
|
|
|
--diff_files $MYSQLTEST_VARDIR/tmp/local.sql $MYSQLTEST_VARDIR/tmp/remote.sql
|
|
|
|
|
|
|
|
|
|
--exec rm $MYSQLTEST_VARDIR/tmp/remote.sql
|
|
|
|
|
|
|
|
|
|
--exec rm $MYSQLTEST_VARDIR/tmp/local.sql
|
|
|
|
|
|
|
|
|
|
DROP TABLE IF EXISTS t1, t2, t3, t04, t05, t4, t5;
|
|
|
|
|
|
2006-02-22 22:03:55 +01:00
|
|
|
|
# End of 4.1 tests
|