Files
mongo-php-driver/tests/bson/bug0592.phpt
Andreas Braun deead9687e PHPC-1716 Allow configuring server API version in manager (#1204)
* Introduce MongoDB\Driver\ServerApi

* Accept serverApi driver option

* Introduce create_test_manager factory to create manager

A centralised entry point is required to inject the API_VERSION env variable later.

* Add build variant to test with requireApiVersion=true

* Fix wrong configuration for auth variable

This changed when migrating from our own scripts to drivers-evergreen-tools and was not updated properly, causing all tests to run with auth disabled.

* Declare ZEND_PARSE_PARAMETERS_NONE macro

This macro is missing on PHP < 7.3

* Remove duplicated API param storage

* Add missing semicolons

* Add ZEND_PARSE_PARAMETERS_NON_EX macro

* Extract error handling functionality to separate macros

* Throw if internal mongoc_server_api_t is already initialised

* Use imported namespaces in tools file

* Fix type info for reflection

* Use American English spelling

* Only use typed serialize signature on PHP 8+

* Update PHONGO_PARSE_PARAMETERS_NONE macro for PHP < 7.3

* Remove usage of ZEND_STRL within zend_hash_str_add

This causes compile failures on PHP < 7.3 that I have yet to understand.

* Fix errors in new PHONGO_PARSE_PARAMETERS macros
2021-03-26 15:43:48 +01:00

117 lines
2.7 KiB
PHP

--TEST--
PHPC-592: Property name corrupted when unserializing 64-bit integer on 32-bit platform
--SKIPIF--
<?php if (4 !== PHP_INT_SIZE) { die('skip Only for 32-bit platform'); } ?>
--FILE--
<?php
require_once __DIR__ . '/../utils/basic.inc';
$tests = [
'{ "x": { "$numberLong": "-2147483648" }}',
'{ "x": { "$numberLong": "2147483647" }}',
'{ "x": { "$numberLong": "4294967294" }}',
'{ "x": { "$numberLong": "4294967295" }}',
'{ "x": { "$numberLong": "9223372036854775807" }}',
'{ "longFieldName": { "$numberLong": "-2147483648" }}',
'{ "longFieldName": { "$numberLong": "2147483647" }}',
'{ "longFieldName": { "$numberLong": "4294967294" }}',
'{ "longFieldName": { "$numberLong": "4294967295" }}',
'{ "longFieldName": { "$numberLong": "9223372036854775807" }}',
];
foreach ($tests as $json) {
printf("Test %s\n", $json);
try {
$encoded = toPHP(fromJSON($json));
var_dump( $encoded );
} catch ( MongoDB\Driver\Exception\InvalidArgumentException $e ) {
echo "MongoDB\Driver\Exception\InvalidArgumentException: ", $e->getMessage(), "\n";
}
echo "\n";
}
?>
===DONE===
<?php exit(0); ?>
--EXPECTF--
Test { "x": { "$numberLong": "-2147483648" }}
object(stdClass)#%d (%d) {
["x"]=>
int(-2147483648)
}
Test { "x": { "$numberLong": "2147483647" }}
object(stdClass)#%d (%d) {
["x"]=>
int(2147483647)
}
Test { "x": { "$numberLong": "4294967294" }}
object(stdClass)#%d (%d) {
["x"]=>
object(MongoDB\BSON\Int64)#%d (%d) {
["integer"]=>
string(10) "4294967294"
}
}
Test { "x": { "$numberLong": "4294967295" }}
object(stdClass)#%d (%d) {
["x"]=>
object(MongoDB\BSON\Int64)#%d (%d) {
["integer"]=>
string(10) "4294967295"
}
}
Test { "x": { "$numberLong": "9223372036854775807" }}
object(stdClass)#%d (%d) {
["x"]=>
object(MongoDB\BSON\Int64)#%d (%d) {
["integer"]=>
string(19) "9223372036854775807"
}
}
Test { "longFieldName": { "$numberLong": "-2147483648" }}
object(stdClass)#%d (%d) {
["longFieldName"]=>
int(-2147483648)
}
Test { "longFieldName": { "$numberLong": "2147483647" }}
object(stdClass)#%d (%d) {
["longFieldName"]=>
int(2147483647)
}
Test { "longFieldName": { "$numberLong": "4294967294" }}
object(stdClass)#%d (%d) {
["longFieldName"]=>
object(MongoDB\BSON\Int64)#%d (%d) {
["integer"]=>
string(10) "4294967294"
}
}
Test { "longFieldName": { "$numberLong": "4294967295" }}
object(stdClass)#%d (%d) {
["longFieldName"]=>
object(MongoDB\BSON\Int64)#%d (%d) {
["integer"]=>
string(10) "4294967295"
}
}
Test { "longFieldName": { "$numberLong": "9223372036854775807" }}
object(stdClass)#%d (%d) {
["longFieldName"]=>
object(MongoDB\BSON\Int64)#%d (%d) {
["integer"]=>
string(19) "9223372036854775807"
}
}
===DONE===