rpl_change_master_bind.inc 2.2 KB
Newer Older
H
hustjieke 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
#
# Test CHANGE MASTER MASTER_BIND=xxx
#
# Parameters:
#  $master_bind - the address to use for MASTER_BIND
#  $master_bind_error_expected - expect an error when using the specified
#                                master_bind address
#
#

# Stop the slave
connection slave;
source include/stop_slave.inc;

# Create table and insert one record with the bind address on master
connection master;
create table t1(n int, b varchar(256));
--replace_result $master_bind <master_bind>
eval insert into t1 values(1, $master_bind);

# Configure slave to connect to master with the give bind address
# for master_bind and master_host unless it's an invalid address
connection slave;
let $_master_host=;
if (!$master_bind_error_expected)
{
  if ($master_bind != "''")
  {
    let $_master_host=master_host=$master_bind,;
  }
}

--replace_result $master_bind <master_bind>
eval change master to $_master_host master_bind=$master_bind;
start slave;

# Check that SHOW SLAVE STATUS has Master_bind column set to $master_bind
let $master_bind_value= query_get_value(SHOW SLAVE STATUS, Master_Bind, 1);
if (`select '$master_bind_value' != $master_bind`)
{
  source include/show_rpl_debug_info.inc;
  echo 'master_bind_value: $master_bind_value' != 'master_bind: $master_bind';
  die Master_bind in SHOW SLAVE STAUS not showing configured value;
}

if ($master_bind_error_expected)
{
  # The given master bind address is not valid
  # and replication should fail
  let $slave_io_errno= $master_bind_error_expected;
  let $slave_io_error_is_nonfatal= 1;
  source include/wait_for_slave_io_error.inc;
  echo got expected error $master_bind_error_expected;
  source include/stop_slave.inc;

  # Reset the master_bind so that cleanup can run
  eval change master to master_bind='';
  start slave;

}

source include/wait_for_slave_to_start.inc;

connection master;
sync_slave_with_master;

connection slave;
let $master_bind_repl= query_get_value(select b from t1, b, 1);
if (`select '$master_bind_repl' != $master_bind`)
{
  select * from t1;
  source include/show_rpl_debug_info.inc;
  echo 'master_bind_repl: $master_bind_repl' != 'master_bind: $master_bind';
  die The replicated value to show replication working was not correct;
}

# Clean up
connection master;
drop table t1;
sync_slave_with_master;