]> granicus.if.org Git - php/commitdiff
- Initial release
authorTimm Friebe <thekid@php.net>
Fri, 21 May 2004 19:45:55 +0000 (19:45 +0000)
committerTimm Friebe <thekid@php.net>
Fri, 21 May 2004 19:45:55 +0000 (19:45 +0000)
ext/sybase_ct/tests/bug28354.phpt [new file with mode: 0644]

diff --git a/ext/sybase_ct/tests/bug28354.phpt b/ext/sybase_ct/tests/bug28354.phpt
new file mode 100644 (file)
index 0000000..3ad6c62
--- /dev/null
@@ -0,0 +1,49 @@
+--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= basename(__FILE__, '.php');
+  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)
+>>> Query: exec %s
+int(0)
+string(%s)