summaryrefslogtreecommitdiff
path: root/ext/mysqli/tests/bug73462.phpt
blob: 224c981dfa90123c89b8c9c0429fa2c37fd86fcd (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
--TEST--
Bug #73462 (Persistent connections don't set $connect_errno)
--SKIPIF--
<?php
require_once('skipif.inc');
require_once('skipifconnectfailure.inc');
?>
--FILE--
<?php
    require_once("connect.inc");

    /* Initial persistent connection */
    $mysql_1 = new mysqli('p:'.$host, $user, $passwd, $db);
    $result = $mysql_1->query("SHOW STATUS LIKE 'Connections'");
    $c1 = $result->fetch_row();
    $result->free();
    $mysql_1->close();

    /* Failed connection to invalid host */
    $mysql_2 = @new mysqli(' !!! invalid !!! ', $user, $passwd, $db);
    try {
        $mysql_2->close();
    } catch (Error $exception) {
        echo $exception->getMessage() . "\n";
    }

    /* Re-use persistent connection */
    $mysql_3 = new mysqli('p:'.$host, $user, $passwd, $db);
    $error = mysqli_connect_errno();
    $result = $mysql_3->query("SHOW STATUS LIKE 'Connections'");
    $c3 = $result->fetch_row();
    $result->free();
    $mysql_3->close();

    if (end($c1) !== end($c3))
        printf("[001] Expected '%d' got '%d'.\n", end($c1), end($c3));

    if ($error !== 0)
        printf("[002] Expected '0' got '%d'.\n", $error);

    print "done!";
?>
--EXPECT--
mysqli object is already closed
done!