Annotation of embedaddon/php/ext/pdo/tests/bug_44159.phpt, revision 1.1.1.1
1.1 misho 1: --TEST--
2: Bug #44159 (Crash: $pdo->setAttribute(PDO::STATEMENT_ATTR_CLASS, NULL))
3: --SKIPIF--
4: <?php # vim:ft=php
5: if (!extension_loaded('pdo')) die('skip PDO not available');
6: try {
7: $pdo = new PDO("sqlite:".__DIR__."/foo.db");
8: } catch (Exception $e) {
9: die("skip PDP_SQLITE not available");
10: }
11: ?>
12: --FILE--
13: <?php
14: $pdo = new PDO("sqlite:".__DIR__."/foo.db");
15:
16: $attrs = array(PDO::ATTR_STATEMENT_CLASS, PDO::ATTR_STRINGIFY_FETCHES, PDO::NULL_TO_STRING);
17:
18: foreach ($attrs as $attr) {
19: var_dump($pdo->setAttribute($attr, NULL));
20: var_dump($pdo->setAttribute($attr, 1));
21: var_dump($pdo->setAttribute($attr, 'nonsense'));
22: }
23:
24: @unlink(__DIR__."/foo.db");
25:
26: ?>
27: --EXPECTF--
28: Warning: PDO::setAttribute(): SQLSTATE[HY000]: General error: PDO::ATTR_STATEMENT_CLASS requires format array(classname, array(ctor_args)); the classname must be a string specifying an existing class in %s on line %d
29: bool(false)
30:
31: Warning: PDO::setAttribute(): SQLSTATE[HY000]: General error: PDO::ATTR_STATEMENT_CLASS requires format array(classname, array(ctor_args)); the classname must be a string specifying an existing class in %s on line %d
32: bool(false)
33:
34: Warning: PDO::setAttribute(): SQLSTATE[HY000]: General error: PDO::ATTR_STATEMENT_CLASS requires format array(classname, array(ctor_args)); the classname must be a string specifying an existing class in %s on line %d
35: bool(false)
36:
37: Warning: PDO::setAttribute(): SQLSTATE[HY000]: General error: attribute value must be an integer in %s on line %d
38: bool(false)
39: bool(true)
40: bool(true)
41: bool(true)
42: bool(true)
43: bool(true)
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>