File: group_commit_crash_no_optimize_thread.test

package info (click to toggle)
mariadb 1%3A11.8.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, trixie
  • size: 765,428 kB
  • sloc: ansic: 2,382,827; cpp: 1,803,532; asm: 378,315; perl: 63,176; sh: 46,496; pascal: 40,776; java: 39,363; yacc: 20,428; python: 19,506; sql: 17,864; xml: 12,463; ruby: 8,544; makefile: 6,059; cs: 5,855; ada: 1,700; lex: 1,193; javascript: 1,039; objc: 80; tcl: 73; awk: 46; php: 22
file content (78 lines) | stat: -rw-r--r-- 1,983 bytes parent folder | download | duplicates (4)
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
--source include/have_innodb.inc
# Testing group commit by crashing a few times.
# Test adapted from the Facebook patch: lp:mysqlatfacebook
--source include/not_embedded.inc
# Don't test this under valgrind, memory leaks will occur
--source include/not_valgrind.inc

# Binary must be compiled with debug for crash to occur
--source include/have_debug.inc
--source include/have_log_bin.inc

CREATE TABLE t1(a CHAR(255),
                b CHAR(255),
                c CHAR(255),
                d CHAR(255),
                id INT,
                PRIMARY KEY(id)) ENGINE=InnoDB;
create table t2 like t1;
delimiter //;
create procedure setcrash(IN i INT)
begin
  CASE i
    WHEN 1 THEN SET SESSION debug_dbug="d,crash_commit_after_prepare";
    WHEN 2 THEN SET SESSION debug_dbug="d,crash_commit_after_log";
    WHEN 3 THEN SET SESSION debug_dbug="d,crash_commit_before_unlog";
    WHEN 4 THEN SET SESSION debug_dbug="d,crash_commit_after";
    WHEN 5 THEN SET SESSION debug_dbug="d,crash_commit_before";
    ELSE BEGIN END;
  END CASE;
end //
delimiter ;//
# Avoid getting a crashed mysql.proc table.
FLUSH TABLES;

let $numtests = 5;

let $numinserts = 10;
while ($numinserts)
{
  dec $numinserts;
  eval INSERT INTO t2(a, b, c, d, id) VALUES ('a', 'b', 'c', 'd', 1+$numinserts);
}

--enable_reconnect

while ($numtests)
{
  SET binlog_format= mixed;
  RESET MASTER;

  START TRANSACTION;
  insert into t1 select * from t2;
  # Write file to make mysql-test-run.pl expect crash
  --write_line restart $MYSQLTEST_VARDIR/tmp/mysqld.1.expect

  eval call setcrash($numtests);

  # Run the crashing query
  --error 2006,2013
  COMMIT;

  # Poll the server waiting for it to be back online again.
  --source include/wait_until_connected_again.inc

  # table and binlog should be in sync.
  SELECT * FROM t1 ORDER BY id;
--replace_column 2 # 5 #
  SHOW BINLOG EVENTS LIMIT 4,1;

  delete from t1;

  dec $numtests;
}

# final cleanup
DROP TABLE t1;
DROP TABLE t2;
DROP PROCEDURE setcrash;