--TEST-- MongoDB\Driver\BulkWrite::update() PackedArray for arrayFilters option --SKIPIF-- --FILE-- 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(NS, $bulk); $updateBulk = new MongoDB\Driver\BulkWrite(); $updateBulk->update( ['grades' => ['$gte' => 100]], ['$set' => ['grades.$[element]' => 100]], [ 'arrayFilters' => MongoDB\BSON\PackedArray::fromPHP([['element' => ['$gte' => 100]]]), 'multi' => true, ] ); $manager->executeBulkWrite(NS, $updateBulk); $cursor = $manager->executeQuery(NS, new MongoDB\Driver\Query([])); var_dump($cursor->toArray()); ?> ===DONE=== --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===