Files
php-src/ext/pgsql/tests/bug47199.phpt
KentarouTakeda c15988aab3 ext/pgsql: Refactor tests (#12608)
This makes the tests independent of each other and allows them to be run in parallel.

Co-authored-by: Gina Peter Banyard <girgias@php.net>
2023-11-06 22:36:52 +00:00

76 lines
1.6 KiB
PHP

--TEST--
Bug #47199 (pg_delete fails on NULL)
--EXTENSIONS--
pgsql
--SKIPIF--
<?php
require_once('inc/skipif.inc');
?>
--FILE--
<?php
require_once('inc/config.inc');
$dbh = pg_connect($conn_str);
$tbl_name = 'test_47199';
pg_query($dbh, "CREATE TABLE $tbl_name (null_field INT, not_null_field INT NOT NULL)");
pg_insert($dbh, $tbl_name, array('null_field' => null, 'not_null_field' => 1));
pg_insert($dbh, $tbl_name, array('null_field' => null, 'not_null_field' => 2));
var_dump(pg_fetch_all(pg_query($dbh, 'SELECT * FROM '. $tbl_name)));
$query = pg_delete($dbh, $tbl_name, array('null_field' => NULL,'not_null_field' => 2), PGSQL_DML_STRING|PGSQL_DML_EXEC);
echo $query, "\n";
$query = pg_update($dbh, $tbl_name, array('null_field' => NULL, 'not_null_field' => 0), array('not_null_field' => 1, 'null_field' => ''), PGSQL_DML_STRING|PGSQL_DML_EXEC);
echo $query, "\n";
var_dump(pg_fetch_all(pg_query($dbh, 'SELECT * FROM '. $tbl_name)));
pg_close($dbh);
echo PHP_EOL."Done".PHP_EOL;
?>
--CLEAN--
<?php
require_once('inc/config.inc');
$dbh = pg_connect($conn_str);
$tbl_name = 'test_47199';
pg_query($dbh, "DROP TABLE IF EXISTS $tbl_name");
?>
--EXPECT--
array(2) {
[0]=>
array(2) {
["null_field"]=>
NULL
["not_null_field"]=>
string(1) "1"
}
[1]=>
array(2) {
["null_field"]=>
NULL
["not_null_field"]=>
string(1) "2"
}
}
DELETE FROM "test_47199" WHERE "null_field" IS NULL AND "not_null_field"=2;
UPDATE "test_47199" SET "null_field"=NULL,"not_null_field"=0 WHERE "not_null_field"=1 AND "null_field" IS NULL;
array(1) {
[0]=>
array(2) {
["null_field"]=>
NULL
["not_null_field"]=>
string(1) "0"
}
}
Done