mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
a9150f0007
alter_treable-big.test was failing due to the use of RAND() function which is no more replication safe. This has been modified using static values. Also, 'sleep' has been replaced using 'debug_sync' and the execution time of the test has been reduced significantly. This test is now taken out of the disabled.def file and is being enabled.
173 lines
5.7 KiB
Text
173 lines
5.7 KiB
Text
#
|
|
# 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
|
|
# 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
|