gh8626.phpt 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. --TEST--
  2. GH-8626: PDOStatement->execute() failed, then execute successfully, errorInfo() information is incorrect
  3. --SKIPIF--
  4. <?php
  5. if (!extension_loaded('pdo')) die('skip');
  6. $dir = getenv('REDIR_TEST_DIR');
  7. if (false == $dir) die('skip no driver');
  8. require_once $dir . 'pdo_test.inc';
  9. PDOTest::skip();
  10. $db = PDOTest::factory();
  11. if ($db->getAttribute(PDO::ATTR_DRIVER_NAME) == 'oci') {
  12. die("xfail OCI driver errorInfo is inconsistent with other PDO drivers");
  13. }
  14. ?>
  15. --FILE--
  16. <?php
  17. if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.__DIR__ . '/../../pdo/tests/');
  18. require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
  19. $db = PDOTest::factory();
  20. $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT);
  21. $db->exec('DROP TABLE test');
  22. $db->exec('CREATE TABLE test (x int NOT NULL)');
  23. $stmt = $db->prepare('INSERT INTO test VALUES(?)');
  24. // fail
  25. var_dump($stmt->execute([null]), $stmt->errorCode());
  26. $errorInfo = $stmt->errorInfo();
  27. var_dump(array_slice($errorInfo, 0, 3)); // odbc, dblib
  28. $stmt->closeCursor(); // sqlite
  29. // success
  30. var_dump($stmt->execute([1]), $stmt->errorCode());
  31. $errorInfo = $stmt->errorInfo();
  32. var_dump(array_slice($errorInfo, 0, 3)); // odbc, dblib
  33. ?>
  34. ===DONE===
  35. --EXPECTF--
  36. bool(false)
  37. string(%d) "%s"
  38. array(3) {
  39. [0]=>
  40. string(%d) "%s"
  41. [1]=>
  42. int(%d)
  43. [2]=>
  44. string(%d) "%s%w%S"
  45. }
  46. bool(true)
  47. string(5) "00000"
  48. array(3) {
  49. [0]=>
  50. string(5) "00000"
  51. [1]=>
  52. NULL
  53. [2]=>
  54. NULL
  55. }
  56. ===DONE===