|
| 1 | +--TEST-- |
| 2 | +mysqli_pconnect() - COM_RESET_CONNECTION clears session state |
| 3 | +--EXTENSIONS-- |
| 4 | +mysqli |
| 5 | +--SKIPIF-- |
| 6 | +<?php |
| 7 | +require_once 'skipifconnectfailure.inc'; |
| 8 | +?> |
| 9 | +--FILE-- |
| 10 | +<?php |
| 11 | +require_once 'connect.inc'; |
| 12 | + |
| 13 | +$host = 'p:' . $host; |
| 14 | + |
| 15 | +$link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket); |
| 16 | +if (!$link) { |
| 17 | + printf("[001] Cannot connect\n"); |
| 18 | +} |
| 19 | + |
| 20 | +mysqli_query($link, "SET @test_var = 42"); |
| 21 | +mysqli_query($link, "CREATE TEMPORARY TABLE test_reset_tmp (id INT)"); |
| 22 | +mysqli_query($link, "INSERT INTO test_reset_tmp VALUES (1)"); |
| 23 | + |
| 24 | +$res = mysqli_query($link, "SELECT @test_var AS v"); |
| 25 | +$row = mysqli_fetch_assoc($res); |
| 26 | +if ($row['v'] !== '42') { |
| 27 | + printf("[002] Expected 42, got %s\n", $row['v']); |
| 28 | +} |
| 29 | +mysqli_free_result($res); |
| 30 | + |
| 31 | +$thread_id = mysqli_thread_id($link); |
| 32 | +mysqli_close($link); |
| 33 | + |
| 34 | +$link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket); |
| 35 | +if (!$link) { |
| 36 | + printf("[003] Cannot reconnect\n"); |
| 37 | +} |
| 38 | + |
| 39 | +if (mysqli_thread_id($link) !== $thread_id) { |
| 40 | + printf("[004] Got a different connection, persistent reuse did not happen\n"); |
| 41 | +} |
| 42 | + |
| 43 | +$res = mysqli_query($link, "SELECT @test_var AS v"); |
| 44 | +$row = mysqli_fetch_assoc($res); |
| 45 | +if ($row['v'] !== null) { |
| 46 | + printf("[005] Expected NULL after reset, got %s\n", $row['v']); |
| 47 | +} |
| 48 | +mysqli_free_result($res); |
| 49 | + |
| 50 | +$res = mysqli_query($link, "SHOW TABLES LIKE 'test_reset_tmp'"); |
| 51 | +if (mysqli_num_rows($res) !== 0) { |
| 52 | + printf("[006] Temporary table should not exist after reset\n"); |
| 53 | +} |
| 54 | +mysqli_free_result($res); |
| 55 | + |
| 56 | +mysqli_close($link); |
| 57 | + |
| 58 | +echo "done!"; |
| 59 | +?> |
| 60 | +--EXPECT-- |
| 61 | +done! |
0 commit comments