xref: /PHP-8.0/ext/pdo_pgsql/tests/bug69344.phpt (revision a5527577)
1--TEST--
2PDO PgSQL Bug #69344 (PDO PgSQL Incorrect binding numeric array with gaps)
3--SKIPIF--
4<?php
5if (!extension_loaded('pdo') || !extension_loaded('pdo_pgsql')) die('skip not loaded');
6require __DIR__ . '/config.inc';
7require __DIR__ . '/../../../ext/pdo/tests/pdo_test.inc';
8PDOTest::skip();
9?>
10--FILE--
11<?php
12
13require __DIR__ . '/../../../ext/pdo/tests/pdo_test.inc';
14$pdo = PDOTest::test_factory(__DIR__ . '/common.phpt');
15$pdo->setAttribute (\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
16$pdo->setAttribute (\PDO::ATTR_DEFAULT_FETCH_MODE, \PDO::FETCH_ASSOC);
17
18$test = function () use ($pdo) {
19    $arr = [
20        0 => "a",
21        2 => "b",
22    ];
23
24    $stmt = $pdo->prepare("SELECT (?)::text AS a, (?)::text AS b");
25
26    try {
27        $stmt->execute($arr);
28        var_dump($stmt->fetch());
29    } catch (\Exception $e) {
30        echo $e->getMessage()."\n";
31    }
32};
33
34$test();
35
36$pdo->setAttribute(\PDO::ATTR_EMULATE_PREPARES, true);
37
38$test();
39
40?>
41--EXPECT--
42SQLSTATE[HY093]: Invalid parameter number: parameter was not defined
43SQLSTATE[HY093]: Invalid parameter number: parameter was not defined
44