mirror of
https://github.com/MariaDB/server.git
synced 2025-01-28 01:34:17 +01:00
d9f975d08b
Adjust full test suite to work with GTID. Huge patch, mainly due to having to update .result file for all SHOW BINLOG EVENTS and mysqlbinlog outputs, where the new GTID events pop up. Everything was painstakingly checked to be still correct and valid .result file updates.
67 lines
1.9 KiB
Text
67 lines
1.9 KiB
Text
# This test checks that a slave DOES execute queries originating
|
|
# from itself, if running with --replicate-same-server-id.
|
|
|
|
source include/master-slave.inc;
|
|
connection slave;
|
|
create table t1 (n int);
|
|
reset master;
|
|
# replicate ourselves
|
|
stop slave;
|
|
--source include/wait_for_slave_to_stop.inc
|
|
--replace_result $SLAVE_MYPORT SLAVE_PORT
|
|
eval change master to master_port=$SLAVE_MYPORT;
|
|
start slave;
|
|
--source include/wait_for_slave_to_start.inc
|
|
insert into t1 values (1);
|
|
save_master_pos;
|
|
sync_with_master;
|
|
select * from t1; # check that indeed 2 were inserted
|
|
# We stop the slave before cleaning up otherwise we'll get
|
|
# 'drop table t1' executed twice, so an error in the slave.err
|
|
# (not critical).
|
|
stop slave;
|
|
--source include/wait_for_slave_to_stop.inc
|
|
drop table t1;
|
|
|
|
|
|
#
|
|
# Bug#38934 slave slave until does not work with --replicate-same-server-id
|
|
#
|
|
# Verifying that slave performs all events until the master_log_pos
|
|
# in presense of --replicate-same-server-id the slave is started with.
|
|
|
|
connection master;
|
|
reset master;
|
|
|
|
# setting the until position to correspond to the last position of
|
|
# create table which will make the event executed and the slave sql
|
|
# thread stopped right after that.
|
|
|
|
create table t1(n int);
|
|
let $until_pos= query_get_value(SHOW MASTER STATUS, Position, 1);
|
|
dec $until_pos;
|
|
create table t2(n int);
|
|
|
|
connection slave;
|
|
--replace_result $MASTER_MYPORT MASTER_PORT
|
|
eval change master to master_port=$MASTER_MYPORT;
|
|
--replace_result $until_pos UNTIL_POS
|
|
eval start slave until master_log_file='master-bin.000001', master_log_pos=$until_pos;
|
|
--source include/wait_for_slave_io_to_start.inc
|
|
--source include/wait_for_slave_sql_to_stop.inc
|
|
|
|
--echo *** checking until position execution: must be only t1 in the list ***
|
|
show tables;
|
|
|
|
# cleanup
|
|
|
|
connection slave;
|
|
start slave sql_thread;
|
|
|
|
connection master;
|
|
drop table t1;
|
|
drop table t2;
|
|
sync_slave_with_master;
|
|
|
|
# End of tests
|
|
--source include/rpl_end.inc
|