mirror of
https://github.com/MariaDB/server.git
synced 2025-01-22 06:44:16 +01:00
56290f2690
In tests waiting on a timeout is not deterministic enough to make sure that an event actually finished executing. Fixed the test by waiting in a loop and checking the effect that the event is supposed to produce.
122 lines
3.9 KiB
SQL
122 lines
3.9 KiB
SQL
##################################################################
|
|
# Author: Giuseppe, Chuck Bell #
|
|
# Date: 17-January-2007 #
|
|
# Purpose: To test that event effects are replicated #
|
|
# in both row based and statement based format #
|
|
##################################################################
|
|
|
|
--disable_warnings
|
|
DROP EVENT IF EXISTS test.justonce;
|
|
drop table if exists t1,t2;
|
|
--enable_warnings
|
|
|
|
# first, we need a table to record something from an event
|
|
|
|
eval CREATE TABLE `t1` (
|
|
`id` INT(10) UNSIGNED NOT NULL AUTO_INCREMENT,
|
|
`c` VARCHAR(50) NOT NULL,
|
|
`ts` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
|
PRIMARY KEY (`id`)
|
|
) ENGINE=$engine_type DEFAULT CHARSET=utf8;
|
|
|
|
INSERT INTO t1 (c) VALUES ('manually');
|
|
|
|
# then, we create the event
|
|
CREATE EVENT test.justonce ON SCHEDULE AT NOW() + INTERVAL 2 SECOND DO INSERT INTO t1
|
|
(c) VALUES ('from justonce');
|
|
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test' AND name = 'justonce';
|
|
|
|
# wait 3 seconds, so the event can trigger
|
|
--real_sleep 3
|
|
let $wait_condition=
|
|
SELECT count(*) = 1 FROM t1 WHERE c = 'from justonce';
|
|
--source include/wait_condition.inc
|
|
|
|
# check that table t1 contains something
|
|
--echo "in the master"
|
|
--enable_info
|
|
--replace_column 3 TIMESTAMP
|
|
SELECT * FROM t1 WHERE c = 'from justonce' OR c = 'manually' ORDER BY id;
|
|
--disable_info
|
|
|
|
sync_slave_with_master;
|
|
|
|
--echo "in the slave"
|
|
--enable_info
|
|
--replace_column 3 TIMESTAMP
|
|
SELECT * FROM t1 WHERE c = 'from justonce' OR c = 'manually' ORDER BY id;
|
|
--disable_info
|
|
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test' AND name = 'justonce';
|
|
|
|
# Create an event on the slave and check to see what the originator is.
|
|
--disable_warnings
|
|
DROP EVENT IF EXISTS test.slave_once;
|
|
--enable_warnings
|
|
|
|
CREATE EVENT test.slave_once ON SCHEDULE EVERY 5 MINUTE DO
|
|
INSERT INTO t1(c) VALUES ('from slave_once');
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test' AND name = 'slave_once';
|
|
|
|
--disable_warnings
|
|
DROP EVENT IF EXISTS test.slave_once;
|
|
--enable_warnings
|
|
|
|
connection master;
|
|
|
|
# BUG#20384 - disable events on slave
|
|
--disable_warnings
|
|
DROP EVENT IF EXISTS test.justonce;
|
|
--enable_warnings
|
|
|
|
CREATE EVENT test.er ON SCHEDULE EVERY 3 SECOND DO
|
|
INSERT INTO t1(c) VALUES ('from er');
|
|
SELECT db, name, status, originator, body FROM mysql.event WHERE db = 'test' AND name = 'er';
|
|
|
|
sync_slave_with_master;
|
|
|
|
--echo "in the slave"
|
|
SELECT db, name, status, originator, body FROM mysql.event WHERE db = 'test' AND name = 'er';
|
|
|
|
connection master;
|
|
--echo "in the master"
|
|
ALTER EVENT test.er ON SCHEDULE EVERY 5 SECOND DO INSERT into t1(c) VALUES ('from alter er');
|
|
SELECT db, name, status, originator, body FROM mysql.event WHERE db = 'test' AND name = 'er';
|
|
|
|
sync_slave_with_master;
|
|
|
|
--echo "in the slave"
|
|
SELECT db, name, status, originator, body FROM mysql.event WHERE db = 'test' AND name = 'er';
|
|
|
|
connection master;
|
|
--echo "in the master"
|
|
DROP EVENT test.er;
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test';
|
|
|
|
--disable_info
|
|
|
|
sync_slave_with_master;
|
|
|
|
--echo "in the slave"
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test';
|
|
|
|
# test the DISABLE ON SLAVE for setting event SLAVESIDE_DISABLED as status
|
|
# on CREATE EVENT
|
|
|
|
CREATE EVENT test.slave_terminate ON SCHEDULE EVERY 3 SECOND
|
|
DO INSERT INTO t1(c) VALUES ('from slave_terminate');
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test' AND name = 'slave_terminate';
|
|
|
|
DROP EVENT test.slave_terminate;
|
|
|
|
CREATE EVENT test.slave_terminate ON SCHEDULE EVERY 3 SECOND
|
|
DISABLE ON SLAVE DO INSERT INTO t1(c) VALUES ('from slave_terminate');
|
|
SELECT db, name, status, originator FROM mysql.event WHERE db = 'test' AND name = 'slave_terminate';
|
|
|
|
DROP EVENT test.slave_terminate;
|
|
|
|
--echo "in the master"
|
|
connection master;
|
|
DROP TABLE t1;
|
|
|