config root man

Current Path : /compat/linux/proc/self/root/usr/opt/mysql57/mysql-test/suite/rpl/t/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : //compat/linux/proc/self/root/usr/opt/mysql57/mysql-test/suite/rpl/t/transactional_ddl_locking.test

################# t/transactional_ddl_locking.test ###################
#                                                                    #
# Tests ensure that concurrent DDL operations should not be allowed  #
# on the table that are already in use inside an active transaction. #
#                                                                    #
# In order to ensure serialization in binary log we will need full   #
# mirrored replication setup and master and slave will contain the   #
# same schema/database structure.                                    #
#                                                                    #
# Contents of slave and master should be the same ie result sets are #
# correct and slave does not fail with any error like row not found. #
#                                                                    #
# Creation:                                                          #
# 2012-10-08 shipjain Implement this test as a part of WL4986        #
#                     Transactional DDL locking                      #
#                                                                    #
######################################################################

--source include/not_gtid_enabled.inc
--source include/big_test.inc
--source include/have_log_bin.inc
--source include/master-slave.inc
--source include/have_myisam.inc

--echo # Prepare playground for test by creating tables

CREATE TABLE t1 (a INT) ;
CREATE TABLE t2 (a INT, b INT);
CREATE TABLE t3 (a INT);
CREATE TABLE t4 (a INT);
CREATE TABLE t1part (id INT, year_col INT);
CREATE TABLE t2part (id INT, year_col INT)
        PARTITION BY RANGE (year_col) (
        PARTITION p0 VALUES LESS THAN (1991),
        PARTITION p1 VALUES LESS THAN (1995),
        PARTITION p2 VALUES LESS THAN (2013));
CREATE TABLE t3part (id INT, year_col INT)
PARTITION BY HASH(year_col)
PARTITIONS 4;
CREATE TABLE t4part (id INT, year_col INT)
        PARTITION BY RANGE (year_col) (
        PARTITION p0 VALUES LESS THAN (1970),
        PARTITION p1 VALUES LESS THAN (1995),
        PARTITION p2 VALUES LESS THAN (2013));
CREATE TABLE t1prim (a INT, b INT PRIMARY KEY);
CREATE TABLE t1opt (id INT , content TEXT, author_id INT,
                    article_title VARCHAR(120), article_hash INT);
CREATE TABLE t1bin (c INT);
CREATE TABLE t2bin SELECT * FROM t1bin;
CREATE TABLE t1myisam (c INT) ENGINE = MYISAM;
CREATE TABLE t1innodb (c INT) ENGINE = INNODB;
CREATE TABLE t3967_1 (id INT(11) NOT NULL AUTO_INCREMENT,
                      b INT(11) DEFAULT NULL, PRIMARY KEY (id))
                      ENGINE = INNODB;
CREATE TABLE t3967_2 (id INT(11) NOT NULL AUTO_INCREMENT,
                      b INT(11) DEFAULT NULL, PRIMARY KEY (id))
                      ENGINE = INNODB;
CREATE TABLE `t1_30138` (id INT) ENGINE = INNODB;
COMMIT;

connect (master2,localhost,root,,);
connect (master3,localhost,root,,);

# Concurrent execution of DROP TABLE and INSERT inside an active transaction.

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;

--echo send statement and reap result later ---
--send DROP TABLE t1;

--echo --- connection master2 ---
connection master2;
let $lock_status= `SELECT COUNT(*) = 1 FROM information_schema.processlist
                   WHERE state = 'Waiting for TABLE metadata lock'
                   AND info = 'DROP TABLE t1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous ---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE RENAME TO and INSERT inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 RENAME TO t1new;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 RENAME TO t1new'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;

--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE DROP COLUMN and INSERT inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t2 VALUES (1,1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2 DROP COLUMN a;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2 DROP COLUMN a'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2 ;

--let $diff_tables= master:t2, slave:t2
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE ADD COLUMN and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
UPDATE t1 SET a = 2;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 ADD COLUMN b INT;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 ADD COLUMN b INT'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of RENAME TABLE and INSERT inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send RENAME TABLE t1 to t2new;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'RENAME TABLE t1 to t2new'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE ADD COMMENT and INSERT inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 MODIFY a bigINT COMMENT 'first';

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 MODIFY a bigINT COMMENT \'first\''`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

connection master;
COMMIT;
--sync_slave_with_master

