summaryrefslogtreecommitdiff
path: root/ext/mysqli/tests/mysqli_autocommit_oo.phpt
blob: 3a5a25779ddd4c83be3cd046534f7329e8c56669 (plain)
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
--TEST--
mysqli->autocommit()
--SKIPIF--
<?php
	require_once('skipif.inc');
	require_once('skipifemb.inc');
	require_once('skipifconnectfailure.inc');
	require_once('connect.inc');

	if (!$link = new my_mysqli($host, $user, $passwd, $db, $port, $socket)) {
		printf("skip Cannot connect to the server using host=%s, user=%s, passwd=***, dbname=%s, port=%s, socket=%s\n",
			$host, $user, $db, $port, $socket);
		exit(1);
	}

	if (!have_innodb($link))
		die(sprintf("Needs InnoDB support, [%d] %s", $link->errno, $link->error));
?>
--FILE--
<?php
	require_once("connect.inc");

	if (!$mysqli = new my_mysqli($host, $user, $passwd, $db, $port, $socket)) {
		printf("[001] Cannot connect to the server using host=%s, user=%s, passwd=***, dbname=%s, port=%s, socket=%s\n",
			$host, $user, $db, $port, $socket);
	}

	if (!is_bool($tmp = $mysqli->autocommit(true)))
		printf("[002] Expecting boolean/any, got %s/%s\n", gettype($tmp), $tmp);

	if (!$mysqli->query('SET AUTOCOMMIT = 0'))
		printf("[003] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$res = $mysqli->query('SELECT @@autocommit as auto_commit'))
		printf("[004] [%d] %s\n", $mysqli->errno, $mysqli->error);

	$tmp = $res->fetch_assoc();
	$res->free_result();
	if ($tmp['auto_commit'])
		printf("[005] Cannot turn off autocommit\n");

	if (true !== ($tmp = $mysqli->autocommit( true)))
		printf("[006] Expecting true, got %s/%s\n", gettype($tmp), $tmp);

	if (!$res = $mysqli->query('SELECT @@autocommit as auto_commit'))
		printf("[007] [%d] %s\n", $mysqli->errno, $mysqli->error);
	$tmp = $res->fetch_assoc();
	$res->free_result();
	if (!$tmp['auto_commit'])
		printf("[008] Cannot turn on autocommit\n");

	if (!$mysqli->query('DROP TABLE IF EXISTS test'))
		printf("[009] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$mysqli->query('CREATE TABLE test(id INT) ENGINE = InnoDB')) {
		printf("[010] Cannot create test table, [%d] %s\n", $mysqli->errno, $mysqli->error);
	}

	if (!$mysqli->query('INSERT INTO test(id) VALUES (1)'))
		printf("[011] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$mysqli->query('ROLLBACK'))
		printf("[012] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$res = $mysqli->query('SELECT COUNT(*) AS num FROM test'))
		printf("[013] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if ((!$tmp = $res->fetch_assoc()) || (1 != $tmp['num']))
		printf("[014] Expecting 1 row in table test, found %d rows. [%d] %s\n",
			$tmp['num'], $mysqli->errno, $mysqli->error);

	$res->free_result();

	if (!$mysqli->query('DROP TABLE IF EXISTS test'))
		printf("[015] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$mysqli->query('SET AUTOCOMMIT = 1'))
		printf("[016] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$res = $mysqli->query('SELECT @@autocommit as auto_commit'))
		printf("[017] [%d] %s\n", $mysqli->errno, $mysqli->error);

	$tmp = $res->fetch_assoc();
	$res->free_result();
	if (!$tmp['auto_commit'])
		printf("[018] Cannot turn on autocommit\n");

	if (true !== ($tmp = $mysqli->autocommit( false)))
		printf("[019] Expecting true, got %s/%s\n", gettype($tmp), $tmp);

	if (!$mysqli->query('CREATE TABLE test(id INT) ENGINE = InnoDB')) {
		printf("[020] Cannot create test table, [%d] %s\n", $mysqli->errno, $mysqli->error);
	}

	if (!$mysqli->query('INSERT INTO test(id) VALUES (1)'))
		printf("[021] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$mysqli->query('ROLLBACK'))
		printf("[022] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$res = $mysqli->query('SELECT COUNT(*) AS num FROM test'))
		printf("[023] [%d] %s\n", $mysqli->errno, $mysqli->error);
	$tmp = $res->fetch_assoc();
	if (0 != $tmp['num'])
		printf("[24] Expecting 0 rows in table test, found %d rows\n", $tmp['num']);
	$res->free_result();

	if (!$mysqli->query('INSERT INTO test(id) VALUES (1)'))
		printf("[025] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$mysqli->query('COMMIT'))
		printf("[025] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if (!$res = $mysqli->query('SELECT COUNT(*) AS num FROM test'))
		printf("[027] [%d] %s\n", $mysqli->errno, $mysqli->error);

	if ((!$tmp = $res->fetch_assoc()) || (1 != $tmp['num']))
		printf("[028] Expecting 1 row in table test, found %d rows. [%d] %s\n",
			$tmp['num'], $mysqli->errno, $mysqli->error);
	$res->free_result();

	if (!$mysqli->query('DROP TABLE IF EXISTS test'))
		printf("[029] [%d] %s\n", $mysqli->errno, $mysqli->error);

	$mysqli->close();

	if (NULL !== ($tmp = @$mysqli->autocommit( false)))
		printf("[030] Expecting NULL, got %s/%s\n", gettype($tmp), $tmp);

	print "done!";
?>
--CLEAN--
<?php
	require_once("clean_table.inc");
?>
--EXPECTF--
done!