pdo_033.phpt 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. --TEST--
  2. PDO Common: PDO::quote()
  3. --EXTENSIONS--
  4. pdo
  5. --SKIPIF--
  6. <?php
  7. $dir = getenv('REDIR_TEST_DIR');
  8. if (false == $dir) die('skip no driver');
  9. if (!strncasecmp(getenv('PDOTEST_DSN'), 'odbc', strlen('odbc'))) die('skip odbc driver doesn\'t have escape API, use prepared statements');
  10. require_once $dir . 'pdo_test.inc';
  11. PDOTest::skip();
  12. ?>
  13. --FILE--
  14. <?php
  15. if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.__DIR__ . '/../../pdo/tests/');
  16. require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
  17. $db = PDOTest::factory();
  18. $unquoted = ' !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~';
  19. $quoted = $db->quote($unquoted);
  20. $len = strlen($unquoted);
  21. @$db->exec("DROP TABLE test");
  22. $db->query("CREATE TABLE test (t char($len))");
  23. $db->query("INSERT INTO test (t) VALUES($quoted)");
  24. $stmt = $db->prepare('SELECT * from test');
  25. $stmt->execute();
  26. print_r($stmt->fetchAll(PDO::FETCH_ASSOC));
  27. $db->exec("DROP TABLE test");
  28. ?>
  29. --EXPECT--
  30. Array
  31. (
  32. [0] => Array
  33. (
  34. [t] => !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~
  35. )
  36. )