mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 05:22:25 +01:00
09346e6e2d
This includes both code and test cases. BitKeeper/deleted/.del-ctype_ucs_binlog.result~280d136b1a0bcf17: Delete: mysql-test/r/ctype_ucs_binlog.result BitKeeper/deleted/.del-rpl_delete_all.result~7c050d592614b3f: Delete: mysql-test/r/rpl_delete_all.result BitKeeper/deleted/.del-rpl000013-slave.opt~18266ad8a2403e8d: Delete: mysql-test/t/rpl000013-slave.opt BitKeeper/deleted/.del-rpl_delete_all.test~700a1490277780e0: Delete: mysql-test/t/rpl_delete_all.test mysql-test/extra/binlog_tests/binlog.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/blackhole.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/ctype_cp932.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/ctype_cp932_binlog.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/ctype_ucs_binlog.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/drop_temp_table.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/insert_select-binlog.test: Import patch wl1012.patch mysql-test/extra/binlog_tests/mix_innodb_myisam_binlog.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_ddl.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_deadlock.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_err_ignoredtable.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_flsh_tbls.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_loaddata_m.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_log.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_max_relay_size.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_multi_query.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_reset_slave.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_stm_000001.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_stm_EE_err.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_stm_charset.test: Import patch wl1012.patch mysql-test/extra/rpl_tests/rpl_user_variables.test: Import patch wl1012.patch mysql-test/r/binlog_stm_binlog.result: Import patch wl1012.patch mysql-test/r/binlog_stm_blackhole.result: Import patch wl1012.patch mysql-test/r/binlog_stm_ctype_cp932.result: Import patch wl1012.patch mysql-test/r/binlog_stm_ctype_ucs.result: Import patch wl1012.patch mysql-test/r/binlog_stm_drop_tmp_tbl.result: Import patch wl1012.patch mysql-test/r/binlog_stm_insert_select.result: Import patch wl1012.patch mysql-test/r/binlog_stm_mix_innodb_myisam.result: Import patch wl1012.patch mysql-test/r/rpl_000012.result: Import patch wl1012.patch mysql-test/r/rpl_000015.result: Import patch wl1012.patch mysql-test/r/rpl_deadlock_innodb.result: Import patch wl1012.patch mysql-test/r/rpl_flushlog_loop.result: Import patch wl1012.patch mysql-test/r/rpl_loaddata_s.result: Import patch wl1012.patch mysql-test/r/rpl_stm_000001.result: Import patch wl1012.patch mysql-test/r/rpl_stm_EE_err.result: Import patch wl1012.patch mysql-test/r/rpl_stm_charset.result: Import patch wl1012.patch mysql-test/r/rpl_stm_ddl.result: Import patch wl1012.patch mysql-test/r/rpl_stm_err_ignoredtable.result: Import patch wl1012.patch mysql-test/r/rpl_stm_flsh_tbls.result: Import patch wl1012.patch mysql-test/r/rpl_stm_loaddata_m.result: Import patch wl1012.patch mysql-test/r/rpl_stm_log.result: Import patch wl1012.patch mysql-test/r/rpl_stm_max_relay_size.result: Import patch wl1012.patch mysql-test/r/rpl_stm_multi_query.result: Import patch wl1012.patch mysql-test/r/rpl_stm_mystery22.result: Import patch wl1012.patch mysql-test/r/rpl_stm_reset_slave.result: Import patch wl1012.patch mysql-test/r/rpl_stm_rewrt_db.result: Import patch wl1012.patch mysql-test/r/rpl_stm_sp.result: Import patch wl1012.patch mysql-test/r/rpl_stm_timezone.result: Import patch wl1012.patch mysql-test/r/rpl_stm_until.result: Import patch wl1012.patch mysql-test/r/rpl_stm_user_variables.result: Import patch wl1012.patch mysql-test/r/rpl_stm_view.result: Import patch wl1012.patch mysql-test/t/binlog_row_binlog-master.opt: Import patch wl1012.patch mysql-test/t/rpl_000012.test: Import patch wl1012.patch mysql-test/t/rpl_000015-slave.sh: Import patch wl1012.patch mysql-test/t/rpl_000015.slave-mi: Import patch wl1012.patch mysql-test/t/rpl_000015.test: Import patch wl1012.patch mysql-test/t/rpl_deadlock_innodb-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_flushlog_loop-master.opt: Import patch wl1012.patch mysql-test/t/rpl_flushlog_loop-master.sh: Import patch wl1012.patch mysql-test/t/rpl_flushlog_loop-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_flushlog_loop-slave.sh: Import patch wl1012.patch mysql-test/t/rpl_flushlog_loop.test: Import patch wl1012.patch mysql-test/t/rpl_loaddata_s-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_loaddata_s.test: Import patch wl1012.patch mysql-test/t/rpl_stm_000001-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_err_ignoredtable-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_loaddata_m-master.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_log-master.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_log-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_mystery22.test: Import patch wl1012.patch mysql-test/t/rpl_stm_rewrt_db-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_rewrt_db.test: Import patch wl1012.patch mysql-test/t/rpl_stm_sp-master.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_sp-slave.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_sp.test: Import patch wl1012.patch mysql-test/t/rpl_stm_timezone-master.opt: Import patch wl1012.patch mysql-test/t/rpl_stm_timezone-slave.opt: Import patch wl1012.patch BUILD/SETUP.sh: Import patch wl1012.patch Makefile.am: Import patch wl1012.patch mysql-test/t/rpl_stm_timezone.test: Import patch wl1012.patch mysql-test/t/rpl_stm_until.test: Import patch wl1012.patch mysql-test/t/rpl_stm_view.test: Import patch wl1012.patch client/Makefile.am: Import patch wl1012.patch client/client_priv.h: Import patch wl1012.patch client/mysqlbinlog.cc: Import patch wl1012.patch configure.in: Import patch wl1012.patch include/Makefile.am: Import patch wl1012.patch include/base64.h: Import patch wl1012.patch include/config-win.h: Import patch wl1012.patch include/my_base.h: Import patch wl1012.patch include/my_global.h: Import patch wl1012.patch mysql-test/Makefile.am: Import patch wl1012.patch mysql-test/mysql-test-run.pl: Import patch wl1012.patch mysql-test/mysql-test-run.sh: Import patch wl1012.patch mysql-test/r/date_formats.result: Import patch wl1012.patch mysql-test/r/flush_block_commit.result: Import patch wl1012.patch mysql-test/r/innodb.result: Import patch wl1012.patch mysql-test/r/rpl000017.result: Import patch wl1012.patch mysql-test/r/rpl_change_master.result: Import patch wl1012.patch mysql-test/r/rpl_commit_after_flush.result: Import patch wl1012.patch mysql-test/r/rpl_create_database.result: Import patch wl1012.patch mysql-test/r/rpl_do_grant.result: Import patch wl1012.patch mysql-test/r/rpl_loaddata.result: Import patch wl1012.patch mysql-test/r/rpl_log_pos.result: Import patch wl1012.patch mysql-test/r/rpl_multi_delete.result: Import patch wl1012.patch mysql-test/r/rpl_multi_update.result: Import patch wl1012.patch mysql-test/r/rpl_openssl.result: Import patch wl1012.patch mysql-test/r/rpl_replicate_do.result: Import patch wl1012.patch mysql-test/r/rpl_rotate_logs.result: Import patch wl1012.patch mysql-test/r/rpl_server_id1.result: Import patch wl1012.patch mysql-test/r/rpl_server_id2.result: Import patch wl1012.patch mysql-test/r/rpl_temporary.result: Import patch wl1012.patch mysql-test/r/user_var-binlog.result: Import patch wl1012.patch mysql-test/t/create_select_tmp.test: Import patch wl1012.patch mysql-test/t/date_formats.test: Import patch wl1012.patch mysql-test/t/disabled.def: Import patch wl1012.patch mysql-test/t/innodb.test: Import patch wl1012.patch mysql-test/t/mysqlbinlog.test: Import patch wl1012.patch mysql-test/t/mysqlbinlog2.test: Import patch wl1012.patch mysql-test/t/rpl000002.test: Import patch wl1012.patch mysql-test/t/rpl000006.test: Import patch wl1012.patch mysql-test/t/rpl000013.test: Import patch wl1012.patch mysql-test/t/rpl000017.test: Import patch wl1012.patch mysql-test/t/rpl_auto_increment.test: Import patch wl1012.patch mysql-test/t/rpl_change_master.test: Import patch wl1012.patch mysql-test/t/rpl_commit_after_flush.test: Import patch wl1012.patch mysql-test/t/rpl_create_database.test: Import patch wl1012.patch mysql-test/t/rpl_do_grant.test: Import patch wl1012.patch mysql-test/t/rpl_drop.test: Import patch wl1012.patch mysql-test/t/rpl_empty_master_crash.test: Import patch wl1012.patch mysql-test/t/rpl_failed_optimize.test: Import patch wl1012.patch mysql-test/t/rpl_heap.test: Import patch wl1012.patch mysql-test/t/rpl_insert_id.test: Import patch wl1012.patch mysql-test/t/rpl_insert_ignore.test: Import patch wl1012.patch mysql-test/t/rpl_loaddata.test: Import patch wl1012.patch mysql-test/t/rpl_log_pos.test: Import patch wl1012.patch mysql-test/t/rpl_multi_delete.test: Import patch wl1012.patch mysql-test/t/rpl_multi_update.test: Import patch wl1012.patch mysql-test/t/rpl_multi_update2.test: Import patch wl1012.patch mysql-test/t/rpl_multi_update3.test: Import patch wl1012.patch mysql-test/t/rpl_openssl.test: Import patch wl1012.patch mysql-test/t/rpl_redirect.test: Import patch wl1012.patch mysql-test/t/rpl_relayrotate.test: Import patch wl1012.patch mysql-test/t/rpl_replicate_do.test: Import patch wl1012.patch mysql-test/t/rpl_rotate_logs.test: Import patch wl1012.patch mysql-test/t/rpl_server_id1.test: Import patch wl1012.patch mysql-test/t/rpl_sp_effects.test: Import patch wl1012.patch mysql-test/t/rpl_temporary.test: Import patch wl1012.patch mysql-test/t/rpl_trigger.test: Import patch wl1012.patch mysql-test/t/sp.test: Import patch wl1012.patch mysql-test/t/user_var-binlog.test: Import patch wl1012.patch mysys/Makefile.am: Import patch wl1012.patch mysys/base64.c: Import patch wl1012.patch sql/Makefile.am: Import patch wl1012.patch sql/ha_innodb.cc: Import patch wl1012.patch sql/ha_innodb.h: Import patch wl1012.patch sql/ha_partition.cc: Import patch wl1012.patch sql/handler.cc: Import patch wl1012.patch sql/handler.h: Import patch wl1012.patch sql/item_sum.cc: Import patch wl1012.patch sql/log.cc: Import patch wl1012.patch sql/log_event.cc: Import patch wl1012.patch sql/log_event.h: Import patch wl1012.patch sql/mysql_priv.h: Import patch wl1012.patch sql/mysqld.cc: Import patch wl1012.patch sql/rpl_filter.h: Import patch wl1012.patch sql/set_var.cc: Import patch wl1012.patch sql/share/errmsg.txt: Import patch wl1012.patch sql/slave.cc: Import patch wl1012.patch sql/slave.h: Import patch wl1012.patch sql/sp.cc: Import patch wl1012.patch sql/sp_head.cc: Import patch wl1012.patch sql/sql_acl.cc: Import patch wl1012.patch sql/sql_base.cc: Import patch wl1012.patch sql/sql_class.cc: Import patch wl1012.patch sql/sql_class.h: Import patch wl1012.patch sql/sql_delete.cc: Import patch wl1012.patch sql/sql_insert.cc: Import patch wl1012.patch sql/sql_lex.h: Import patch wl1012.patch sql/sql_list.h: Import patch wl1012.patch sql/sql_load.cc: Import patch wl1012.patch sql/sql_parse.cc: Import patch wl1012.patch sql/sql_plugin.cc: Import patch wl1012.patch sql/sql_rename.cc: Import patch wl1012.patch sql/sql_repl.h: Import patch wl1012.patch sql/sql_select.cc: Import patch wl1012.patch sql/sql_show.cc: Import patch wl1012.patch sql/sql_table.cc: Import patch wl1012.patch sql/sql_udf.cc: Import patch wl1012.patch sql/sql_union.cc: Import patch wl1012.patch sql/sql_update.cc: Import patch wl1012.patch sql/sql_yacc.yy: Import patch wl1012.patch sql/table.cc: Import patch wl1012.patch sql/table.h: Import patch wl1012.patch storage/innobase/include/lock0lock.h: Import patch wl1012.patch storage/innobase/include/row0mysql.h: Import patch wl1012.patch storage/innobase/include/row0vers.h: Import patch wl1012.patch storage/innobase/lock/lock0lock.c: Import patch wl1012.patch storage/innobase/row/row0mysql.c: Import patch wl1012.patch storage/innobase/row/row0sel.c: Import patch wl1012.patch storage/innobase/row/row0vers.c: Import patch wl1012.patch
510 lines
16 KiB
Text
510 lines
16 KiB
Text
######################## rpl_ddl.test ########################
|
|
# #
|
|
# DDL statements (sometimes with implicit COMMIT) executed #
|
|
# by the master and it's propagation into the slave #
|
|
# #
|
|
##############################################################
|
|
|
|
#
|
|
# NOTE, PLEASE BE CAREFUL, WHEN MODIFYING THE TESTS !!
|
|
#
|
|
# 1. !All! objects to be dropped, renamed, altered ... must be created
|
|
# in AUTOCOMMIT= 1 mode before AUTOCOMMIT is set to 0 and the test
|
|
# sequences start.
|
|
#
|
|
# 2. Never use a test object, which was direct or indirect affected by a
|
|
# preceeding test sequence again.
|
|
# Except table d1.t1 where ONLY DML is allowed.
|
|
#
|
|
# If one preceeding test sequence hits a (sometimes not good visible,
|
|
# because the sql error code of the statement might be 0) bug
|
|
# and these rules are ignored, a following test sequence might earn ugly
|
|
# effects like failing 'sync_slave_with_master', crashes of the slave or
|
|
# abort of the test case etc..
|
|
#
|
|
# 3. The assignment of the DDL command to be tested to $my_stmt can
|
|
# be a bit difficult. "'" must be avoided, because the test
|
|
# routine "include/rpl_stmt_seq.inc" performs a
|
|
# eval SELECT CONCAT('######## ','$my_stmt',' ########') as "";
|
|
#
|
|
|
|
###############################################################
|
|
# Some preparations
|
|
###############################################################
|
|
# The sync_slave_with_master is needed to make the xids deterministic.
|
|
sync_slave_with_master;
|
|
connection master;
|
|
|
|
SET AUTOCOMMIT = 1;
|
|
#
|
|
# 1. DROP all objects, which probably already exist, but must be created here
|
|
#
|
|
--disable_warnings
|
|
DROP DATABASE IF EXISTS mysqltest1;
|
|
DROP DATABASE IF EXISTS mysqltest2;
|
|
DROP DATABASE IF EXISTS mysqltest3;
|
|
--enable_warnings
|
|
#
|
|
# 2. CREATE all objects needed
|
|
# working database is mysqltest1
|
|
# working (transactional!) is mysqltest1.t1
|
|
#
|
|
CREATE DATABASE mysqltest1;
|
|
CREATE DATABASE mysqltest2;
|
|
eval CREATE TABLE mysqltest1.t1 (f1 BIGINT) ENGINE=$engine_type;
|
|
INSERT INTO mysqltest1.t1 SET f1= 0;
|
|
eval CREATE TABLE mysqltest1.t2 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t3 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t4 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t5 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t6 (f1 BIGINT) ENGINE=$engine_type;
|
|
CREATE INDEX my_idx6 ON mysqltest1.t6(f1);
|
|
eval CREATE TABLE mysqltest1.t7 (f1 BIGINT) ENGINE=$engine_type;
|
|
INSERT INTO mysqltest1.t7 SET f1= 0;
|
|
eval CREATE TABLE mysqltest1.t8 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t9 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t10 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t11 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t12 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t13 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t14 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t15 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t16 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t17 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t18 (f1 BIGINT) ENGINE=$engine_type;
|
|
eval CREATE TABLE mysqltest1.t19 (f1 BIGINT) ENGINE=$engine_type;
|
|
CREATE TEMPORARY TABLE mysqltest1.t23 (f1 BIGINT);
|
|
|
|
#
|
|
# 3. master sessions: never do AUTOCOMMIT
|
|
# slave sessions: never do AUTOCOMMIT
|
|
#
|
|
SET AUTOCOMMIT = 0;
|
|
use mysqltest1;
|
|
sync_slave_with_master;
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SET AUTOCOMMIT = 0;
|
|
use mysqltest1;
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
|
|
# We don't want to abort the whole test if one statement sent
|
|
# to the server gets an error, because the following test
|
|
# sequences are nearly independend of the previous statements.
|
|
--disable_abort_on_error
|
|
|
|
###############################################################
|
|
# Banal case: (explicit) COMMIT and ROLLBACK
|
|
# Just for checking if the test sequence is usable
|
|
###############################################################
|
|
|
|
let $my_stmt= COMMIT;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
let $my_stmt= ROLLBACK;
|
|
let $my_master_commit= false;
|
|
let $my_slave_commit= false;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
###############################################################
|
|
# Cases with commands very similar to COMMIT
|
|
###############################################################
|
|
|
|
let $my_stmt= SET AUTOCOMMIT=1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SET AUTOCOMMIT=0;
|
|
|
|
let $my_stmt= START TRANSACTION;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
let $my_stmt= BEGIN;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
###############################################################
|
|
# Cases with (BASE) TABLES and (UPDATABLE) VIEWs
|
|
###############################################################
|
|
|
|
let $my_stmt= DROP TABLE mysqltest1.t2;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW TABLES LIKE 't2';
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW TABLES LIKE 't2';
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
# Note: Since this test is executed with a skip-innodb slave, the
|
|
# slave incorrectly commits the insert. One can *not* have InnoDB on
|
|
# master and MyISAM on slave and expect that a transactional rollback
|
|
# after a CREATE TEMPORARY TABLE should work correctly on the slave.
|
|
# For this to work properly the handler on the slave must be able to
|
|
# handle transactions (e.g. InnoDB or NDB).
|
|
let $my_stmt= DROP TEMPORARY TABLE mysqltest1.t23;
|
|
let $my_master_commit= false;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW TABLES LIKE 't23';
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW TABLES LIKE 't23';
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
let $my_stmt= RENAME TABLE mysqltest1.t3 to mysqltest1.t20;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW TABLES LIKE 't20';
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW TABLES LIKE 't20';
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
let $my_stmt= ALTER TABLE mysqltest1.t4 ADD column f2 BIGINT;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
describe mysqltest1.t4;
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
describe mysqltest1.t4;
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
let $my_stmt= CREATE TABLE mysqltest1.t21 (f1 BIGINT) ENGINE=;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq2.inc
|
|
|
|
# Note: Since this test is executed with a skip-innodb slave, the
|
|
# slave incorrectly commits the insert. One can *not* have InnoDB on
|
|
# master and MyISAM on slave and expect that a transactional rollback
|
|
# after a CREATE TEMPORARY TABLE should work correctly on the slave.
|
|
# For this to work properly the handler on the slave must be able to
|
|
# handle transactions (e.g. InnoDB or NDB).
|
|
let $engine='';
|
|
let $eng_type='';
|
|
|
|
let $my_stmt= CREATE TEMPORARY TABLE mysqltest1.t22 (f1 BIGINT);
|
|
let $my_master_commit= false;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
let $my_stmt= TRUNCATE TABLE mysqltest1.t7;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SELECT * FROM mysqltest1.t7;
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SELECT * FROM mysqltest1.t7;
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
###############################################################
|
|
# Cases with LOCK/UNLOCK
|
|
###############################################################
|
|
|
|
# MySQL insists in locking mysqltest1.t1, because rpl_stmt_seq performs an
|
|
# INSERT into this table.
|
|
let $my_stmt= LOCK TABLES mysqltest1.t1 WRITE, mysqltest1.t8 READ;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
UNLOCK TABLES;
|
|
|
|
# No prior locking
|
|
let $my_stmt= UNLOCK TABLES;
|
|
let $my_master_commit= false;
|
|
let $my_slave_commit= false;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
# With prior read locking
|
|
# Note that this test generate an error since the rpl_stmt_seq.inc
|
|
# tries to insert into t1.
|
|
LOCK TABLES mysqltest1.t1 READ;
|
|
let $my_stmt= UNLOCK TABLES;
|
|
let $my_master_commit= false;
|
|
let $my_slave_commit= false;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
# With prior write locking
|
|
LOCK TABLES mysqltest1.t1 WRITE, mysqltest1.t8 READ;
|
|
let $my_stmt= UNLOCK TABLES;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
|
|
###############################################################
|
|
# Cases with INDEXES
|
|
###############################################################
|
|
|
|
let $my_stmt= DROP INDEX my_idx6 ON mysqltest1.t6;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW INDEX FROM mysqltest1.t6;
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW INDEX FROM mysqltest1.t6;
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
let $my_stmt= CREATE INDEX my_idx5 ON mysqltest1.t5(f1);
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW INDEX FROM mysqltest1.t5;
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW INDEX FROM mysqltest1.t5;
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
###############################################################
|
|
# Cases with DATABASE
|
|
###############################################################
|
|
|
|
let $my_stmt= DROP DATABASE mysqltest2;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW DATABASES LIKE "mysqltest2";
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW DATABASES LIKE "mysqltest2";
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
let $my_stmt= CREATE DATABASE mysqltest3;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW DATABASES LIKE "mysqltest3";
|
|
connection slave;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave --------' as "";
|
|
--enable_query_log
|
|
SHOW DATABASES LIKE "mysqltest3";
|
|
connection master;
|
|
--disable_query_log
|
|
SELECT '-------- switch to master -------' as "";
|
|
--enable_query_log
|
|
|
|
# End of 4.1 tests
|
|
|
|
###############################################################
|
|
# Cases with stored procedures
|
|
###############################################################
|
|
let $my_stmt= CREATE PROCEDURE p1() READS SQL DATA SELECT "this is p1";
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
--vertical_results
|
|
--replace_column 5 # 6 #
|
|
SHOW PROCEDURE STATUS LIKE 'p1';
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
--replace_column 5 # 6 #
|
|
SHOW PROCEDURE STATUS LIKE 'p1';
|
|
connection master;
|
|
--horizontal_results
|
|
|
|
let $my_stmt= ALTER PROCEDURE p1 COMMENT "I have been altered";
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
--vertical_results
|
|
--replace_column 5 # 6 #
|
|
SHOW PROCEDURE STATUS LIKE 'p1';
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
--replace_column 5 # 6 #
|
|
SHOW PROCEDURE STATUS LIKE 'p1';
|
|
connection master;
|
|
--horizontal_results
|
|
|
|
let $my_stmt= DROP PROCEDURE p1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
--vertical_results
|
|
SHOW PROCEDURE STATUS LIKE 'p1';
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SHOW PROCEDURE STATUS LIKE 'p1';
|
|
connection master;
|
|
--horizontal_results
|
|
|
|
###############################################################
|
|
# Cases with VIEWs
|
|
###############################################################
|
|
let $my_stmt= CREATE OR REPLACE VIEW v1 as select * from t1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW CREATE VIEW v1;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SHOW CREATE VIEW v1;
|
|
connection master;
|
|
|
|
let $my_stmt= ALTER VIEW v1 AS select f1 from t1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW CREATE VIEW v1;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SHOW CREATE VIEW v1;
|
|
connection master;
|
|
|
|
let $my_stmt= DROP VIEW IF EXISTS v1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
--error 1146
|
|
SHOW CREATE VIEW v1;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
--error 1146
|
|
SHOW CREATE VIEW v1;
|
|
connection master;
|
|
|
|
###############################################################
|
|
# Cases with TRIGGERs
|
|
###############################################################
|
|
let $my_stmt= CREATE TRIGGER trg1 BEFORE INSERT ON t1 FOR EACH ROW SET @a:=1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW TRIGGERS;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SHOW TRIGGERS;
|
|
connection master;
|
|
|
|
let $my_stmt= DROP TRIGGER trg1;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SHOW TRIGGERS;
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SHOW TRIGGERS;
|
|
connection master;
|
|
|
|
###############################################################
|
|
# Cases with USERs
|
|
###############################################################
|
|
let $my_stmt= CREATE USER user1@localhost;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SELECT user FROM mysql.user WHERE user = 'user1';
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SELECT user FROM mysql.user WHERE user = 'user1';
|
|
connection master;
|
|
|
|
let $my_stmt= RENAME USER user1@localhost TO rename1@localhost;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SELECT user FROM mysql.user WHERE user = 'rename1';
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SELECT user FROM mysql.user WHERE user = 'rename1';
|
|
connection master;
|
|
|
|
let $my_stmt= DROP USER rename1@localhost;
|
|
let $my_master_commit= true;
|
|
let $my_slave_commit= true;
|
|
--source include/rpl_stmt_seq.inc
|
|
SELECT user FROM mysql.user WHERE user = 'rename1';
|
|
--disable_query_log
|
|
SELECT '-------- switch to slave -------' as "";
|
|
--enable_query_log
|
|
connection slave;
|
|
SELECT user FROM mysql.user WHERE user = 'rename1';
|
|
connection master;
|
|
|
|
###############################################################
|
|
# Cleanup
|
|
###############################################################
|
|
--disable_warnings
|
|
DROP DATABASE IF EXISTS mysqltest1;
|
|
DROP DATABASE IF EXISTS mysqltest2;
|
|
DROP DATABASE IF EXISTS mysqltest3;
|
|
--enable_warnings
|
|
|
|
|