|
1 | 1 | --TEST--
|
2 |
| -mysqli autocommit/commit/rollback |
| 2 | +mysqli autocommit/commit/rollback with innodb with CACHE |
3 | 3 | --EXTENSIONS--
|
4 | 4 | mysqli
|
5 |
| ---CONFLICTS-- |
6 |
| -mysqli_transactions |
7 | 5 | --SKIPIF--
|
8 | 6 | <?php
|
9 |
| -require_once dirname(__DIR__) . "/connect.inc"; |
10 |
| -if (!$link = @my_mysqli_connect($host, $user, $passwd, $db, $port, $socket)) { |
11 |
| - die(sprintf("skip Can't connect to MySQL Server - [%d] %s", mysqli_connect_errno(), mysqli_connect_error())); |
12 |
| -} |
13 |
| - |
14 |
| -if (!have_innodb($link)) { |
15 |
| - die(sprintf("skip Needs InnoDB support, [%d] %s", $link->errno, $link->error)); |
16 |
| -} |
| 7 | +require_once dirname(__DIR__) . "/test_setup/test_helpers.inc"; |
| 8 | +mysqli_check_innodb_support_skip_test(); |
17 | 9 | ?>
|
18 | 10 | --FILE--
|
19 | 11 | <?php
|
20 |
| -require_once dirname(__DIR__) . "/connect.inc"; |
21 |
| - $link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket); |
22 |
| - |
23 |
| - if (!mysqli_autocommit($link, TRUE)) |
24 |
| - printf("[001] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
25 |
| - |
26 |
| - if (!mysqli_query($link, "DROP TABLE IF EXISTS test")) |
27 |
| - printf("[002] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
28 |
| - |
29 |
| - if (!mysqli_query($link, "CREATE TABLE test(a int, b varchar(10)) engine=InnoDB")) |
30 |
| - printf("[003] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 12 | +require_once dirname(__DIR__) . "/test_setup/test_helpers.inc"; |
31 | 13 |
|
32 |
| - if (!mysqli_query($link, "INSERT INTO test VALUES (1, 'foobar')")) |
33 |
| - printf("[004] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 14 | + $link = default_mysqli_connect(); |
34 | 15 |
|
35 |
| - if (!mysqli_autocommit($link, FALSE)) |
36 |
| - printf("[005] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 16 | + mysqli_autocommit($link, true); |
| 17 | + mysqli_query($link,"CREATE TABLE test_transactions_14(a int, b varchar(10)) Engine=InnoDB"); |
| 18 | + mysqli_query($link, "INSERT INTO test_transactions_14 VALUES (1, 'foobar')"); |
| 19 | + mysqli_autocommit($link, false); |
37 | 20 |
|
38 |
| - if (!mysqli_query($link, "DELETE FROM test")) |
39 |
| - printf("[006] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 21 | + /* Modify data in DB */ |
| 22 | + mysqli_query($link, "DELETE FROM test_transactions_14"); |
| 23 | + mysqli_query($link, "INSERT INTO test_transactions_14 VALUES (2, 'egon')"); |
40 | 24 |
|
41 |
| - if (!mysqli_query($link, "INSERT INTO test VALUES (2, 'egon')")) |
42 |
| - printf("[007] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
43 |
| - |
44 |
| - if (!mysqli_rollback($link)) |
45 |
| - printf("[008] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
46 |
| - |
47 |
| - if (!$result = mysqli_query($link, "SELECT * FROM test")) |
48 |
| - printf("[009] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 25 | + /* Attempt to rollback */ |
| 26 | + mysqli_rollback($link); |
49 | 27 |
|
| 28 | + /* Check if rollback was successful */ |
| 29 | + $result = mysqli_query($link, "SELECT * FROM test_transactions_14"); |
50 | 30 | printf("Num_of_rows=%d\n", mysqli_num_rows($result));
|
51 |
| - if (!$row = mysqli_fetch_row($result)) |
52 |
| - printf("[010] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
53 |
| - |
| 31 | + $row = mysqli_fetch_row($result); |
54 | 32 | mysqli_free_result($result);
|
55 | 33 |
|
56 | 34 | var_dump($row);
|
57 | 35 |
|
58 |
| - if (!mysqli_query($link, "DELETE FROM test")) |
59 |
| - printf("[011] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
60 |
| - |
61 |
| - if (!mysqli_query($link, "INSERT INTO test VALUES (2, 'egon')")) |
62 |
| - printf("[012] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
63 |
| - |
64 |
| - if (!mysqli_commit($link)) |
65 |
| - printf("[012] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
66 |
| - |
67 |
| - if (!$result = mysqli_query($link, "SELECT * FROM test")) |
68 |
| - printf("[013] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 36 | + /* Modify data in DB */ |
| 37 | + mysqli_query($link, "DELETE FROM test_transactions_14"); |
| 38 | + mysqli_query($link, "INSERT INTO test_transactions_14 VALUES (2, 'egon')"); |
69 | 39 |
|
70 |
| - if (!$row = mysqli_fetch_row($result)) |
71 |
| - printf("[014] [%d] %s\n", mysqli_errno($link), mysqli_error($link)); |
| 40 | + /* Commit modifications */ |
| 41 | + mysqli_commit($link); |
72 | 42 |
|
| 43 | + /* Check if commit was successful */ |
| 44 | + $result = mysqli_query($link, "SELECT * FROM test_transactions_14"); |
| 45 | + $row = mysqli_fetch_row($result); |
73 | 46 | mysqli_free_result($result);
|
74 | 47 |
|
75 | 48 | var_dump($row);
|
76 | 49 |
|
77 |
| - mysqli_query($link, "DROP TABLE IF EXISTS test"); |
78 | 50 | mysqli_close($link);
|
79 | 51 | print "done!";
|
80 | 52 | ?>
|
81 | 53 | --CLEAN--
|
82 | 54 | <?php
|
83 |
| -require_once dirname(__DIR__) . "/clean_table.inc"; |
| 55 | +require_once dirname(__DIR__) . "/test_setup/test_helpers.inc"; |
| 56 | +tear_down_table_on_default_connection('test_transactions_14'); |
84 | 57 | ?>
|
85 | 58 | --EXPECT--
|
86 | 59 | Num_of_rows=1
|
|
0 commit comments