mirror of
https://github.com/macintoshplus/mongo-php-driver.git
synced 2026-04-27 18:43:14 +02:00
deead9687e
* 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
85 lines
1.8 KiB
PHP
85 lines
1.8 KiB
PHP
--TEST--
|
|
MongoDB\Driver\Command with findAndModify and arrayFilters
|
|
--SKIPIF--
|
|
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
|
|
<?php skip_if_not_live(); ?>
|
|
<?php skip_if_server_version('<', '3.6'); ?>
|
|
<?php skip_if_not_clean(); ?>
|
|
--FILE--
|
|
<?php
|
|
require_once __DIR__ . "/../utils/basic.inc";
|
|
|
|
$manager = create_test_manager();
|
|
|
|
$bulk = new MongoDB\Driver\BulkWrite();
|
|
|
|
$bulk->insert([ '_id' => 1, 'grades' => [ 95, 92, 90 ] ]);
|
|
$bulk->insert([ '_id' => 2, 'grades' => [ 98, 100, 102 ] ]);
|
|
$bulk->insert([ '_id' => 3, 'grades' => [ 95, 110, 100 ] ]);
|
|
|
|
$manager->executeBulkWrite(DATABASE_NAME . '.' . COLLECTION_NAME, $bulk);
|
|
|
|
$command = new MongoDB\Driver\Command([
|
|
'findAndModify' => COLLECTION_NAME,
|
|
'query' => ['grades' => [ '$gt' => 100 ] ],
|
|
'update' => ['$set' => [ 'grades.$[element]' => 100 ] ],
|
|
'arrayFilters' => [ [ 'element' => [ '$gt' => 100 ] ] ],
|
|
]);
|
|
|
|
// Running this twice, because findAndModify only updates the first document
|
|
// it finds.
|
|
$manager->executeCommand(DATABASE_NAME, $command);
|
|
$manager->executeCommand(DATABASE_NAME, $command);
|
|
|
|
$cursor = $manager->executeQuery( DATABASE_NAME . '.' . COLLECTION_NAME, new \MongoDB\Driver\Query([]));
|
|
var_dump($cursor->toArray());
|
|
?>
|
|
===DONE===
|
|
<?php exit(0); ?>
|
|
--EXPECTF--
|
|
array(%d) {
|
|
[0]=>
|
|
object(stdClass)#%d (%d) {
|
|
["_id"]=>
|
|
int(1)
|
|
["grades"]=>
|
|
array(%d) {
|
|
[0]=>
|
|
int(95)
|
|
[1]=>
|
|
int(92)
|
|
[2]=>
|
|
int(90)
|
|
}
|
|
}
|
|
[1]=>
|
|
object(stdClass)#%d (%d) {
|
|
["_id"]=>
|
|
int(2)
|
|
["grades"]=>
|
|
array(%d) {
|
|
[0]=>
|
|
int(98)
|
|
[1]=>
|
|
int(100)
|
|
[2]=>
|
|
int(100)
|
|
}
|
|
}
|
|
[2]=>
|
|
object(stdClass)#%d (%d) {
|
|
["_id"]=>
|
|
int(3)
|
|
["grades"]=>
|
|
array(%d) {
|
|
[0]=>
|
|
int(95)
|
|
[1]=>
|
|
int(100)
|
|
[2]=>
|
|
int(100)
|
|
}
|
|
}
|
|
}
|
|
===DONE===
|