mirror of
https://github.com/php/php-src.git
synced 2024-09-22 18:37:25 +00:00
f4a5db3e08
Co-authored-by: George Peter Banyard <girgias@php.net> Co-authored-by: Jorg Adam Sowa <jorg.sowa@gmail.com>
112 lines
2.3 KiB
PHP
112 lines
2.3 KiB
PHP
--TEST--
|
|
PDO Common: Bug #71447 (Quotes inside comments not properly handled)
|
|
--EXTENSIONS--
|
|
pdo
|
|
--SKIPIF--
|
|
<?php
|
|
$dir = getenv('REDIR_TEST_DIR');
|
|
if (false == $dir) die('skip no driver');
|
|
require_once $dir . 'pdo_test.inc';
|
|
PDOTest::skip();
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.__DIR__ . '/../../pdo/tests/');
|
|
require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
|
|
|
|
$db = PDOTest::factory();
|
|
$db->setAttribute (\PDO::ATTR_ERRMODE, \PDO::ERRMODE_WARNING);
|
|
$db->setAttribute (\PDO::ATTR_DEFAULT_FETCH_MODE, \PDO::FETCH_NUM);
|
|
$db->setAttribute (\PDO::ATTR_EMULATE_PREPARES, false);
|
|
$db->exec('CREATE TABLE test71447(id int)');
|
|
$db->exec('INSERT INTO test71447 VALUES(1)');
|
|
|
|
// Comment without quotes or placeholders
|
|
$stmt = $db->prepare("
|
|
SELECT -- That's all folks!
|
|
'\"abc\":8000'
|
|
FROM test71447
|
|
");
|
|
|
|
$stmt->execute();
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
// Comment and placeholder within a string
|
|
$stmt = $db->prepare("
|
|
SELECT
|
|
'\"abc\":8001 -- Wat?'
|
|
FROM test71447
|
|
");
|
|
|
|
$stmt->execute();
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
// Comment with single quote
|
|
$stmt = $db->prepare("
|
|
SELECT -- That's all folks!
|
|
'\"abc\":8002'
|
|
FROM test71447
|
|
");
|
|
|
|
$stmt->execute();
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
// C-Style comment with single quote
|
|
$stmt = $db->prepare("
|
|
SELECT /* That's all folks! */
|
|
'\"abc\":8003'
|
|
FROM test71447
|
|
");
|
|
|
|
$stmt->execute();
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
// Comment with double quote
|
|
$stmt = $db->prepare("
|
|
SELECT -- Is it only \"single quotes?
|
|
'\"abc\":8004'
|
|
FROM test71447
|
|
");
|
|
|
|
$stmt->execute();
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
// Comment with ? placeholder
|
|
$stmt = $db->prepare("
|
|
SELECT -- What about question marks here?
|
|
*
|
|
FROM test71447
|
|
WHERE id = ?
|
|
");
|
|
|
|
$stmt->execute([1]);
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
// Comment with named placeholder
|
|
$stmt = $db->prepare("
|
|
SELECT -- What about placeholders :bar
|
|
*
|
|
FROM test71447
|
|
WHERE id = :id
|
|
");
|
|
|
|
$stmt->execute(['id' => 1]);
|
|
var_dump($stmt->fetchColumn());
|
|
|
|
|
|
?>
|
|
--CLEAN--
|
|
<?php
|
|
require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
|
|
$db = PDOTest::factory();
|
|
PDOTest::dropTableIfExists($db, "test71447");
|
|
?>
|
|
--EXPECT--
|
|
string(10) ""abc":8000"
|
|
string(18) ""abc":8001 -- Wat?"
|
|
string(10) ""abc":8002"
|
|
string(10) ""abc":8003"
|
|
string(10) ""abc":8004"
|
|
string(1) "1"
|
|
string(1) "1"
|