bug_41698.phpt 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. --TEST--
  2. PDO MySQL Bug #41698 (float parameters truncated to integer in prepared statements)
  3. --SKIPIF--
  4. <?php
  5. if (!extension_loaded('pdo') || !extension_loaded('pdo_mysql')) die('skip not loaded');
  6. require dirname(__FILE__) . '/config.inc';
  7. require dirname(__FILE__) . '/../../../ext/pdo/tests/pdo_test.inc';
  8. PDOTest::skip();
  9. ?>
  10. --FILE--
  11. <?php
  12. require dirname(__FILE__) . '/config.inc';
  13. require dirname(__FILE__) . '/../../../ext/pdo/tests/pdo_test.inc';
  14. $db = PDOTest::test_factory(dirname(__FILE__) . '/common.phpt');
  15. setlocale(LC_ALL, "de","de_DE","de_DE.ISO8859-1","de_DE.ISO_8859-1","de_DE.UTF-8");
  16. $db->exec('CREATE TABLE test(floatval DECIMAL(8,6))');
  17. $db->exec('INSERT INTO test VALUES(2.34)');
  18. $value=4.56;
  19. $stmt = $db->prepare('INSERT INTO test VALUES(?)');
  20. $stmt->execute(array($value));
  21. var_dump($db->query('SELECT * from test')->fetchAll(PDO::FETCH_ASSOC));
  22. ?>
  23. --EXPECTF--
  24. array(2) {
  25. [0]=>
  26. array(1) {
  27. [%u|b%"floatval"]=>
  28. %unicode|string%(8) "2.340000"
  29. }
  30. [1]=>
  31. array(1) {
  32. [%u|b%"floatval"]=>
  33. %unicode|string%(8) "4.560000"
  34. }
  35. }