pdo_033.phpt 1.2 KB

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