1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
|
# test simple MVCC, that a transaction does not read something committed after it
--source include/have_tokudb.inc
SET DEFAULT_STORAGE_ENGINE = 'tokudb';
set session transaction isolation level repeatable read;
set session tokudb_disable_slow_alter=ON;
--echo # Establish connection conn1 (user = root)
connect (conn1,localhost,root,,);
--disable_warnings
DROP TABLE IF EXISTS foo;
--enable_warnings
connection conn1;
set session transaction isolation level repeatable read;
create table foo (a int, b int) engine=TokuDB;
insert into foo values (1,10);
begin;
select * from foo;
connection default;
alter table foo add column c int;
alter table foo drop column b;
connection conn1;
commit;
begin;
insert into foo values (1,10);
connection default;
--error ER_LOCK_WAIT_TIMEOUT
alter table foo add column cc int;
--error ER_LOCK_WAIT_TIMEOUT
alter table foo drop column c;
connection conn1;
commit;
connection default;
disconnect conn1;
connection default;
# Final cleanup.
set session transaction isolation level serializable;
DROP TABLE foo;
|