php-src/ext/oci8/tests/bug32325.phpt

64 lines
1.1 KiB
Plaintext
Raw Normal View History

2005-09-06 19:33:18 +00:00
--TEST--
2009-10-02 20:16:59 +00:00
Bug #32325 (Cannot retrieve collection using OCI8)
2005-12-06 19:26:57 +00:00
--SKIPIF--
2005-09-06 19:33:18 +00:00
<?php if (!extension_loaded('oci8')) die("skip no oci8 extension"); ?>
--FILE--
<?php
2009-10-02 20:16:59 +00:00
require(dirname(__FILE__).'/connect.inc');
// Initialize
$stmtarray = array(
"create or replace type bug32325_t as table of number"
);
foreach ($stmtarray as $stmt) {
$s = oci_parse($c, $stmt);
$r = @oci_execute($s);
if (!$r) {
$m = oci_error($s);
if (!in_array($m['code'], array( // ignore expected errors
942 // table or view does not exist
))) {
echo $stmt . PHP_EOL . $m['message'] . PHP_EOL;
}
}
}
// Run test
$collection = oci_new_collection($c, "BUG32325_T");
$sql = "begin
select bug32325_t(1,2,3,4) into :list from dual;
2005-09-06 19:33:18 +00:00
end;";
$stmt = oci_parse($c, $sql);
oci_bind_by_name($stmt, ":list", $collection, -1, OCI_B_NTY);
oci_execute($stmt);
var_dump($collection->size());
var_dump($collection->getelem(1));
var_dump($collection->getelem(2));
2009-10-02 20:16:59 +00:00
// Cleanup
$stmtarray = array(
"drop type bug32325_t"
);
foreach ($stmtarray as $stmt) {
$s = oci_parse($c, $stmt);
oci_execute($s);
}
2005-09-06 19:33:18 +00:00
echo "Done\n";
?>
2009-10-02 20:16:59 +00:00
--EXPECT--
2005-09-06 19:33:18 +00:00
int(4)
float(2)
float(3)
Done