1--TEST--
2Bug #80107 mysqli_query() fails for ~16 MB long query when compression is enabled
3--SKIPIF--
4<?php
5require_once('skipif.inc');
6require_once('skipifemb.inc');
7require_once("connect.inc");
8$link = @my_mysqli_connect($host, $user, $passwd, $db, $port, $socket);
9if (!$link) {
10    die(sprintf("skip Can't connect to MySQL Server - [%d] %s", mysqli_connect_errno(), mysqli_connect_error()));
11}
12$result = $link->query("SHOW VARIABLES LIKE 'max_allowed_packet'");
13if ($result->fetch_assoc()['Value'] < 0xffffff) {
14    die('skip max_allowed_packet is less than 0xffffff');
15}
16?>
17--FILE--
18<?php
19
20require_once("connect.inc");
21
22$data_size = 16777174;
23
24// Insert with compression disabled:
25
26$mysqli = mysqli_init();
27$result = my_mysqli_real_connect($mysqli, $host, $user, $passwd, $db, $port, $socket);
28$mysqli->query("DROP TABLE IF EXISTS test");
29$mysqli->query("CREATE TABLE test (`blob` LONGBLOB NOT NULL) ENGINE=MyISAM");
30
31$data = str_repeat("x", $data_size);
32$mysqli->query("INSERT INTO $db.test(`blob`) VALUE ('$data')");
33
34var_dump(mysqli_error_list($mysqli));
35$mysqli->close();
36
37// Insert with compression enabled:
38
39$mysqli = mysqli_init();
40$result = my_mysqli_real_connect($mysqli, $host, $user, $passwd, $db, $port, $socket, MYSQLI_CLIENT_COMPRESS);
41
42$data = str_repeat("x", $data_size);
43$mysqli->query("INSERT INTO $db.test(`blob`) VALUE ('$data')");
44
45var_dump(mysqli_error_list($mysqli));
46$mysqli->close();
47
48?>
49--CLEAN--
50<?php
51require_once("clean_table.inc");
52?>
53--EXPECT--
54array(0) {
55}
56array(0) {
57}
58