bug_39656.phpt 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. --TEST--
  2. PDO Common: Bug #39656 (Crash when calling fetch() on a PDO statement object after closeCursor())
  3. --EXTENSIONS--
  4. pdo
  5. --SKIPIF--
  6. <?php
  7. $dir = getenv('REDIR_TEST_DIR');
  8. if (false == $dir) die('skip no driver');
  9. require_once $dir . 'pdo_test.inc';
  10. PDOTest::skip();
  11. ?>
  12. --FILE--
  13. <?php
  14. if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.__DIR__ . '/../../pdo/tests/');
  15. require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
  16. $db = PDOTest::factory();
  17. @$db->exec("DROP TABLE test");
  18. $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  19. $db->exec("CREATE TABLE test (id INTEGER NOT NULL PRIMARY KEY, usr VARCHAR( 256 ) NOT NULL)");
  20. $db->exec("INSERT INTO test (id, usr) VALUES (1, 'user')");
  21. $stmt = $db->prepare("SELECT * FROM test WHERE id = ?");
  22. $stmt->bindValue(1, 1, PDO::PARAM_INT );
  23. $stmt->execute();
  24. $row = $stmt->fetch();
  25. var_dump( $row );
  26. $stmt->execute();
  27. $stmt->closeCursor();
  28. $row = $stmt->fetch(); // this line will crash CLI
  29. var_dump( $row );
  30. @$db->exec("DROP TABLE test");
  31. echo "Done\n";
  32. ?>
  33. --EXPECT--
  34. array(4) {
  35. ["id"]=>
  36. string(1) "1"
  37. [0]=>
  38. string(1) "1"
  39. ["usr"]=>
  40. string(4) "user"
  41. [1]=>
  42. string(4) "user"
  43. }
  44. bool(false)
  45. Done