]> granicus.if.org Git - php/commitdiff
Fixed bug #45120 (PDOStatement->execute() returns true then false for same statement).
authorPierrick Charron <pierrick@php.net>
Thu, 3 Dec 2009 15:24:43 +0000 (15:24 +0000)
committerPierrick Charron <pierrick@php.net>
Thu, 3 Dec 2009 15:24:43 +0000 (15:24 +0000)
NEWS
ext/pdo/pdo_stmt.c
ext/pdo_mysql/tests/bug_45120.phpt [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index 0c5153ce291dfaa4b0dbf4ca1e2d983f77aa4e88..b57138c264e2d3ed9f2f11f1aecdddf5ef6c154f 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -14,7 +14,8 @@ PHP                                                                        NEWS
 - Fixed bug #49660 (libxml 2.7.3+ limits text nodes to 10MB). (Felipe)
 - Fixed bug #49472 (Constants defined in Interfaces can be overridden).
   (Felipe)
-
+- Fixed bug #45120 (PDOStatement->execute() returns true then false for same
+  statement). (Pierrick)
 
 27 Nov 2009, PHP 5.2.12RC3
 - Fixed break in the build chain introduced in 5.2.12RC2 (Jani)
index ad38c36fe4ba6f687982ed6793bd77c68f86f1d9..5fb0179994220ece0befd50e6e1dee6117e7a685 100755 (executable)
@@ -509,6 +509,7 @@ static PHP_METHOD(PDOStatement, execute)
                        /* no changes were made */
                        stmt->active_query_string = stmt->query_string;
                        stmt->active_query_stringlen = stmt->query_stringlen;
+                       ret = 1;
                } else if (ret == -1) {
                        /* something broke */
                        PDO_HANDLE_STMT_ERR();
diff --git a/ext/pdo_mysql/tests/bug_45120.phpt b/ext/pdo_mysql/tests/bug_45120.phpt
new file mode 100644 (file)
index 0000000..db5da82
--- /dev/null
@@ -0,0 +1,48 @@
+--TEST--
+Bug #45120 (PDOStatement->execute() returns true then false for same statement)
+--SKIPIF--
+<?php
+if (!extension_loaded('pdo') || !extension_loaded('pdo_mysql')) die('skip not loaded');
+require dirname(__FILE__) . '/config.inc';
+require dirname(__FILE__) . '/../../../ext/pdo/tests/pdo_test.inc';
+PDOTest::skip();
+?>
+--FILE--
+<?php
+require dirname(__FILE__) . '/config.inc';
+require dirname(__FILE__) . '/../../../ext/pdo/tests/pdo_test.inc';
+$db = PDOTest::test_factory(dirname(__FILE__) . '/common.phpt');
+
+function bug_45120($db) {
+
+       $stmt = $db->prepare("SELECT 1 AS 'one'");
+       if (true !== $stmt->execute())
+               printf("[001] Execute has failed: %s\n", var_export($stmt->errorInfo(), true));
+
+       $res = $stmt->fetch(PDO::FETCH_ASSOC);
+       if ($res['one'] != 1)
+               printf("[002] Wrong results: %s\n", var_export($res, true));
+
+       if (true !== $stmt->execute())
+               printf("[003] Execute has failed: %s\n", var_export($stmt->errorInfo(), true));
+
+       $res = $stmt->fetch(PDO::FETCH_ASSOC);
+       if ($res['one'] != 1)
+               printf("[004] Wrong results: %s\n", var_export($res, true));
+
+}
+
+print "Emulated Prepared Statements\n";
+$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 1);
+bug_45120($db);
+
+print "Native Prepared Statements\n";
+$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 0);
+bug_45120($db);
+
+print "done!";
+?>
+--EXPECT--
+Emulated Prepared Statements
+Native Prepared Statements
+done!