connection slave;
SELECT COUNT(*) FROM t1 ;
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE ADD CONSTRAINT and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
UPDATE t1 SET a = 1;

--echo --- connection master1 --
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 ADD PRIMARY KEY (a);

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 ADD PRIMARY Key (a)'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE ADD CONSTRAINT and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
UPDATE t1 SET a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 ADD FOREIGN KEY (a) REFERENCES t2 (a) ;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 ADD FOREIGN KEY (a) REFERENCES t2 (a) '`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE ALTER COLUMN and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
UPDATE t1 SET a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 ALTER a SET DEFAULT 1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 ALTER a SET DEFAULT 1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE CHANGE COLUMN and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
BEGIN;
UPDATE t1 SET a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 CHANGE a b smallINT;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 CHANGE a b smallINT'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE MODIFY COLUMN and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
INSERT INTO t1 VALUES(1);
BEGIN;
UPDATE t1 SET a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 MODIFY a INTEGER;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 MODIFY a INTEGER'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master


--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE DROP PRIMARY KEY and UPDATE inside an active transaction

--echo --- connection master ---
connection master;
INSERT INTO t1prim VALUES (1,1);
INSERT INTO t1prim VALUES (2,2);
COMMIT;
BEGIN;
UPDATE t1prim SET b = 4 WHERE a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1prim DROP PRIMARY KEY;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1prim DROP PRIMARY KEY'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1prim ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1prim ;

--let $diff_tables= master:t1prim, slave:t1prim
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE DISABLE KEY and UPDATE inside an active transaction

--echo --- connection master ---
connection master;

BEGIN;
UPDATE t1 SET a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 disable KEYS;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 disable KEYS'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of ALTER TABLE PARTITION BY and INSERT inside an active transaction

--echo --- connection master ---
connection master;
INSERT INTO t1part VALUES(1, '1998');
INSERT INTO t1part VALUES(2, '2012');

BEGIN;
INSERT INTO t1part SELECT * FROM t1part;
--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1part PARTITION BY HASH(id) PARTITIONS 2 ;

--echo --- connection master2 ---
connection master2;
let $lock_status= `SELECT COUNT(*) = 1 FROM information_schema.processlist
                   WHERE state = 'Waiting for TABLE metadata lock'
                   AND info = 'ALTER TABLE t1part PARTITION BY HASH(id) PARTITIONS 2'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1part;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1part;

--let $diff_tables= master:t1part, slave:t1part
--source include/diff_tables.inc


# Concurrent execution of INSERT and ALTER TABLE ADD PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (1, '1988');
BEGIN;
INSERT INTO t2part VALUES (2, '1998');

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part ADD PARTITION (PARTITION p3 VALUES LESS THAN (2015));

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part ADD PARTITION (PARTITION p3 VALUES LESS THAN (2015))'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc


# Concurrent execution of INSERT and ALTER TABLE DROP PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (1, '1912');
BEGIN;
INSERT INTO t2part VALUES (2, '1978');
--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part Drop PARTITION p1 ;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part Drop PARTITION p1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc

# Concurrent execution of INSERT and ALTER TABLE COALESCE PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t3part VALUES (1, '1902');
BEGIN;
INSERT INTO t3part VALUES (2, '1965');

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t3part COALESCE PARTITION 2 ;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t3part COALESCE PARTITION 2'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t3part;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t3part;

--let $diff_tables= master:t3part, slave:t3part
--source include/diff_tables.inc


# Concurrent execution of INSERT on a partitioned table and REORGANIZE PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t4part VALUES (1, '1932');
--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t4part VALUES (2, '1998');

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t4part REORGANIZE PARTITION p0,p1 INTO (PARTITION s0 VALUES LESS THAN (1995));

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t4part
		    REORGANIZE PARTITION p0 INTO (PARTITION s0 VALUES LESS THAN (1960),
                    PARTITION s1 VALUES LESS THAN (1970))'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t4part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t4part ;

--let $diff_tables= master:t4part, slave:t4part
--source include/diff_tables.inc


# Concurrent execution of INSERT and ALTER TABLE ANALYSE/CHECK PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (3, '1892');
--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t2part VALUES (4, '2012');
--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part CHECK PARTITION ALL;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part CHECK PARTITION ALL'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master


--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part ;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc


# Concurrent execution of INSERT and ALTER TABLE ANALYSE PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (5, '1975');
BEGIN;
INSERT INTO t2part VALUES (6, '1980');
--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part CHECK PARTITION ALL;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part ANALYSE PARTITION ALL'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part ;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc


# Concurrent execution of INSERT and ALTER TABLE OPTIMIZE PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (7, '1912');
BEGIN;
INSERT INTO t2part VALUES (8, '1998');
--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part OPTIMIZE PARTITION ALL;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part OPTIMIZE PARTITION ALL'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master


--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part ;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc

# Concurrent execution of INSERT and ALTER TABLE REBUILD PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (9, '2011');
BEGIN;
INSERT INTO t2part VALUES (10, '1982');

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part REBUILD PARTITION ALL;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part REBUILD PARTITION ALL'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part ;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc

# Concurrent execution of INSERT and ALTER TABLE REPAIR PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (11, '1912');
BEGIN;
INSERT INTO t2part VALUES (12, '1999');

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part REPAIR PARTITION ALL;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part REPAIR PARTITION ALL'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part ;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc

# Concurrent execution of INSERT and ALTER TABLE REPAIR PARTITION inside an active transaction.

--echo --- connection master ---
connection master;
INSERT INTO t2part VALUES (13, '1923');
BEGIN;
INSERT INTO t2part VALUES (14, '1981');

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2part REMOVE PARTITIONING ;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t2part REMOVE PARTITIONING' `;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2part ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2part ;

