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_sbm_previous_gtid_event.test

###############################################################################
# Bug #18622657 SECONDS_BEHIND_MASTER DISTORTED BECAUSE OF
# PREVIOUS_GTID EVENT
# Problem: Previous gtid log event in relay log should not be contributed to
#  seconds behind master calculation.
# Steps to reproduce:
#  1) Try all 6 different possible rotations (new relay log files)
#  2) Execute SBM after every previous_gtid_log_event execution from each
#     log file and make sure that timestamp is not considered for SBM
#     calculation.
###############################################################################
--source include/have_debug_sync.inc
--source include/have_gtid.inc
--let $rpl_skip_start_slave= 1
--source include/master-slave.inc
--source include/have_binlog_format_statement.inc

# Set sync debug point to calculate sbm exactly after every
#  previous_gtid_log_event.
--connection slave
SET @save_global_debug=@@GLOBAL.DEBUG;
SET @@GLOBAL.DEBUG= '+d,dbug.calculate_sbm_after_previous_gtid_log_event';

# To avoid warning MTS
SET @saved_slave_transaction_retries=@@global.slave_transaction_retries;
SET @@global.slave_transaction_retries=0;
# Previous gtid log events are generated at the time of
#  relay log is rotated and will be written at the top
#  of the relay log. There are few ways in which
#  relay log gets rotated. Lets find out SBM after
#  Previous_gtid_log_event execution in all those
#  of relay logs

# Case-1 :At the time of server started, a new relaylog
#  slave-relay-bin.000001
--connection slave
--let $slave_datadir=`select @@datadir`

# Case-2 : Start IO thread , relay log will be rotated to
#  slave-relay-bin.000002
--source include/start_slave_io.inc

# Case-3 : Restart IO thread, relay log will be rotated to
#  slave-relay-bin.000003
--source include/stop_slave_io.inc
--source include/start_slave_io.inc

# Case-4 Lets put (more than) 4096 data in binary log and when it
#  reaches slave, relaylog will be rotated (please relay-log-file-size
#  is set to in .opt file) to slave-relay-bin.000004/
--connection master
CREATE TABLE t1(i INT);
--let $i=20
while ($i > 1)
{
eval INSERT INTO t1 VALUES ($i);
dec $i;
}
DROP TABLE t1;

# Case-5 (FLUSH LOGS on slave will rotate to relaylog
#  slave-relay-bin.000005)
--connection slave
FLUSH LOGS;

# Case-6 (FLUSH LOGS on master will reach slave and relaylog will be rotated
# at slave, generating two new slave bins slave-relay-bin.000006,
# slave-relay-bin.000007)
--connection master
FLUSH LOGS;
--source include/sync_slave_io_with_master.inc

#####################################
#                                   #
#    Actual testing starts here.    #
#                                   #
#####################################

# Let SQL thread read and execute all 7 slave-relay-bin's
#  previous_gtid_log_events and SBM cannot be greater or equal to
#  $idle seconds.
--source include/start_slave_sql.inc

# Just to fake that I/O thread started 3 mints ago,
#  the server changes the I/O thread start time to
#  now() - 180 seconds (3 mints ago) instead of now()
#  using debug point 'calculate_sbm_after_previous_gtid_log_event'.
#  But that 3 mints delay should not be seen when
#  some one asks for SBM after Previous_gtid_log_event and
#  this test script try to test that below.
--let $idle=180

--let $i=0
while ($i < 7)
{
SET DEBUG_SYNC="now wait_for signal.reached";

# Calcualte SBM
let $sbm= query_get_value("SHOW SLAVE STATUS", Seconds_Behind_Master, 1);
--let $assert_text= Seconds Behind Master should be less than $idle seconds.
--let $assert_cond= $sbm < $idle
--source include/assert.inc

SET DEBUG_SYNC="now signal signal.done_sbm_calculation";
--inc $i
}

# Cleanup
SET @@GLOBAL.DEBUG=@save_global_debug;
SET @@global.slave_transaction_retries=@saved_slave_transaction_retries;
--source include/rpl_end.inc

Man Man