-- connect (con1,localhost,root,,)
-- connect (con2,localhost,root,,)
-- connection con1
# Enable MDEV-515 table-level undo logging for insert into empty table
SET foreign_key_checks=0, unique_checks=0;
SET autocommit=0;
SELECT * FROM t1 FOR UPDATE;
-- if ($con1_extra_sql_present) {
-- eval $con1_extra_sql
-- }
-- connection con2
SELECT * FROM t2 FOR UPDATE;
-- if ($con2_extra_sql_present) {
-- eval $con2_extra_sql
-- if ($con1_should_be_rolledback) {
-- send
INSERT INTO t2 VALUES (0);
INSERT INTO t1 VALUES (0);
ROLLBACK;
-- error ER_LOCK_DEADLOCK
-- reap
# else
-- if (!$con1_should_be_rolledback) {
-- connection default
DELETE FROM t5_nontrans;
-- disconnect con1
-- disconnect con2