rpl_slave_status.test 1.57 KB
Newer Older
1
--source include/master-slave.inc
2 3 4 5 6 7 8 9

############################################################################
# Test case for BUG#10780
#
# REQUIREMENT
#   A slave without replication privileges should have Slave_IO_Running = No

# 1. Create new replication user
10 11
connection master;
grant replication slave on *.* to rpl@127.0.0.1 identified by 'rpl';
12

13 14 15 16
connection slave;
stop slave;
change master to master_user='rpl',master_password='rpl';
start slave;
17 18

# 2. Do replication as new user
19 20 21
connection master;
--disable_warnings
drop table if exists t1;
22
--enable_warnings
23 24 25 26 27 28
create table t1 (n int);
insert into t1 values (1);
save_master_pos;
connection slave;
sync_with_master;
select * from t1;
29 30

# 3. Delete new replication user
31 32 33 34
connection master;
delete from mysql.user where user='rpl';
flush privileges;
connection slave;
35 36 37

# 4. Restart slave without privileges
# (slave.err will contain access denied error for this START SLAVE command)
38
stop slave;
39
source include/wait_for_slave_to_stop.inc;
40
start slave;
41 42 43
source include/wait_for_slave_sql_to_start.inc;

# 5. Make sure Slave_IO_Running = No
44
--replace_result $MASTER_MYPORT MASTER_MYPORT
45 46
# Column 1 is replaced, since the output can be either
# "Connecting to master" or "Waiting for master update"
47 48
--replace_column 1 # 7 # 8 # 9 # 22 # 23 # 35 # 36 #
query_vertical show slave status;
49

50 51 52 53
# Cleanup (Note that slave IO thread is not running)
connection slave;
drop table t1;
delete from mysql.user where user='rpl';
54 55 56
# cleanup: slave io thread has been stopped "irrecoverably"
# so we clean up mess manually

57 58 59
connection master;
drop table t1;

60
# end of 4.1 tests