diff options
Diffstat (limited to 'mysql-test/main/alter_table-big.test')
-rw-r--r-- | mysql-test/main/alter_table-big.test | 174 |
1 files changed, 174 insertions, 0 deletions
diff --git a/mysql-test/main/alter_table-big.test b/mysql-test/main/alter_table-big.test new file mode 100644 index 00000000..66f95938 --- /dev/null +++ b/mysql-test/main/alter_table-big.test @@ -0,0 +1,174 @@ +# +# Tests for various concurrency-related aspects of ALTER TABLE implemetation +# +# This test takes rather long time so let us run it only in --big-test mode +--source include/big_test.inc +# We are using some debug-only features in this test +--source include/have_debug.inc +--source include/have_debug_sync.inc +# Also we are using SBR to check that statements are executed +# in proper order. +--source include/have_binlog_format_mixed_or_statement.inc + +# +# Test for Bug#25044 ALTER TABLE ... ENABLE KEYS acquires global +# 'opening tables' lock +# +# ALTER TABLE ... ENABLE KEYS should not acquire LOCK_open mutex for +# the whole its duration as it prevents other queries from execution. +--disable_warnings +drop table if exists t1, t2; +--enable_warnings +set debug_sync='RESET'; + +connect (addconroot, localhost, root,,); +connect (addconroot2, localhost, root,,); +connection default; +create table t1 (n1 int, n2 int, n3 int, + key (n1, n2, n3), + key (n2, n3, n1), + key (n3, n1, n2)); +create table t2 (i int); + +alter table t1 disable keys; +insert into t1 values (1, 2, 3); + +# Later we use binlog to check the order in which statements are +# executed so let us reset it first. +reset master; +set debug_sync='alter_table_enable_indexes SIGNAL parked WAIT_FOR go'; +--send alter table t1 enable keys; +connection addconroot; +# Wait until ALTER TABLE acquires metadata lock. +set debug_sync='now WAIT_FOR parked'; +# This statement should not be blocked by in-flight ALTER and therefore +# should be executed and written to binlog before ALTER TABLE ... ENABLE KEYS +# finishes. +insert into t2 values (1); +# And this should wait until the end of ALTER TABLE ... ENABLE KEYS. +--send insert into t1 values (1, 1, 1); +connection addconroot2; +# Wait until the above INSERT INTO t1 is blocked due to ALTER +let $wait_condition= + select count(*) = 1 from information_schema.processlist + where state = "Waiting for table metadata lock" and + info = "insert into t1 values (1, 1, 1)"; +--source include/wait_condition.inc +# Resume ALTER execution. +set debug_sync='now SIGNAL go'; +connection default; +--reap +connection addconroot; +--reap +connection default; +# Check that statements were executed/binlogged in correct order. +source include/show_binlog_events.inc; + +# Clean up +drop tables t1, t2; +disconnect addconroot; +disconnect addconroot2; +set debug_sync='RESET'; + +--echo End of 5.0 tests + +# +# Additional coverage for the main ALTER TABLE case +# +# We should be sure that table being altered is properly +# locked during statement execution and in particular that +# no DDL or DML statement can sneak in and get access to +# the table when real operation has already taken place +# but this fact has not been noted in binary log yet. +--disable_warnings +drop table if exists t1, t2, t3; +--enable_warnings +connect (addconroot, localhost, root,,); +connect (addconroot2, localhost, root,,); +connection default; +create table t1 (i int); +# We are going to check that statements are logged in correct order +reset master; +set debug_sync='alter_table_before_main_binlog SIGNAL parked WAIT_FOR go'; +--send alter table t1 change i c char(10) default 'Test1'; +connection addconroot; +# Wait until ALTER TABLE acquires metadata lock. +set debug_sync='now WAIT_FOR parked'; +--send insert into t1 values (); +connection addconroot2; +# Wait until the above INSERT INTO t1 is blocked due to ALTER +let $wait_condition= + select count(*) = 1 from information_schema.processlist + where state = "Waiting for table metadata lock" and + info = "insert into t1 values ()"; +--source include/wait_condition.inc +# Resume ALTER execution. +set debug_sync='now SIGNAL go'; +connection default; +--reap +connection addconroot; +--reap +connection default; +select * from t1; +set debug_sync='alter_table_before_main_binlog SIGNAL parked WAIT_FOR go'; +--send alter table t1 change c vc varchar(100) default 'Test2'; +connection addconroot; +# Wait until ALTER TABLE acquires metadata lock. +set debug_sync='now WAIT_FOR parked'; +--send rename table t1 to t2; +connection addconroot2; +# Wait until the above RENAME TABLE is blocked due to ALTER +let $wait_condition= + select count(*) = 1 from information_schema.processlist + where state = "Waiting for table metadata lock" and + info = "rename table t1 to t2"; +--source include/wait_condition.inc +# Resume ALTER execution. +set debug_sync='now SIGNAL go'; +connection default; +--reap +connection addconroot; +--reap +connection default; +drop table t2; +# And now tests for ALTER TABLE with RENAME clause. In this +# case target table name should be properly locked as well. +create table t1 (i int); +set debug_sync='alter_table_before_main_binlog SIGNAL parked WAIT_FOR go'; +--send alter table t1 change i c char(10) default 'Test3', rename to t2; +connection addconroot; +# Wait until ALTER TABLE acquires metadata lock. +set debug_sync='now WAIT_FOR parked'; +--send insert into t2 values(); +connection addconroot2; +# Wait until the above INSERT INTO t2 is blocked due to ALTER +let $wait_condition= + select count(*) = 1 from information_schema.processlist + where state = "Waiting for table metadata lock" and + info = "insert into t2 values()"; +--source include/wait_condition.inc +# Resume ALTER execution. +set debug_sync='now SIGNAL go'; +connection default; +--reap +connection addconroot; +--reap +connection default; +select * from t2; +--send alter table t2 change c vc varchar(100) default 'Test2', rename to t1; +connection addconroot; +connection default; +--reap +rename table t1 to t3; + +disconnect addconroot; +disconnect addconroot2; +drop table t3; +set debug_sync='alter_table_before_main_binlog SIGNAL parked WAIT_FOR go'; +set debug_sync='RESET'; + +# Check that all statements were logged in correct order +source include/show_binlog_events.inc; + + +--echo End of 5.1 tests |