config root man

Current Path : /home/usr.opt/mysql57/mysql-test/suite/rpl/t/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : //home/usr.opt/mysql57/mysql-test/suite/rpl/t/rpl_rotate_gtid.test

# ==== Purpose ====
#
# When the slave SQL thread processes transactions, it internally keeps
# track of the starting position of the current transaction. This position
# is used to rewind the position in case the SQL thread is stopped in the
# middle of a transaction, or in case the transaction is re-executed due to
# slave_transaction_retries > 0.
#
# This test verifies that the start of the transaction is correctly updated
# even if the transaction spans multiple relay logs, such that a Gtid_log_event
# is immediately followed by a Rotate_log_event.
#
# ==== Related Bugs and Worklogs ====
#
# Bug #18652178 STOP SQL_THREAD, START SQL_THREAD
#               CAUSES A TRX TO LOG WITH A DIFFERENT GTID
#
--source include/have_binlog_format_statement.inc
--source include/have_innodb.inc
--source include/have_gtid.inc
--source include/master-slave.inc
# Test should run only on debug build
source include/have_debug.inc;
source include/have_debug_sync.inc;


--echo # Preparing the relaylog
#
# Create a relaylog on slave containing a relaylog file that finishes with
# an Gtig_log_event and the rest of the group (transaction) is in the
# next relaylog file.
#
# The better way of doing this is disabling slave's auto positioning
# and using a debug point to stop the IO thread right after queuing
# the Gtid_log_event. Because auto positioning is disabled, the IO thread
# will not ask the Gtid_log_event again.
#
--source include/rpl_connection_slave.inc
--source include/stop_slave.inc
# Disabling auto positioning
CHANGE MASTER TO MASTER_AUTO_POSITION=0;
# Make sync includes to rely on position instead of GTIDs
--let $use_gtids= 0
--source include/start_slave_io.inc

# Setting the debug point to stop IO thread after queuing Gtid_log_event
SET @save_debug=@@global.debug;
SET GLOBAL DEBUG='d,stop_io_after_reading_gtid_log_event';

--echo # Create a transaction on the master
--echo # that will have it's GTID and other events in separated relay log files
--source include/rpl_connection_master.inc
CREATE TABLE t1 (c1 INT) ENGINE=InnoDB;

# Wait for IO thread to stop and restarts it to get the rest of the transaction
--source include/rpl_connection_slave.inc
--source include/wait_for_slave_io_to_stop.inc
SET GLOBAL DEBUG=@save_debug;
--source include/start_slave_io.inc

--echo # Create other transaction on the master
--source include/rpl_connection_master.inc
CREATE TABLE t2 (c1 INT) ENGINE=InnoDB;

--source include/sync_slave_io_with_master.inc

--echo # Restart the SQL thread until the beginning of the last relay log file
--source include/rpl_connection_slave.inc
# Disable warnings to avoid logging "UNTIL condtion is not supported ..." on MTS
--disable_warnings
START SLAVE SQL_THREAD UNTIL
  RELAY_LOG_FILE= 'slave-relay-bin.000003',
  RELAY_LOG_POS= 4;
--enable_warnings
--source include/wait_for_slave_sql_to_stop.inc

--echo # Restart the SQL thread
--source include/start_slave_sql.inc

--source include/rpl_connection_master.inc
--source include/sync_slave_sql_with_master.inc
# If t1 was replicated to the slave and it's original GTID was skipped
# this test will fail in the rpl_end.inc because the GTID_EXECUTED of the
# master contains a GTID that was sent to the slave (it is in
# Retrieved_Gtid_Set), but wasn't applied by the SQL thread.
--let $assert_cond= "[SHOW TABLES LIKE "t1"]" = "t1"
--let $assert_text= t1 should be replicated
--source include/assert.inc

--echo # Cleanup
--source include/rpl_connection_master.inc
DROP TABLE t1, t2;
# Make rpl_end.inc to verify GTID_EXECUTED
--let $use_gtids= 1
--source include/rpl_end.inc

Man Man