2003-01-14 11:27:26 +02:00
# See if replication of a "LOAD DATA in an autoincrement column"
# Honours autoincrement values
# i.e. if the master and slave have the same sequence
2003-04-03 12:54:08 -04:00
#
2003-08-11 22:44:43 +03:00
# check replication of load data for temporary tables with additional
# parameters
2003-04-03 12:54:08 -04:00
#
2003-06-03 15:47:29 +02:00
# check if duplicate entries trigger an error (they should unless IGNORE or
# REPLACE was used on the master) (bug 571).
2003-08-04 10:59:44 +02:00
#
# check if START SLAVE, RESET SLAVE, CHANGE MASTER reset Last_slave_error and
2003-08-11 22:44:43 +03:00
# Last_slave_errno in SHOW SLAVE STATUS (1st and 3rd commands did not: bug 986)
2003-06-03 15:47:29 +02:00
2003-01-14 11:27:26 +02:00
source include/master-slave.inc;
2003-08-20 23:24:45 +02:00
connection slave;
reset master;
connection master;
2003-01-14 11:27:26 +02:00
create table t1(a int not null auto_increment, b int, primary key(a) );
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata.dat' into table t1;
2003-04-03 12:54:08 -04:00
create temporary table t2 (day date,id int(9),category enum('a','b','c'),name varchar(60));
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata2.dat' into table t2 fields terminated by ',' optionally enclosed by '%' escaped by '@' lines terminated by '\n##\n' starting by '>' ignore 1 lines;
2003-04-03 12:54:08 -04:00
create table t3 (day date,id int(9),category enum('a','b','c'),name varchar(60));
insert into t3 select * from t2;
2003-01-14 11:27:26 +02:00
save_master_pos;
connection slave;
sync_with_master;
2003-04-03 12:54:08 -04:00
select * from t1;
select * from t3;
2003-08-20 23:24:45 +02:00
# We want to be sure that LOAD DATA is in the slave's binlog.
2 minor edits, plus
fix for BUG#1113 "INSERT into non-trans table SELECT ; ROLLBACK" does not send warning"
and
fix for BUG#873 "In transaction, INSERT to non-trans table is written too early to binlog".
Now we don't always write the non-trans update immediately to the binlog;
if there is something in the binlog cache we write it to the binlog cache
(because the non-trans update could depend on a trans table which was modified
earlier in the transaction); then in case of ROLLBACK, we write the binlog
cache to the binlog, wrapped with BEGIN/ROLLBACK.
This guarantees that the slave does the same updates.
For ROLLBACK TO SAVEPOINT: when we execute a SAVEPOINT command we write it
to the binlog cache. At ROLLBACK TO SAVEPOINT, if some non-trans table was updated,
we write ROLLBACK TO SAVEPOINT to the binlog cache; when the transaction
terminates (COMMIT/ROLLBACK), the binlog cache will be flushed to the binlog
(because of the non-trans update) so we'll have SAVEPOINT and ROLLBACK TO
SAVEPOINT in the binlog.
Apart from this rare case of updates of mixed table types in transaction, the
usual way is still clear the binlog cache at ROLLBACK, or chop it at
ROLLBACK TO SAVEPOINT (meaning the SAVEPOINT command is also chopped, which
is fine).
Note that BUG#873 encompasses subbugs 1) and 2) of BUG#333 "3 binlogging bugs when doing INSERT with mixed InnoDB/MyISAM".
2003-08-22 15:39:24 +02:00
# But we can't simply read this binlog, because as the slave has not been
# restarted for this test, the file_id is uncertain (would cause test
# failures). So instead, we test if the binlog looks long enough to
2005-03-16 04:32:47 +03:00
# contain LOAD DATA. Since 5.0.3 we assume that binlog of 1292 is ok.
2 minor edits, plus
fix for BUG#1113 "INSERT into non-trans table SELECT ; ROLLBACK" does not send warning"
and
fix for BUG#873 "In transaction, INSERT to non-trans table is written too early to binlog".
Now we don't always write the non-trans update immediately to the binlog;
if there is something in the binlog cache we write it to the binlog cache
(because the non-trans update could depend on a trans table which was modified
earlier in the transaction); then in case of ROLLBACK, we write the binlog
cache to the binlog, wrapped with BEGIN/ROLLBACK.
This guarantees that the slave does the same updates.
For ROLLBACK TO SAVEPOINT: when we execute a SAVEPOINT command we write it
to the binlog cache. At ROLLBACK TO SAVEPOINT, if some non-trans table was updated,
we write ROLLBACK TO SAVEPOINT to the binlog cache; when the transaction
terminates (COMMIT/ROLLBACK), the binlog cache will be flushed to the binlog
(because of the non-trans update) so we'll have SAVEPOINT and ROLLBACK TO
SAVEPOINT in the binlog.
Apart from this rare case of updates of mixed table types in transaction, the
usual way is still clear the binlog cache at ROLLBACK, or chop it at
ROLLBACK TO SAVEPOINT (meaning the SAVEPOINT command is also chopped, which
is fine).
Note that BUG#873 encompasses subbugs 1) and 2) of BUG#333 "3 binlogging bugs when doing INSERT with mixed InnoDB/MyISAM".
2003-08-22 15:39:24 +02:00
# If LOAD DATA was not logged, the binlog would be shorter.
show master status;
2003-04-03 12:54:08 -04:00
2003-01-14 11:27:26 +02:00
connection master;
2003-04-03 12:54:08 -04:00
2003-01-14 11:27:26 +02:00
drop table t1;
2003-04-03 12:54:08 -04:00
drop table t2;
drop table t3;
2003-06-03 15:47:29 +02:00
create table t1(a int, b int, unique(b));
2003-04-03 12:54:08 -04:00
2003-01-14 11:27:26 +02:00
save_master_pos;
connection slave;
sync_with_master;
2003-08-20 23:24:45 +02:00
# See if slave stops when there's a duplicate entry for key error in LOAD DATA
2003-06-03 15:47:29 +02:00
insert into t1 values(1,10);
connection master;
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata.dat' into table t1;
2003-06-03 15:47:29 +02:00
save_master_pos;
connection slave;
2003-06-16 15:49:54 +02:00
# The SQL slave thread should be stopped now.
wait_for_slave_to_stop;
2003-08-04 10:59:44 +02:00
# Skip the bad event and see if error is cleared in SHOW SLAVE STATUS by START
# SLAVE, even though we are not executing any event (as sql_slave_skip_counter
# takes us directly to the end of the relay log).
2003-06-03 15:47:29 +02:00
2003-08-04 10:59:44 +02:00
set global sql_slave_skip_counter=1;
start slave;
sync_with_master;
--replace_result $MASTER_MYPORT MASTER_PORT
2003-12-19 22:40:23 +01:00
--replace_column 1 # 8 # 9 # 23 # 33 #
2003-08-04 10:59:44 +02:00
show slave status;
2003-07-23 16:48:45 +02:00
2003-08-04 10:59:44 +02:00
# Trigger error again to test CHANGE MASTER
2003-07-23 16:48:45 +02:00
2003-08-04 10:59:44 +02:00
connection master;
set sql_log_bin=0;
delete from t1;
set sql_log_bin=1;
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata.dat' into table t1;
2003-08-04 10:59:44 +02:00
save_master_pos;
connection slave;
2005-03-16 04:32:47 +03:00
# The SQL slave thread should be stopped now.
# Exec_Master_Log_Pos should point to the start of Execute event
# for last load data.
2003-08-04 10:59:44 +02:00
wait_for_slave_to_stop;
# CHANGE MASTER and see if error is cleared in SHOW SLAVE STATUS.
stop slave;
change master to master_user='test';
change master to master_user='root';
--replace_result $MASTER_MYPORT MASTER_PORT
2003-12-19 22:40:23 +01:00
--replace_column 1 # 8 # 9 # 23 # 33 #
2003-08-04 10:59:44 +02:00
show slave status;
# Trigger error again to test RESET SLAVE
set global sql_slave_skip_counter=1;
start slave;
sync_with_master;
connection master;
set sql_log_bin=0;
delete from t1;
set sql_log_bin=1;
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata.dat' into table t1;
2003-08-04 10:59:44 +02:00
save_master_pos;
connection slave;
# The SQL slave thread should be stopped now.
wait_for_slave_to_stop;
# RESET SLAVE and see if error is cleared in SHOW SLAVE STATUS.
stop slave;
reset slave;
--replace_result $MASTER_MYPORT MASTER_PORT
2003-12-19 22:40:23 +01:00
--replace_column 1 # 8 # 9 # 23 # 33 #
2003-08-04 10:59:44 +02:00
show slave status;
2003-09-25 00:14:46 +02:00
# Finally, see if logging is done ok on master for a failing LOAD DATA INFILE
connection master;
reset master;
create table t2 (day date,id int(9),category enum('a','b','c'),name varchar(60),
2005-03-25 14:51:17 +01:00
unique(day)) engine=MyISAM; # no transactions
2005-08-31 17:16:05 +02:00
--error 1062
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata2.dat' into table t2 fields
2003-09-25 00:14:46 +02:00
terminated by ',' optionally enclosed by '%' escaped by '@' lines terminated by
'\n##\n' starting by '>' ignore 1 lines;
2005-03-25 14:51:17 +01:00
select * from t2;
save_master_pos;
connection slave;
start slave;
sync_with_master;
select * from t2;
# verify that if no error on slave, this is an error
alter table t2 drop key day;
connection master;
delete from t2;
2005-09-01 17:01:23 +02:00
--error 1062
2006-01-24 08:30:54 +01:00
load data infile '../std_data_ln/rpl_loaddata2.dat' into table t2 fields
2005-03-25 14:51:17 +01:00
terminated by ',' optionally enclosed by '%' escaped by '@' lines terminated by
'\n##\n' starting by '>' ignore 1 lines;
connection slave;
wait_for_slave_to_stop;
drop table t2;
connection master;
2003-09-25 00:14:46 +02:00
drop table t2;
2006-01-26 17:54:34 +01:00
drop table t1;
sync_with_master;
2005-07-28 03:22:47 +03:00
# End of 4.1 tests