~ubuntu-branches/ubuntu/trusty/mysql-5.6/trusty

« back to all changes in this revision

Viewing changes to mysql-test/suite/large_tests/t/rpl_slave_net_timeout.test

  • Committer: Package Import Robot
  • Author(s): James Page
  • Date: 2014-02-12 11:54:27 UTC
  • Revision ID: package-import@ubuntu.com-20140212115427-oq6tfsqxl1wuwehi
Tags: upstream-5.6.15
ImportĀ upstreamĀ versionĀ 5.6.15

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#
 
2
#  Testing reconnecting by slave as specified by `slave_net_timeout'
 
3
#
 
4
#  Bug #50296 Slave reconnects earlier than the prescribed slave_net_timeout value
 
5
#
 
6
--source include/have_csv.inc
 
7
--source include/master-slave.inc
 
8
 
 
9
 
 
10
# save global env
 
11
connection master;
 
12
set @save_general_log = @@global.general_log;
 
13
set @save_log_output = @@global.log_output;
 
14
 
 
15
connection slave;
 
16
set @save_slave_net_timeout = @@global.slave_net_timeout;
 
17
 
 
18
connection master;
 
19
set @@global.general_log = ON;
 
20
set @@global.log_output = 'table,file';
 
21
 
 
22
connection slave;
 
23
--source include/stop_slave.inc
 
24
#
 
25
# if heartbeat is disabled then reconnecting to the idle master
 
26
# should happen with `slave_net_timeout' period.
 
27
# Since it's the real time that is measured, `slave_net_timeout'
 
28
# merely guarantees that reconnecting can *not* happen earlier of a value specified.
 
29
# That is there can't an exact estimate for how many time it will happen.
 
30
#
 
31
# The following lines verify that having idle master
 
32
# for more than 2 * slave_net_timeout seconds and
 
33
# slave.net_read_timeout < slave_net_timeout
 
34
# won't cause reconnecting by the slave within at least
 
35
# slave_net_timeout interval.
 
36
#
 
37
--replace_result $MASTER_MYPORT MASTER_PORT
 
38
--replace_column 2 ####
 
39
eval change master to master_host = '127.0.0.1',master_port = $MASTER_MYPORT,
 
40
master_user = 'root', master_heartbeat_period = 0;
 
41
 
 
42
set @@global.slave_net_timeout = @@global.net_read_timeout * 2;
 
43
let $idle_time=`select @@global.slave_net_timeout * 2`;
 
44
 
 
45
let $slave_net_timeout = `select @@global.slave_net_timeout`;
 
46
 
 
47
--source include/start_slave.inc
 
48
 
 
49
--disable_query_log
 
50
--disable_result_log
 
51
eval select 'master is idle for ', sleep($idle_time);
 
52
--enable_result_log
 
53
--enable_query_log
 
54
 
 
55
# querying general-log
 
56
 
 
57
connection master;
 
58
 
 
59
# In particular the last reconnection timestamp must be greater or equal to
 
60
# the previous one + slave_net_timeout
 
61
 
 
62
--let $ts_last= `select time_to_sec(event_time) from (select event_time from mysql.general_log as t_1 where command_type like 'Connect' order by event_time desc limit 2) as t_2 order by event_time desc limit 1`
 
63
--let $ts_prev= `select time_to_sec(event_time) from (select event_time from mysql.general_log as t_1 where command_type like 'Connect' order by event_time desc limit 2) as t_2 order by event_time asc limit 1`
 
64
 
 
65
--let $timeout= $idle_time + 10
 
66
while ($timeout)
 
67
{
 
68
  --let $ts_last= `select time_to_sec(event_time) from (select event_time from mysql.general_log as t_1 where command_type like 'Connect' order by event_time desc limit 2) as t_2 order by event_time desc limit 1`
 
69
  --let $ts_flag= `select $ts_last-$ts_prev>=$slave_net_timeout`
 
70
  if($ts_flag)
 
71
  {
 
72
     --let $timeout=1
 
73
  }
 
74
  --dec $timeout
 
75
  --sleep 1
 
76
}
 
77
 
 
78
--let $assert_cond= $ts_flag=1
 
79
--let $assert_text= time between last reconnection and the reconnection before that should be >= slave_net_timeout
 
80
--source include/assert.inc
 
81
 
 
82
# cleanup
 
83
 
 
84
# restore global env
 
85
connection master;
 
86
set @@global.general_log = @save_general_log;
 
87
set @@global.log_output = @save_log_output;
 
88
connection slave;
 
89
set @@global.slave_net_timeout = @save_slave_net_timeout;
 
90
 
 
91
--source include/rpl_end.inc