Annotation of embedaddon/php/ext/pdo_mysql/tests/bug_39858.phpt, revision 1.1.1.1
1.1 misho 1: --TEST--
2: Bug #39858 (Lost connection to MySQL server during query by a repeated call stored proced)
3: --SKIPIF--
4: <?php
5: if (!extension_loaded('pdo') || !extension_loaded('pdo_mysql')) die('skip not loaded');
6: require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'skipif.inc');
7: require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'mysql_pdo_test.inc');
8: MySQLPDOTest::skip();
9: $db = MySQLPDOTest::factory();
10:
11: $row = $db->query('SELECT VERSION() as _version')->fetch(PDO::FETCH_ASSOC);
12: $matches = array();
13: if (!preg_match('/^(\d+)\.(\d+)\.(\d+)/ismU', $row['_version'], $matches))
14: die(sprintf("skip Cannot determine MySQL Server version\n"));
15:
16: $version = $matches[0] * 10000 + $matches[1] * 100 + $matches[2];
17: if ($version < 50000)
18: die(sprintf("skip Need MySQL Server 5.0.0+, found %d.%02d.%02d (%d)\n",
19: $matches[0], $matches[1], $matches[2], $version));
20: ?>
21: --FILE--
22: <?php
23: require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'mysql_pdo_test.inc');
24: $db = MySQLPDOTest::factory();
25: $db->setAttribute(PDO::ATTR_STRINGIFY_FETCHES, true);
26:
27: function bug_39858($db) {
28:
29: $db->exec("DROP PROCEDURE IF EXISTS p");
30: $db->exec("
31: CREATE PROCEDURE p()
32: NOT DETERMINISTIC
33: CONTAINS SQL
34: SQL SECURITY DEFINER
35: COMMENT ''
36: BEGIN
37: SELECT 2 * 2;
38: END;");
39:
40: $stmt = $db->prepare("CALL p()");
41: $stmt->execute();
42: do {
43: var_dump($stmt->fetchAll(PDO::FETCH_ASSOC));
44: } while ($stmt->nextRowset());
45:
46: $stmt = $db->prepare("CALL p()");
47: $stmt->execute();
48: do {
49: var_dump($stmt->fetchAll(PDO::FETCH_ASSOC));
50: } while ($stmt->nextRowset());
51: $stmt->closeCursor();
52:
53: }
54:
55: printf("Emulated Prepared Statements...\n");
56: $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 1);
57: bug_39858($db);
58:
59: printf("Native Prepared Statements...\n");
60: $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 0);
61: bug_39858($db);
62:
63: print "done!";
64: ?>
65: --CLEAN--
66: <?php
67: require dirname(__FILE__) . '/mysql_pdo_test.inc';
68: $db = MySQLPDOTest::factory();
69: $db->exec("DROP PROCEDURE IF EXISTS p");
70: ?>
71: --EXPECTF--
72: Emulated Prepared Statements...
73: array(1) {
74: [0]=>
75: array(1) {
76: [%u|b%"2 * 2"]=>
77: %unicode|string%(1) "4"
78: }
79: }
80: array(1) {
81: [0]=>
82: array(1) {
83: [%u|b%"2 * 2"]=>
84: %unicode|string%(1) "4"
85: }
86: }
87: Native Prepared Statements...
88: array(1) {
89: [0]=>
90: array(1) {
91: [%u|b%"2 * 2"]=>
92: %unicode|string%(1) "4"
93: }
94: }
95: array(1) {
96: [0]=>
97: array(1) {
98: [%u|b%"2 * 2"]=>
99: %unicode|string%(1) "4"
100: }
101: }
102: done!
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>