xref: /PHP-8.0/ext/pdo/tests/bug_36798.phpt (revision efb901eb)
1--TEST--
2PDO Common: Bug #36798 (Error parsing named parameters with queries containing high-ascii chars)
3--SKIPIF--
4<?php
5if (!extension_loaded('pdo')) die('skip');
6$dir = getenv('REDIR_TEST_DIR');
7if (false == $dir) die('skip no driver');
8require_once $dir . 'pdo_test.inc';
9PDOTest::skip();
10
11if (!strncasecmp(getenv('PDOTEST_DSN'), 'oci', strlen('oci'))){
12    if (!strpos(strtolower(getenv('PDOTEST_DSN')), 'charset=we8mswin1252')) die('skip expected output valid for Oracle with WE8MSWIN1252 character set');
13} elseif (!strncasecmp(getenv('PDOTEST_DSN'), 'dblib', strlen('dblib'))) {
14    die('skip not for pdo_dblib');
15}
16
17?>
18--FILE--
19<?php
20
21if (getenv('REDIR_TEST_DIR') === false) putenv('REDIR_TEST_DIR='.__DIR__ . '/../../pdo/tests/');
22require_once getenv('REDIR_TEST_DIR') . 'pdo_test.inc';
23$db = PDOTest::factory();
24
25@$db->exec("SET NAMES 'LATIN1'"); // needed for PostgreSQL
26$db->exec("CREATE TABLE test (id INTEGER)");
27$db->exec("INSERT INTO test (id) VALUES (1)");
28
29$stmt = $db->prepare("SELECT '�' as test FROM test WHERE id = :id");
30$stmt->execute(array(":id" => 1));
31
32$row = $stmt->fetch(PDO::FETCH_NUM);
33var_dump( $row );
34
35?>
36--EXPECT--
37array(1) {
38  [0]=>
39  string(1) "�"
40}
41