mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
BUG#31552 (Replication breaks when deleting rows from out-of-sync table without PK):
Pushing test case for bug only. Bug already fixed as a result of the patch for BUG#19958.
This commit is contained in:
@ -215,11 +215,36 @@ sync_slave_with_master;
|
|||||||
--echo --- on slave ---
|
--echo --- on slave ---
|
||||||
SELECT * FROM t8 ORDER BY a;
|
SELECT * FROM t8 ORDER BY a;
|
||||||
|
|
||||||
#
|
# BUG#31552: Replication breaks when deleting rows from out-of-sync
|
||||||
# Test conflicting operations when changing in a table referenced by a
|
# table without PK
|
||||||
# foreign key. We'll reuse the above table and just add a table that
|
|
||||||
# references it.
|
--echo **** Test for BUG#31552 ****
|
||||||
#
|
|
||||||
|
--echo **** On Master ****
|
||||||
|
# Clean up t1 so that we can use it.
|
||||||
|
connection master;
|
||||||
|
DELETE FROM t1;
|
||||||
|
sync_slave_with_master;
|
||||||
|
|
||||||
|
# Just to get a clean binary log
|
||||||
|
source include/reset_master_and_slave.inc;
|
||||||
|
|
||||||
|
--echo **** On Master ****
|
||||||
|
connection master;
|
||||||
|
INSERT INTO t1 VALUES ('K','K'), ('L','L'), ('M','M');
|
||||||
|
--echo **** On Master ****
|
||||||
|
sync_slave_with_master;
|
||||||
|
DELETE FROM t1 WHERE C1 = 'L';
|
||||||
|
|
||||||
|
connection master;
|
||||||
|
DELETE FROM t1;
|
||||||
|
query_vertical SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
sync_slave_with_master;
|
||||||
|
let $last_error = query_get_value("SHOW SLAVE STATUS", Last_SQL_Errno, 1);
|
||||||
|
disable_query_log;
|
||||||
|
eval SELECT "$last_error" AS Last_SQL_Error;
|
||||||
|
enable_query_log;
|
||||||
|
query_vertical SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
|
||||||
#
|
#
|
||||||
# cleanup
|
# cleanup
|
||||||
@ -227,3 +252,4 @@ SELECT * FROM t8 ORDER BY a;
|
|||||||
|
|
||||||
connection master;
|
connection master;
|
||||||
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
||||||
|
sync_slave_with_master;
|
||||||
|
@ -415,4 +415,23 @@ a b c
|
|||||||
2 4 8
|
2 4 8
|
||||||
3 6 9
|
3 6 9
|
||||||
99 99 99
|
99 99 99
|
||||||
|
**** Test for BUG#31552 ****
|
||||||
|
**** On Master ****
|
||||||
|
DELETE FROM t1;
|
||||||
|
**** Resetting master and slave ****
|
||||||
|
STOP SLAVE;
|
||||||
|
RESET SLAVE;
|
||||||
|
RESET MASTER;
|
||||||
|
START SLAVE;
|
||||||
|
**** On Master ****
|
||||||
|
INSERT INTO t1 VALUES ('K','K'), ('L','L'), ('M','M');
|
||||||
|
**** On Master ****
|
||||||
|
DELETE FROM t1 WHERE C1 = 'L';
|
||||||
|
DELETE FROM t1;
|
||||||
|
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
COUNT(*) 0
|
||||||
|
Last_SQL_Error
|
||||||
|
0
|
||||||
|
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
COUNT(*) 0
|
||||||
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
||||||
|
@ -415,4 +415,23 @@ a b c
|
|||||||
2 4 8
|
2 4 8
|
||||||
3 6 9
|
3 6 9
|
||||||
99 99 99
|
99 99 99
|
||||||
|
**** Test for BUG#31552 ****
|
||||||
|
**** On Master ****
|
||||||
|
DELETE FROM t1;
|
||||||
|
**** Resetting master and slave ****
|
||||||
|
STOP SLAVE;
|
||||||
|
RESET SLAVE;
|
||||||
|
RESET MASTER;
|
||||||
|
START SLAVE;
|
||||||
|
**** On Master ****
|
||||||
|
INSERT INTO t1 VALUES ('K','K'), ('L','L'), ('M','M');
|
||||||
|
**** On Master ****
|
||||||
|
DELETE FROM t1 WHERE C1 = 'L';
|
||||||
|
DELETE FROM t1;
|
||||||
|
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
COUNT(*) 0
|
||||||
|
Last_SQL_Error
|
||||||
|
0
|
||||||
|
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
COUNT(*) 0
|
||||||
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
||||||
|
@ -415,4 +415,23 @@ a b c
|
|||||||
2 4 8
|
2 4 8
|
||||||
3 6 9
|
3 6 9
|
||||||
99 99 99
|
99 99 99
|
||||||
|
**** Test for BUG#31552 ****
|
||||||
|
**** On Master ****
|
||||||
|
DELETE FROM t1;
|
||||||
|
**** Resetting master and slave ****
|
||||||
|
STOP SLAVE;
|
||||||
|
RESET SLAVE;
|
||||||
|
RESET MASTER;
|
||||||
|
START SLAVE;
|
||||||
|
**** On Master ****
|
||||||
|
INSERT INTO t1 VALUES ('K','K'), ('L','L'), ('M','M');
|
||||||
|
**** On Master ****
|
||||||
|
DELETE FROM t1 WHERE C1 = 'L';
|
||||||
|
DELETE FROM t1;
|
||||||
|
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
COUNT(*) 0
|
||||||
|
Last_SQL_Error
|
||||||
|
0
|
||||||
|
SELECT COUNT(*) FROM t1 ORDER BY c1,c2;
|
||||||
|
COUNT(*) 0
|
||||||
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
DROP TABLE IF EXISTS t1,t2,t3,t4,t5,t6,t7,t8;
|
||||||
|
Reference in New Issue
Block a user