--let $diff_tables= master:t2part, slave:t2part
--source include/diff_tables.inc

# Concurrent execution of INSERT and ALTER TABLE ALGORITHM COPY inside an active transaction.

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 ALGORITHM = COPY;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 ALGORITHM = COPY;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master


--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of INSERT and ALTER TABLE ALGORITHM INPLACE inside an active transaction.

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1 ALGORITHM = INPLACE;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1 ALGORITHM = INPLACE;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc

# Meta data locking for HANDLER statement

CREATE TABLE t1hand (a INT, KEY a(a));

--echo --- connection master ---
connection master;
SET SESSION lock_wait_timeout = 1;
BEGIN;
SELECT * FROM t1hand;
HANDLER t1hand OPEN;
HANDLER t1hand READ a NEXT;

--echo --- connection master1 ---
connection master1;
let $lock_status = `SELECT COUNT(*) FROM information_schema.processlist
                   WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'HANDLER t1hand READ a NEXT'`;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t1hand;

--echo --- connection master2 ---
connection master2;
let $wait_condition = SELECT COUNT(*) FROM INFORMATION_SCHEMA.PROCESSLIST
                     WHERE STATE = "Waiting for table"
                     AND INFO = "DROP TABLE t1hand";

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
HANDLER t1hand CLOSE;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1hand ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1hand ;

--let $diff_tables= master:t1hand, slave:t1hand
--source include/diff_tables.inc
DROP TABLE t1hand;

# Triggers - Tables from different engines cause full table lock

USE test;

--echo --- connection master ---
connection master;
CREATE TABLE t1trig(c INT) ENGINE = INNODB;
CREATE TABLE t2trig(c INT) ENGINE = MYISAM;
DELIMITER |;
CREATE TRIGGER trig AFTER UPDATE ON t1trig FOR EACH ROW
BEGIN
INSERT INTO t2trig(c) VALUES (1);
END|
DELIMITER ;|
INSERT INTO t1trig(c) VALUES (1);
--disable_warnings
UPDATE t1trig SET c = 2 WHERE c = 1;
--enable_warnings

--echo --- connection master1 ---
connection master1;
INSERT INTO t1trig VALUES (9);

--echo --- connection master ---
connection master;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1trig;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1trig;

--let $diff_tables= master:t1trig, slave:t1trig
--source include/diff_tables.inc

# Concurrent execution of INSERT and REVOKE PRIVILEGES inside an active transaction.

USE test;
CREATE USER 'user1'@'localhost' ;
GRANT ALL ON test.t1 TO user1@localhost;

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send REVOKE ALL ON test.t1 FROM user1@localhost;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'REVOKE ALL ON test.t1 FROM user1@localhost'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc

# Four way deadlock - Waiting for locks and hang
USE test;
--echo --- connection master ---
connection master;
CREATE TABLE tz (s1 INT UNIQUE) ENGINE = INNODB;
INSERT INTO tz VALUES (1);

