Browse Source

MDEV-17588 replicate-do filters cause errors when creating filtered-out tables on master with syntax unsupported on slave

Add only test case for MDEV , because MDEV-19653 already fixed the issue.
pull/1387/head
Sachin 7 years ago
parent
commit
bdc961acc7
  1. 32
      mysql-test/suite/rpl/r/mdev_17588.result
  2. 1
      mysql-test/suite/rpl/t/mdev_17588-slave.opt
  3. 39
      mysql-test/suite/rpl/t/mdev_17588.test

32
mysql-test/suite/rpl/r/mdev_17588.result

@ -0,0 +1,32 @@
include/master-slave.inc
[connection master]
create table t1 (a int) engine=innodb;
create table t2 (a int);
create table t3 (a int) engine=innodb;
include/save_master_gtid.inc
include/wait_for_slave_sql_error.inc [errno=1286]
Last_Error = 'Error 'Unknown storage engine 'innodb'' on query. Default database: 'test'. Query: 'create table t1 (a int) engine=innodb''
STOP SLAVE IO_THREAD;
include/wait_for_slave_to_stop.inc
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
include/start_slave.inc
include/sync_with_master_gtid.inc
show tables;
Tables_in_test
t2
show create table t2;
Table Create Table
t2 CREATE TABLE `t2` (
`a` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1
show create table t1;
ERROR 42S02: Table 'test.t1' doesn't exist
show create table t3;
ERROR 42S02: Table 'test.t3' doesn't exist
drop table if exists t1;
drop table if exists t2;
drop table if exists t3;
include/save_master_gtid.inc
include/sync_with_master_gtid.inc
CALL mtr.add_suppression('Slave: Unknown storage engine .* Error_code: 1286');
include/rpl_end.inc

1
mysql-test/suite/rpl/t/mdev_17588-slave.opt

@ -0,0 +1 @@
--loose-disable-innodb --replicate-ignore-table=test.t3

39
mysql-test/suite/rpl/t/mdev_17588.test

@ -0,0 +1,39 @@
--source include/master-slave.inc
--source include/have_innodb.inc
--connection master
create table t1 (a int) engine=innodb;
create table t2 (a int);
create table t3 (a int) engine=innodb;
--source include/save_master_gtid.inc
--connection slave
# Using ER_UNKNOWN_STORAGE_ENGINE wont work
let $slave_sql_errno= 1286;
--source include/wait_for_slave_sql_error.inc
--let $status_items= Last_Error
--source include/show_slave_status.inc
STOP SLAVE IO_THREAD;
source include/wait_for_slave_to_stop.inc;
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
--source include/start_slave.inc
--source include/sync_with_master_gtid.inc
show tables;
show create table t2;
--error ER_NO_SUCH_TABLE
show create table t1;
--error ER_NO_SUCH_TABLE
show create table t3;
--connection master
drop table if exists t1;
drop table if exists t2;
drop table if exists t3;
--source include/save_master_gtid.inc
--connection slave
--source include/sync_with_master_gtid.inc
CALL mtr.add_suppression('Slave: Unknown storage engine .* Error_code: 1286');
--source include/rpl_end.inc
Loading…
Cancel
Save