--TEST-- mysqli_set_local_infile_handler() - kill database link --SKIPIF-- <?php require_once('skipif.inc'); require_once('skipifemb.inc'); require_once('skipifconnectfailure.inc'); if (!function_exists('mysqli_set_local_infile_handler')) die("skip - function not available."); require_once('connect.inc'); if (!$link = my_mysqli_connect($host, $user, $passwd, $db, $port, $socket)) die("skip Cannot connect to MySQL"); include_once("local_infile_tools.inc"); if ($msg = check_local_infile_support($link, $engine)) die(sprintf("skip %s, [%d] %s", $msg, $link->errno, $link->error)); mysqli_close($link); ?> --INI-- mysqli.allow_local_infile=1 --FILE-- <?php require("table.inc"); require_once('local_infile_tools.inc'); function callback_kill_link($fp, &$buffer, $buflen, &$error) { global $link; static $invocation = 0; printf("Callback: %d\n", $invocation++); flush(); if (is_object($link)) mysqli_kill($link, mysqli_thread_id($link)); $buffer = "1;'a';\n"; if ($invocation > 10) return 0; mysqli_set_local_infile_default($link); return strlen($buffer); } $file = create_standard_csv(1); $expected = array(array('id' => 1, 'label' => 'a')); try_handler(20, $link, $file, 'callback_kill_link', $expected); mysqli_close($link); print "done!"; ?> --CLEAN-- <?php require_once("clean_table.inc"); ?> --EXPECTF-- Callback set to 'callback_kill_link' Callback: 0 [022] LOAD DATA failed, [2000] Can't execute load data local init callback function done!