--echo --- connection master1 ---
connection master1;
INSERT INTO tz VALUES (2);
INSERT INTO tz VALUES (3);

--echo --- connection master2 ---
connection master2;
DROP TABLE tz;

--echo --- connection master3 ---
connection master3;
--error ER_BAD_TABLE_ERROR
--echo send statement and reap result later ---
--send DROP TABLE tz;


--echo --- connection master ---
connection master;
--sync_slave_with_master

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc

# Concurrent execution of ROLLBACK and INSERT inside an active transaction.

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);
INSERT INTO t1 VALUES (5);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ROLLBACK;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ROLLBACK;'`;


--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of Multiple DML statement on different tables with DROP TABLE on other connection.
--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);
INSERT INTO t2 VALUES (2,3);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t2;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP TABLE t2;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of Multiple DML statement on different tables with RENAME on other connection.

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (1);
INSERT INTO t2 VALUES (2,3);
INSERT INTO t3 VALUES (2);
INSERT INTO t4 VALUES (1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send RENAME TABLE t1 to t2, t2 to t3, t3 to t4, t4 to t1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'RENAME TABLE t1 to t2, t2 to t3, t3 to t4, t4 to t1;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
SELECT COUNT(*) FROM t2 ;
SELECT COUNT(*) FROM t3 ;
SELECT COUNT(*) FROM t4 ;

--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;
SELECT COUNT(*) FROM t2 ;
SELECT COUNT(*) FROM t3 ;
SELECT COUNT(*) FROM t4 ;

--let $diff_tables= master:t1, slave:t1
--let $diff_tables= master:t2, slave:t2
--let $diff_tables= master:t3, slave:t3
--let $diff_tables= master:t4, slave:t4
--source include/diff_tables.inc


# Rename tables on innodb tables with pending clause slave data issue

--echo --- connection master ---
connection master;
INSERT INTO t3967_1 (b) VALUES (1),(2),(3);
BEGIN;
INSERT INTO t3967_1(b) VALUES (4);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send RENAME TABLE t3967_1 to t1_backup, t3967_2 to t3967_1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'RENAME TABLE t3967_1 to t1_backup, t3967_2 to t3967_1;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t3967_1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t3967_1 ;

--let $diff_tables= master:t3967_1, slave:t3967_1
--source include/diff_tables.inc


# WITH CONSISTENT SNAPSHOT does not isolate against TABLE CHANGES.

INSERT INTO t1_30138 VALUES (1),(2),(3);
SET AUTOCOMMIT = 0;
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
START TRANSACTION WITH CONSISTENT SNAPSHOT;
SELECT COUNT(*) FROM t1_30138;
CREATE TABLE t1_30138_new (id INT) ENGINE = INNODB;
INSERT INTO t1_30138_new VALUES (4),(5),(6),(7);
INSERT INTO t1_30138 VALUES(8);
RENAME TABLE t1_30138 TO t1_30138_old, t1_30138_new TO t1_30138;
SELECT COUNT(*) FROM t1_30138;
SELECT COUNT(*) FROM t1_30138_old;
--sync_slave_with_master


--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1_30138 ;
SELECT COUNT(*) FROM t1_30138_old ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1_30138 ;
SELECT COUNT(*) FROM t1_30138_old ;

--let $diff_tables= master:t1_30138, slave:t1_30138
--let $diff_tables= master:t1_30138_old, slave:t1_30138_old
--source include/diff_tables.inc

# Concurrent execution of Multi UPDATE statements on transactional (INNODB) and non transactional tables(MyISAM).
CALL mtr.add_suppression('Unsafe statement written to the binary log using statement format since BINLOG_FORMAT = STATEMENT');
--echo --- connection master ---
connection master;
INSERT INTO t1innodb (c) VALUES (1);
INSERT INTO t1myisam (c) VALUES (1);
COMMIT;
BEGIN;
--disable_warnings
UPDATE t1myisam, t1innodb SET t1myisam.c = 10, t1innodb.c = NULL;
--enable_warnings

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t1myisam;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP TABLE t1myisam'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1myisam ;
SELECT COUNT(*) FROM t1innodb ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1myisam ;
SELECT COUNT(*) FROM t1innodb ;

--let $diff_tables= master:t1myisam, slave:t1myisam
--let $diff_tables= master:t1innodb, slave:t1innodb
--source include/diff_tables.inc

# Binlogging of "CREATE SELECT" which unfold into two or more events in RBL mode.

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 SELECT * FROM t1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP TABLE t1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of DROP DATABASE and CREATE FUNCTION inside in an active transaction.

--echo --- connection master ---
connection master;
CREATE DATABASE db1;
USE db1;
CREATE TABLE db1.t1 (a INT);
BEGIN;
CREATE FUNCTION db1.f1() RETURNS INT RETURN 1;
INSERT INTO db1.t1 VALUES (f1());

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP DATABASE db1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP database db1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE db1;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc
DROP TABLE db1.t1;
DROP FUNCTION db1.f1;

# Concurrent execution of DML statements that uses stored FUNCTION and DROP/MODIFY the same FUNCTION.

USE test;
DROP TABLE t1;
CREATE TABLE t1 (a INT);
CREATE FUNCTION f1() RETURNS INT RETURN 1;

BEGIN;
INSERT INTO t1 VALUES (f1());

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP FUNCTION f1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP FUNCTION f1';`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE test;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of DML statements that uses STORED PROCEDURE and DROP the same.

--echo --- connection master ---
connection master;
CREATE PROCEDURE p1() INSERT INTO t1 SELECT * FROM t3;
BEGIN;
CALL p1();

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP PROCEDURE p1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP PROCEDURE p1';`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc


# Concurrent execution of DML statements that uses STORED PROCEDURE and DROP the same.

--echo --- connection master ---
connection master;
DELIMITER |;
CREATE EVENT e1 ON SCHEDULE EVERY 1 SECOND STARTS NOW() DO
BEGIN
  DECLARE EXIT HANDLER FOR 1136 BEGIN
    INSERT INTO t3 VALUES (1);
  END; -- ER_WRONG_VALUE_COUNT_ON_ROW
  INSERT INTO t2 SELECT * FROM t1;
END|
DELIMITER ;|

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP EVENT e1;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock' AND info = 'DROP EVENT e1';`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t2 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2 ;

--let $diff_tables= master:t2, slave:t2
--source include/diff_tables.inc

# Concurrent execution of INSERT and ALTER on VIEW inside an active transaction.

--echo --- connection master ---
connection master;
CREATE VIEW v1 AS SELECT * FROM t1;
BEGIN;
INSERT INTO v1 VALUES (11);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER VIEW v1 AS SELECT * FROM t2;
--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER VIEW v1 AS SELECT * FROM t2'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM v1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM v1;

--let $diff_tables= master:v1, slave:v1
--source include/diff_tables.inc


# Concurrent execution of INSERT and DROP on VIEW inside an active transaction.

--echo --- connection master ---
connection master;
DROP VIEW v1;
CREATE VIEW v1 AS SELECT * FROM t1;
BEGIN;
INSERT INTO v1 VALUES (12);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP VIEW v1;
--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP VIEW v1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM v1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM v1 ;

--let $diff_tables= master:v1, slave:v1
--source include/diff_tables.inc

# Concurrent execution of ALTER and UPDATE on VIEW inside an active transaction.

--echo --- connection master ---
connection master;
DROP VIEW v1;
CREATE VIEW v1 AS SELECT a, 1 AS col2 FROM t1;
BEGIN;
UPDATE v1 SET a = 0;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER VIEW v1 AS SELECT a,1 AS col2 FROM t2;
--echo --- connection master ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER VIEW v1 AS SELECT a,1 AS col2 FROM t2'`;

--echo --- connection master2 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM v1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM v1 ;

--let $diff_tables= master:v1, slave:v1
--source include/diff_tables.inc


# Concurrent execution of INSERT and CREATE REPLACE ON VIEW inside an active transaction.

--echo --- connection master ---
connection master;
DROP VIEW v1;
CREATE OR REPLACE VIEW v1 AS SELECT * FROM t1;
BEGIN;
INSERT INTO v1 VALUES(13);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER VIEW v1 AS SELECT * FROM t2;
--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER VIEW v1 AS SELECT * FROM t2'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM v1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM v1 ;

--let $diff_tables= master:v1, slave:v1
--source include/diff_tables.inc


# Concurrent execution of OPTIMIZE TABLE and DROP TABLE

--echo --- connection master ---
connection master;
INSERT INTO t1opt VALUES (1,'Mysql locking',20,'Transactional locking',10);
INSERT INTO t1opt SELECT * FROM t1opt;
BEGIN;
--disable_result_log
OPTIMIZE TABLE t1opt;
--enable_result_log

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t1opt;

--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP TABLE t1opt'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;

--let $diff_tables= master:v1, slave:v1
--source include/diff_tables.inc


# Concurrent execution of OPTIMIZE TABLE and DROP TABLE

--echo --- connection master ---
connection master;
CREATE TABLE t1opt (id INT , content TEXT, author_id INT,
                    article_title VARCHAR(120), article_hash INT);
INSERT INTO t1opt VALUES (2,'Mysql locking1',22,'Transactional locking1',11);
INSERT INTO t1opt SELECT * FROM t1opt;
BEGIN;
--disable_result_log
OPTIMIZE TABLE t1opt;
--enable_result_log

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1opt RENAME TO t1opt;
--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'ALTER TABLE t1opt RENAME TO t1opt'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1opt ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1opt ;

--let $diff_tables= master:t1opt, slave:t1opt
--source include/diff_tables.inc


# Concurrent execution of INSERT and DROP using more than one table

--echo --- connection master ---
connection master;
BEGIN;
INSERT INTO t1 VALUES (15);
INSERT INTO t3 VALUES (10);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t1,t3;
--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP TABLE t1,t3'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t1 ;
SELECT COUNT(*) FROM t3 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1 ;
SELECT COUNT(*) FROM t3 ;

--let $diff_tables= master:t1, slave:t1
--let $diff_tables= master:t3, slave:t3
--source include/diff_tables.inc


# Concurrent execution of DELETE and DROP using more than one table

--echo --- connection master ---
connection master;
BEGIN;
DELETE t3.*, t4.* FROM t3, t4 WHERE t3.a = t4.a AND t3.a = 1;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP TABLE t3, t4;
--echo --- connection master2 ---
connection master2;
let $lock_status = `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Waiting for TABLE metadata lock'
                    AND info = 'DROP TABLE t3, t4'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
SELECT COUNT(*) FROM t3 ;
SELECT COUNT(*) FROM t4 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t3 ;
SELECT COUNT(*) FROM t4 ;

--let $diff_tables= master:t3, slave:t3
--let $diff_tables= master:t4, slave:t4
--source include/diff_tables.inc


# Concurrent execution of DROP DATABASE and INSERT in an active transaction

--echo --- connection master ---
connection master;
DROP DATABASE db1;
CREATE DATABASE db1;
USE db1;
CREATE TABLE db1.t1(a INT, b INT);
BEGIN;
INSERT INTO db1.t1 VALUES (1, 1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send DROP DATABASE db1;

--echo --- connection master2 ---
connection master2;
let $lock_status= `SELECT COUNT(*) = 1 FROM information_schema.processlist
                   WHERE state = 'Table lock' AND info = 'DROP DATABASE db1'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE db1;
SELECT COUNT(*) FROM t1;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc

DROP TABLE db1.t1;

# Concurrent execution of ALTER DATABASE and INSERT in an active transaction
USE test;
--echo --- connection master ---
connection master;
DROP DATABASE db1;
CREATE DATABASE db1;
USE db1;
CREATE TABLE db1.t1(a INT, b INT);
BEGIN;
INSERT INTO db1.t1 VALUES (1,1);

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER DATABASE db1 CHARACTER SET big5;

--echo --- connection master2 ---
connection master2;
let $lock_status= `SELECT COUNT(*) = 1 FROM information_schema.processlist
                  WHERE state = 'Table lock' AND info = 'ALTER DATABASE db1 CHARACTER SET big5;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE db1;
SELECT COUNT(*) FROM t1;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1;

--let $diff_tables= master:t1, slave:t1
--source include/diff_tables.inc

DROP TABLE db1.t1;

USE test;
# Select inside FUNCTION takes a shared lock
--echo --- connection master ---
connection master;
USE test;
CREATE TABLE tab1(x INT PRIMARY KEY, y INT) ENGINE = INNODB;
INSERT tab1 VALUES (1, 0), (2, 0), (3, 0), (4, 0), (5, 0);
DELIMITER |;
CREATE FUNCTION func(z INT) RETURNS INT
READS SQL DATA
RETURN (SELECT x FROM tab1 WHERE x = z)
|
DELIMITER ;|
BEGIN;
SELECT func(1);

--echo --- connection master1 ---
connection master1;
USE test;
BEGIN;
SELECT func(1);
UPDATE tab1 SET y = 1 WHERE x = 1;

--echo --- connection master ---
connection master;
COMMIT;

--echo --- connection master1 ---
connection master1;
COMMIT;

--echo --- connection master ---
connection master;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE test;
SELECT COUNT(*) FROM tab1 ;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM tab1;


--let $diff_tables= master:tab1, slave:tab1
--source include/diff_tables.inc

DROP FUNCTION func;
DROP TABLE tab1;

# Exclusive locking on table

USE test;
CREATE TABLE t1lock (a INT);
CREATE TABLE t2lock (a INT);
--echo --- connection master ---
connection master;
LOCK TABLE t1lock WRITE, t2lock WRITE;
DROP TABLE t1lock;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t2lock RENAME t1lock;

--echo --- connection master2 ---
connection master2;
let $lock_status= `SELECT COUNT(*) = 1 FROM information_schema.processlist
                  WHERE state = 'Table lock' AND info = 'ALTER TABLE t1lock RENAME t2lock;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---
--error ER_LOCK_WAIT_TIMEOUT
--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master


--echo --- connection slave ---
connection slave;
USE test;
SELECT COUNT(*) FROM t2lock;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2lock;

--let $diff_tables= master:t2lock, slave:t2lock
--source include/diff_tables.inc


--echo --- connection master ---
connection master;
UNLOCK TABLES;
CREATE TABLE t1lock (a INT);
LOCK TABLE t1lock WRITE;
UNLOCK TABLES;
DROP TABLE t2lock;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
--echo send statement and reap result later ---
--send ALTER TABLE t1lock RENAME t2lock;

--echo --- connection master2 ---
connection master2;
let $lock_status= `SELECT COUNT(*) = 1 FROM information_schema.processlist
                    WHERE state = 'Table lock' and info = 'ALTER TABLE t1lock RENAME t2lock;'`;

--echo --- connection master1 ---
connection master1;
--echo reap result of previous---

--reap

--echo --- connection master ---
connection master;
COMMIT;
--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE test;
SELECT COUNT(*) FROM t2lock;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t2lock;

--let $diff_tables= master:t2lock, slave:t2lock
--source include/diff_tables.inc

DROP TABLE t2lock;

# Waiting for lock and hangs
CREATE TABLE t1lock1 (a INT, b INT);
CREATE TABLE t2lock1 (a INT, b INT);
--echo --- connection master ---
connection master;
LOCK TABLES t1lock1 WRITE;
# InnoDB shows: 'OK' ,whereas, MyISAM shows: 'Table is already up to date'
--replace_result OK "Table is already up to date"
ANALYZE TABLE t1lock1;
UNLOCK TABLES;

--echo --- connection master1 ---
connection master1;
SET SESSION lock_wait_timeout = 1;
LOCK TABLE t2lock1 WRITE;
FLUSH TABLE t2lock1;
UNLOCK TABLES;

--sync_slave_with_master

--echo --- connection slave ---
connection slave;
USE test;
SELECT COUNT(*) FROM t1lock1;
--echo --- connection master ---
connection master;
SELECT COUNT(*) FROM t1lock1;

--let $diff_tables= master:t1lock1, slave:t1lock1
--source include/diff_tables.inc

# Cleanup
DROP TABLE t1lock1,t2lock1;
DROP TABLE t1,t2,t3,t4;
DROP TABLE t1part,t2part,t3part,t4part;
DROP TABLE t1prim,t1opt;
DROP TABLE t1trig,t2trig;
DROP TABLE t1bin,t2bin,t1myisam,t1innodb;
DROP TABLE t3967_1,t3967_2,t1_30138,t1_30138_old;
DROP FUNCTION f1;
DROP VIEW v1;
DROP USER user1@localhost;
DROP DATABASE db1;

--sync_slave_with_master
--source include/rpl_end.inc
connection slave;
disconnect slave;
--source include/wait_until_disconnected.inc
connection master3;
disconnect master3;
--source include/wait_until_disconnected.inc
connection master2;
disconnect master2;
--source include/wait_until_disconnected.inc
connection master1;
disconnect master1;
--source include/wait_until_disconnected.inc
connection master;
disconnect master;
--source include/wait_until_disconnected.inc


Man Man