<?php /* Utility function for mysqli_set_local_infile*.phpt tests */ function shutdown_clean($file) { if ($file) { unlink($file); } } function check_local_infile_allowed_by_server($link) { if (!$res = mysqli_query($link, 'SHOW VARIABLES LIKE "local_infile"')) return "Cannot check if Server variable 'local_infile' is set to 'ON'"; $row = mysqli_fetch_assoc($res); mysqli_free_result($res); if ('ON' != $row['Value']) return sprintf("Server variable 'local_infile' seems not set to 'ON', found '%s'", $row['Value']); return ""; } function check_local_infile_support($link, $engine, $table_name = 'test') { $res = check_local_infile_allowed_by_server($link); if ($res) { return $res; } if (!mysqli_query($link, sprintf('DROP TABLE IF EXISTS %s', $table_name))) { return "Failed to drop old test table"; } if (!mysqli_query($link, $sql = sprintf('CREATE TABLE %s(id INT, label CHAR(1), PRIMARY KEY(id)) ENGINE=%s', $table_name, $engine))) return "Failed to create test table: $sql"; $file = create_standard_csv(1, false); if (!$file) { mysqli_query($link, sprintf('DROP TABLE IF EXISTS %s', $table_name)); return "Cannot create CSV file"; } if (!@mysqli_query($link, sprintf("LOAD DATA LOCAL INFILE '%s' INTO TABLE %s FIELDS TERMINATED BY ';' OPTIONALLY ENCLOSED BY '\'' LINES TERMINATED BY '\n'", mysqli_real_escape_string($link, $file), $table_name))) { if (1148 == mysqli_errno($link)) { mysqli_query($link, sprintf('DROP TABLE IF EXISTS %s', $table_name)); return "Cannot test LOAD DATA LOCAL INFILE, [1148] The used command is not allowed with this MySQL version"; } else if ($link->errno) { return $link->error; } } mysqli_query($link, sprintf('DROP TABLE IF EXISTS %s', $table_name)); return ""; } function create_standard_csv($offset, $verbose = true) { // create a CVS file $file = tempnam(sys_get_temp_dir(), 'mysqli_test'); if (!$fp = fopen($file, 'w')) { if ($verbose) printf("[%03d + 1] Cannot create CVS file '%s'\n", $offset, $file); return NULL; } else { /* Looks ugly? No, handy if you have crashes... */ register_shutdown_function("shutdown_clean", $file); } if (!fwrite($fp, "97;'x';\n") || !fwrite($fp, "98;'y';\n") || !fwrite($fp, "99;'z';\n")) { if ($verbose) printf("[%03d + 3] Cannot write CVS file '%s'\n", $offset, $file); return NULL; } fclose($fp); if (!chmod($file, 0644)) { if ($verbose) printf("[%03d + 4] Cannot change the file perms of '%s' from 0600 to 0644, MySQL might not be able to read it\n", $offset, $file); return NULL; } return $file; } function try_handler($offset, $link, $file, $handler, $expected = null) { if ('default' == $handler) { mysqli_set_local_infile_default($link); } else if (!mysqli_set_local_infile_handler($link, $handler)) { printf("[%03d] Cannot set infile handler to '%s'\n", $offset, $handler); return false; } printf("Callback set to '%s'\n", $handler); if (!mysqli_query($link, sprintf("DELETE FROM test"))) { printf("[%03d] Cannot remove records, [%d] %s\n", $offset + 1, mysqli_errno($link), mysqli_error($link)); return false; } if (!@mysqli_query($link, sprintf("LOAD DATA LOCAL INFILE '%s' INTO TABLE test FIELDS TERMINATED BY ';' OPTIONALLY ENCLOSED BY '\'' LINES TERMINATED BY '\n'", mysqli_real_escape_string($link, $file)))) { printf("[%03d] LOAD DATA failed, [%d] %s\n", $offset + 2, mysqli_errno($link), mysqli_error($link)); } if (!$res = mysqli_query($link, "SELECT id, label FROM test ORDER BY id")) { printf("[%03d] [%d] %s\n", $offset + 3, mysqli_errno($link), mysqli_error($link)); return false; } if (!is_array($expected)) return true; foreach ($expected as $k => $values) { if (!$tmp = mysqli_fetch_assoc($res)) { printf("[%03d/%d] [%d] '%s'\n", $offset + 4, $k, mysqli_errno($link), mysqli_error($link)); return false; } if ($values['id'] != $tmp['id']) { printf("[%03d/%d] Expecting %s got %s\n", $offset + 5, $k, $values['id'], $tmp['id']); return false; } if ($values['label'] != $tmp['label']) { printf("[%03d/%d] Expecting %s got %s\n", $offset + 6, $k, $values['label'], $tmp['label']); return false; } } if ($res && $tmp = mysqli_fetch_assoc($res)) { printf("[%03d] More results than expected!\n", $offset + 7); do { var_dump($tmp); } while ($tmp = mysqli_fetch_assoc($res)); return false; } if ($res) mysqli_free_result($res); return true; } ?>