# Not supported in embedded
--source include/not_embedded.inc

# This test case needs InnoDB.
-- source include/have_innodb.inc

--disable_query_log
call mtr.add_suppression("InnoDB: Failed to find tablespace for table .* in the cache. Attempting to load the tablespace with space id");
call mtr.add_suppression("InnoDB: Allocated tablespace ID \\d+ for test.t[12], old maximum was");
call mtr.add_suppression("InnoDB: Allocated tablespace ID \\d+ for mysql.transaction_registry, old maximum was");
--enable_query_log

create table t1(f1 int not null, f2 int not null, index idx(f2))engine=innodb;
create table t2(f1 int primary key, f2 int, index idx(f2))engine=innodb;
insert into t1 values(1, 2);
insert into t2 values(1, 2);

SET GLOBAL innodb_fast_shutdown = 0;

--echo # Restart the server with innodb_force_recovery as 4.
--let $restart_parameters= --innodb-force-recovery=4
--source include/restart_mysqld.inc

select * from t1;

--error ER_READ_ONLY_MODE
insert into t1 values(2, 3);

--error ER_CANT_CREATE_TABLE
alter table t1 add f3 int not null, algorithm=copy;

--error ER_ALTER_OPERATION_NOT_SUPPORTED_REASON
alter table t1 add f3 int not null, algorithm=inplace;

--error ER_CANT_CREATE_TABLE
drop index idx on t1;
--error ER_ALTER_OPERATION_NOT_SUPPORTED_REASON
alter table t1 drop index idx, algorithm=inplace;

--error ER_READ_ONLY_MODE
update t1 set f1=3 where f2=2;

--error ER_CANT_CREATE_TABLE
create table t3(f1 int not null)engine=innodb;

--error ER_BAD_TABLE_ERROR
drop table t3;

--error ER_ERROR_ON_RENAME
rename table t1 to t3;

--error ER_OPEN_AS_READONLY
truncate table t1;

--error ER_OPEN_AS_READONLY
drop table t1;
show tables;

--echo # Restart the server with innodb_force_recovery as 5.
--let $restart_parameters= --innodb-force-recovery=5
--source include/restart_mysqld.inc

select * from t2;

--error ER_READ_ONLY_MODE
insert into t2 values(2, 3);

--error ER_CANT_CREATE_TABLE
alter table t2 add f3 int not null, algorithm=copy;

--error ER_ALTER_OPERATION_NOT_SUPPORTED_REASON
alter table t2 add f3 int not null, algorithm=inplace;

--error ER_CANT_CREATE_TABLE
drop index idx on t2;

--error ER_READ_ONLY_MODE
update t2 set f1=3 where f2=2;

--error ER_CANT_CREATE_TABLE
create table t3(f1 int not null)engine=innodb;

--error ER_BAD_TABLE_ERROR
drop table t3;

--error ER_ERROR_ON_RENAME
rename table t2 to t3;

--error ER_OPEN_AS_READONLY
truncate table t2;

--error ER_OPEN_AS_READONLY
drop table t2;
show tables;

--echo # Restart the server with innodb_force_recovery as 6.
--let $restart_parameters= --innodb-force-recovery=6
--source include/restart_mysqld.inc

select * from t2;

--error ER_OPEN_AS_READONLY
insert into t2 values(2, 3);

--error ER_OPEN_AS_READONLY
alter table t2 add f3 int not null, algorithm=copy;

--error ER_ALTER_OPERATION_NOT_SUPPORTED_REASON
alter table t2 add f3 int not null, algorithm=inplace;

--error ER_OPEN_AS_READONLY
drop index idx on t2;

--error ER_OPEN_AS_READONLY
update t2 set f1=3 where f2=2;

--error ER_CANT_CREATE_TABLE
create table t3(f1 int not null)engine=innodb;

--error ER_OPEN_AS_READONLY
drop table t1;

--error ER_ERROR_ON_RENAME
rename table t2 to t3;

--error ER_OPEN_AS_READONLY
truncate table t2;

--error ER_OPEN_AS_READONLY
drop table t2;
show tables;

--echo # Restart the server with innodb_force_recovery=2
--let $restart_parameters= --innodb-force-recovery=2
--source include/restart_mysqld.inc

select * from t2;
begin;
update t2 set f2=3;

connect (con1,localhost,root,,);
--echo # Force a redo log flush of the above uncommitted UPDATE
SET GLOBAL innodb_flush_log_at_trx_commit=1;
drop table t1;
disconnect con1;

connection default;
--source include/kill_mysqld.inc

--echo # Restart the server with innodb_force_recovery=3
--let $restart_parameters= --innodb-force-recovery=3
--source include/start_mysqld.inc

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
select * from t2;
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
select * from t2;
SET GLOBAL innodb_lock_wait_timeout=1;
--error ER_LOCK_WAIT_TIMEOUT
insert into t2 values(1,2);
insert into t2 values(9,10);

--let $restart_parameters=
--source include/restart_mysqld.inc

select * from t2;
drop table t2;
show tables;