mirror of
https://github.com/macintoshplus/mongo-php-driver.git
synced 2026-03-29 04:12:23 +02:00
* 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
60 lines
1.6 KiB
PHP
60 lines
1.6 KiB
PHP
--TEST--
|
|
MongoDB\Driver\Cursor query result iteration through NoRewindIterator
|
|
--SKIPIF--
|
|
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
|
|
<?php skip_if_not_live(); ?>
|
|
<?php skip_if_not_clean(); ?>
|
|
--FILE--
|
|
<?php
|
|
require_once __DIR__ . "/../utils/basic.inc";
|
|
|
|
$manager = create_test_manager();
|
|
|
|
$bulk = new MongoDB\Driver\BulkWrite();
|
|
$bulk->insert(array('_id' => 1, 'x' => 1));
|
|
$bulk->insert(array('_id' => 2, 'x' => 1));
|
|
$manager->executeBulkWrite(NS, $bulk);
|
|
|
|
$cursor = $manager->executeQuery(NS, new MongoDB\Driver\Query(array("x" => 1)));
|
|
|
|
/* IteratorIterator requires either rewind() or next() to be called at least
|
|
* once to populate its current.data pointer, which valid() checks. Since next()
|
|
* would skip the first element and NoRewindIterator::rewind() is a NOP, we must
|
|
* explicitly call IteratorIterator::rewind() before composing it. */
|
|
$iteratorIterator = new IteratorIterator($cursor);
|
|
$iteratorIterator->rewind();
|
|
|
|
$noRewindIterator = new NoRewindIterator($iteratorIterator);
|
|
|
|
foreach ($noRewindIterator as $document) {
|
|
var_dump($document);
|
|
}
|
|
|
|
/* NoRewindIterator::rewind() is a NOP, so attempting to iterate a second time
|
|
* or calling rewind() directly accomplishes nothing. That said, it does avoid
|
|
* the exception one would otherwise get invoking the rewind handler after
|
|
* iteration has started. */
|
|
foreach ($noRewindIterator as $document) {
|
|
var_dump($document);
|
|
}
|
|
|
|
$noRewindIterator->rewind();
|
|
|
|
?>
|
|
===DONE===
|
|
<?php exit(0); ?>
|
|
--EXPECTF--
|
|
object(stdClass)#%d (2) {
|
|
["_id"]=>
|
|
int(1)
|
|
["x"]=>
|
|
int(1)
|
|
}
|
|
object(stdClass)#%d (2) {
|
|
["_id"]=>
|
|
int(2)
|
|
["x"]=>
|
|
int(1)
|
|
}
|
|
===DONE===
|