Commit c89c4942 authored by Marko Mäkelä's avatar Marko Mäkelä

Reduce a test so that it fails less frequently on buildbot

There is an inherent race condition between Mariabackup and the
MariaDB server when the InnoDB redo log is being copied. It is
possible that the tail of the circular redo log is overwriting
the head of the log before Mariabackup gets a chance to read it.
So, we reduce the test to generate less redo log. Also, enable
the test on all supported innodb_page_size.
parent d902d43c
CREATE TABLE t1(c1 INT, b VARCHAR(2400), index(b(100),c1)) ENGINE=INNODB ROW_FORMAT=compressed ENCRYPTED=YES; CREATE TABLE t1(c1 INT, b VARCHAR(2400), index(b(100),c1))
CREATE PROCEDURE innodb_insert_proc (REPEAT_COUNT INT) ENGINE=INNODB ROW_FORMAT=compressed ENCRYPTED=YES;
BEGIN BEGIN;
DECLARE CURRENT_NUM INT;
SET CURRENT_NUM = 0;
WHILE CURRENT_NUM < REPEAT_COUNT DO
INSERT INTO t1 VALUES(CURRENT_NUM, concat(uuid(), CURRENT_NUM, repeat('ab', floor(rand()*100) ), uuid()));
SET CURRENT_NUM = CURRENT_NUM + 1;
END WHILE;
END//
COMMIT;
SET AUTOCOMMIT=0;
CALL innodb_insert_proc(50000);
COMMIT; COMMIT;
# xtrabackup backup # xtrabackup backup
drop table t1; drop table t1;
...@@ -20,6 +10,5 @@ drop table t1; ...@@ -20,6 +10,5 @@ drop table t1;
# restart server # restart server
select sum(c1) from t1; select sum(c1) from t1;
sum(c1) sum(c1)
1249975000 12497500
DROP TABLE t1; DROP TABLE t1;
drop procedure innodb_insert_proc;
#--source include/innodb_page_size_small.inc --source include/innodb_page_size_small.inc
--source include/have_file_key_management.inc --source include/have_file_key_management.inc
CREATE TABLE t1(c1 INT, b VARCHAR(2400), index(b(100),c1)) ENGINE=INNODB ROW_FORMAT=compressed ENCRYPTED=YES; CREATE TABLE t1(c1 INT, b VARCHAR(2400), index(b(100),c1))
ENGINE=INNODB ROW_FORMAT=compressed ENCRYPTED=YES;
DELIMITER //; BEGIN;
CREATE PROCEDURE innodb_insert_proc (REPEAT_COUNT INT) let $n= 5000;
BEGIN let $i= $n;
DECLARE CURRENT_NUM INT; let $u= `SELECT uuid()`;
SET CURRENT_NUM = 0; --disable_query_log
WHILE CURRENT_NUM < REPEAT_COUNT DO while ($i) {
INSERT INTO t1 VALUES(CURRENT_NUM, concat(uuid(), CURRENT_NUM, repeat('ab', floor(rand()*100) ), uuid())); eval INSERT INTO t1
SET CURRENT_NUM = CURRENT_NUM + 1; VALUES($n-$i, concat('$u', $n-$i, repeat('ab', floor(rand()*100)), '$u'));
END WHILE; dec $i;
END// }
DELIMITER ;// --enable_query_log
COMMIT; COMMIT;
SET AUTOCOMMIT=0;
CALL innodb_insert_proc(50000);
COMMIT;
echo # xtrabackup backup; echo # xtrabackup backup;
--disable_result_log --disable_result_log
let $targetdir=$MYSQLTEST_VARDIR/tmp/backup; let $targetdir=$MYSQLTEST_VARDIR/tmp/backup;
...@@ -32,5 +28,4 @@ exec $INNOBACKUPEX --apply-log $targetdir; ...@@ -32,5 +28,4 @@ exec $INNOBACKUPEX --apply-log $targetdir;
--enable_result_log --enable_result_log
select sum(c1) from t1; select sum(c1) from t1;
DROP TABLE t1; DROP TABLE t1;
drop procedure innodb_insert_proc;
rmdir $targetdir; rmdir $targetdir;
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment