# This test checks that a slave DOES execute queries originating # from itself, if running with --replicate-same-server-id. source include/not_gtid_enabled.inc; 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 first following 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 --disable_warnings eval start slave until master_log_file='master-bin.000001', master_log_pos=$until_pos; --enable_warnings --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; --source include/sync_slave_sql_with_master.inc # End of tests --source include/rpl_end.inc