mirror of
https://github.com/php/php-src.git
synced 2024-10-21 08:22:42 +00:00
be0793d2e7
pecl#12794, pecl#12401 # Running the tests: # (Note: Doesn't work currnetly on HEAD, see: # http://news.php.net/php.qa/64378) # # PDO_MYSQL_TEST_DSN - DSN # For example: mysql:dbname=test;host=localhost;port=3306 # # PDO_MYSQL_TEST_HOST - database host # PDO_MYSQL_TEST_DB - database (schema) name # PDO_MYSQL_TEST_SOCKET - database server socket # PDO_MYSQL_TEST_ENGINE - storage engine to use # PDO_MYSQL_TEST_USER - database user # PDO_MYSQL_TEST_PASS - database user password # PDO_MYSQL_TEST_CHARSET - database charset # # NOTE: if any of PDO_MYSQL_TEST_[HOST|DB|SOCKET|ENGINE|CHARSET] is # part of PDO_MYSQL_TEST_DSN, the values must match. That is, for example, # for PDO_MYSQL_TEST_DSN = mysql:dbname=test you MUST set PDO_MYSQL_TEST_DB=test.
98 lines
3.4 KiB
PHP
98 lines
3.4 KiB
PHP
--TEST--
|
|
MySQL PDOStatement->fetch(), PDO::FETCH_SERIALIZE
|
|
--SKIPIF--
|
|
<?php
|
|
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'skipif.inc');
|
|
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'mysql_pdo_test.inc');
|
|
MySQLPDOTest::skip();
|
|
if (version_compare(PHP_VERSION, '5.1.0', '<'))
|
|
die("skip Needs 5.1.0 and Interface Serializable");
|
|
?>
|
|
--FILE--
|
|
<?php
|
|
require_once(dirname(__FILE__) . DIRECTORY_SEPARATOR . 'mysql_pdo_test.inc');
|
|
$db = MySQLPDOTest::factory();
|
|
|
|
try {
|
|
|
|
class myclass implements Serializable {
|
|
|
|
public function __construct($caller = null) {
|
|
printf("%s(%s) - note that it must not be called when unserializing\n", __METHOD__, var_export($caller, true));
|
|
}
|
|
|
|
public function __set($prop, $value) {
|
|
printf("%s(%s, %s)\n", __METHOD__, var_export($prop, true), var_export($value, true));
|
|
$this->{$prop} = $value;
|
|
}
|
|
|
|
public function serialize() {
|
|
printf("%s()\n", __METHOD__);
|
|
return 'Value from serialize()';
|
|
}
|
|
|
|
public function unserialize($data) {
|
|
printf("%s(%s)\n", __METHOD__, var_export($data, true));
|
|
}
|
|
|
|
}
|
|
|
|
printf("Lets see what the Serializeable interface makes our object behave like...\n");
|
|
$obj = new myclass('Called by script');
|
|
$tmp = unserialize(serialize($obj));
|
|
var_dump($tmp);
|
|
|
|
printf("\nAnd now magic PDO using fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE)...\n");
|
|
$db->exec('DROP TABLE IF EXISTS test');
|
|
$db->exec(sprintf('CREATE TABLE test(myobj BLOB) ENGINE=%s', MySQLPDOTest::getTableEngine()));
|
|
$db->exec('INSERT INTO test(myobj) VALUES ("Data fetched from DB to be given to unserialize()")');
|
|
|
|
$stmt = $db->prepare('SELECT myobj FROM test');
|
|
$stmt->execute();
|
|
$rows = $stmt->fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE, 'myclass', array('Called by PDO'));
|
|
var_dump($rows[0]);
|
|
|
|
$stmt->execute();
|
|
$rows = $stmt->fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE, 'myclass');
|
|
var_dump($rows[0]);
|
|
|
|
printf("\nAnd now PDO using setFetchMode(PDO::FETCH:CLASS|PDO::FETCH_SERIALIZE) + fetch()...\n");
|
|
$stmt = $db->prepare('SELECT myobj FROM test');
|
|
$stmt->setFetchMode(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE, 'myclass', array('Called by PDO'));
|
|
$stmt->execute();
|
|
var_dump($stmt->fetch());
|
|
|
|
} catch (PDOException $e) {
|
|
printf("[001] %s [%s] %s\n",
|
|
$e->getMessage(), $db->errorCode(), implode(' ', $db->errorInfo()));
|
|
}
|
|
|
|
$db->exec('DROP TABLE IF EXISTS test');
|
|
print "done!\n";
|
|
?>
|
|
--EXPECTF--
|
|
Lets see what the Serializeable interface makes our object behave like...
|
|
myclass::__construct('Called by script') - note that it must not be called when unserializing
|
|
myclass::serialize()
|
|
myclass::unserialize('Value from serialize()')
|
|
object(myclass)#%d (0) {
|
|
}
|
|
|
|
And now magic PDO using fetchAll(PDO::FETCH_CLASS|PDO::FETCH_SERIALIZE)...
|
|
myclass::unserialize('Data fetched from DB to be given to unserialize()')
|
|
myclass::__construct('Called by PDO') - note that it must not be called when unserializing
|
|
object(myclass)#%d (0) {
|
|
}
|
|
myclass::unserialize('Data fetched from DB to be given to unserialize()')
|
|
myclass::__construct(NULL) - note that it must not be called when unserializing
|
|
object(myclass)#%d (0) {
|
|
}
|
|
|
|
And now PDO using setFetchMode(PDO::FETCH:CLASS|PDO::FETCH_SERIALIZE) + fetch()...
|
|
myclass::__set('myobj', 'Data fetched from DB to be given to unserialize()')
|
|
myclass::__construct('Called by PDO') - note that it must not be called when unserializing
|
|
object(myclass)#%d (1) {
|
|
["myobj"]=>
|
|
string(49) "Data fetched from DB to be given to unserialize()"
|
|
}
|
|
done!
|