summaryrefslogtreecommitdiff
path: root/ext/sybase_ct/tests/bug28354.phpt
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@baserock.org>2013-03-14 05:42:27 +0000
committer <>2013-04-03 16:25:08 +0000
commitc4dd7a1a684490673e25aaf4fabec5df138854c4 (patch)
tree4d57c44caae4480efff02b90b9be86f44bf25409 /ext/sybase_ct/tests/bug28354.phpt
downloadphp2-master.tar.gz
Imported from /home/lorry/working-area/delta_php2/php-5.4.13.tar.bz2.HEADphp-5.4.13master
Diffstat (limited to 'ext/sybase_ct/tests/bug28354.phpt')
-rw-r--r--ext/sybase_ct/tests/bug28354.phpt46
1 files changed, 46 insertions, 0 deletions
diff --git a/ext/sybase_ct/tests/bug28354.phpt b/ext/sybase_ct/tests/bug28354.phpt
new file mode 100644
index 0000000..018f7bd
--- /dev/null
+++ b/ext/sybase_ct/tests/bug28354.phpt
@@ -0,0 +1,46 @@
+--TEST--
+Sybase-CT bug #28354 (sybase_free_result crash)
+--SKIPIF--
+<?php require('skipif.inc'); ?>
+--FILE--
+<?php
+/* This file is part of PHP test framework for ext/sybase_ct
+ *
+ * $Id$
+ */
+
+ require('test.inc');
+
+ $db= sybase_connect_ex();
+ sybase_set_message_handler('sybase_msg_handler');
+ error_reporting(error_reporting() & !E_NOTICE); // Suppress notices
+
+ // Check if stored procedure already exists
+ $sp_name= 'phpt_bug28354';
+ var_dump(sybase_select_db(TEMPDB, $db));
+ if (!sybase_select_single($db, 'select object_id("'.$sp_name.'")')) {
+ echo "Stored procedure {$sp_name} not found, creating\n";
+ var_dump(sybase_query('
+ create proc '.$sp_name.' as begin
+ select @@version
+ end
+ '));
+ } else {
+ echo "Stored procedure {$sp_name} found, using\n";
+ var_dump(TRUE);
+ }
+
+ $r= sybase_query('exec '.$sp_name, $db);
+ $i= 0;
+ while ($row= sybase_fetch_row($r)) {
+ var_dump($i++, $row[0]);
+ }
+ sybase_free_result($r);
+ sybase_close($db);
+?>
+--EXPECTF--
+bool(true)
+Stored procedure %s
+bool(true)
+int(0)
+string(%d) "%s"