mirror of
https://github.com/php/php-src.git
synced 2024-09-22 18:37:25 +00:00
52 lines
1.1 KiB
PHP
52 lines
1.1 KiB
PHP
--TEST--
|
|
Bug #68298 (OCI int overflow)
|
|
--SKIPIF--
|
|
<?php
|
|
if (!extension_loaded('oci8')) die ("skip no oci8 extension");
|
|
if (PHP_INT_SIZE != 8) die("skip this test is for 64bit platforms only");
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
|
|
require(dirname(__FILE__).'/connect.inc');
|
|
|
|
$stmtarray = array(
|
|
"DROP TABLE BUG68298",
|
|
"CREATE TABLE BUG68298 (COL1 NUMBER(20))"
|
|
);
|
|
|
|
oci8_test_sql_execute($c, $stmtarray);
|
|
|
|
$s = oci_parse($c, "INSERT INTO BUG68298 VALUES (:INTVALUE)");
|
|
$intvalue = 1152921504606846975;
|
|
oci_bind_by_name($s, ":INTVALUE", $intvalue, -1, SQLT_INT);
|
|
oci_execute($s);
|
|
|
|
$s = oci_parse($c, "INSERT INTO BUG68298 VALUES (:INTVALUE)");
|
|
$intvalue = -1152921504606846975;
|
|
oci_bind_by_name($s, ":INTVALUE", $intvalue, -1, SQLT_INT);
|
|
oci_execute($s);
|
|
|
|
|
|
$s = oci_parse($c, "SELECT COL1 FROM BUG68298");
|
|
oci_execute($s);
|
|
oci_fetch_all($s, $r);
|
|
var_dump($r);
|
|
|
|
$stmtarray = array("DROP TABLE BUG68298");
|
|
oci8_test_sql_execute($c, $stmtarray);
|
|
?>
|
|
===DONE===
|
|
<?php exit(0); ?>
|
|
--EXPECT--
|
|
array(1) {
|
|
["COL1"]=>
|
|
array(2) {
|
|
[0]=>
|
|
string(19) "1152921504606846975"
|
|
[1]=>
|
|
string(20) "-1152921504606846975"
|
|
}
|
|
}
|
|
===DONE===
|