--TEST-- MongoDB\Driver\Session::startTransaction() Committing a transaction with example for how to handle failures --SKIPIF-- --FILE-- executeCommand( DATABASE_NAME, new \MongoDB\Driver\Command([ 'create' => $EMPLOYEES_COL ]), [ 'writeConcern' => new \MongoDB\Driver\WriteConcern( \MongoDB\Driver\WriteConcern::MAJORITY ) ] ); $manager->executeCommand( DATABASE_NAME, new \MongoDB\Driver\Command([ 'create' => $EVENTS_COL ]), [ 'writeConcern' => new \MongoDB\Driver\WriteConcern( \MongoDB\Driver\WriteConcern::MAJORITY ) ] ); /* Do the transaction */ $session = $manager->startSession(); $session->startTransaction( [ 'readConcern' => new \MongoDB\Driver\ReadConcern( "snapshot" ), 'writeConcern' => new \MongoDB\Driver\WriteConcern( \MongoDB\Driver\WriteConcern::MAJORITY ) ] ); while (true) { try { $cmd = new \MongoDB\Driver\Command( [ 'update' => $EMPLOYEES_COL, 'updates' => [ [ 'q' => [ 'employee' => 3 ], 'u' => [ '$set' => [ 'status' => 'Inactive' ] ], ] ] ] ); $manager->executeCommand(DATABASE_NAME, $cmd, ['session' => $session]); $cmd = new \MongoDB\Driver\Command( [ 'insert' => $EVENTS_COL, 'documents' => [ [ 'employee' => 3, 'status' => [ 'new' => 'Inactive', 'old' => 'Active' ] ] ] ] ); $manager->executeCommand(DATABASE_NAME, $cmd, ['session' => $session]); $session->commitTransaction(); echo "Transaction committed.\n";break; } catch (\MongoDB\Driver\Exception\CommandException $e) { $rd = $e->getResultDocument(); if (isset($rd->errorLabels) && in_array('TransientTransactionError', $rd->errorLabels)) { echo "Temporary error: ", $e->getMessage(), ", retrying...\n"; $rd = $e->getResultDocument(); var_dump($rd); continue; } else { var_dump($e); } break; } } ?> ===DONE=== --EXPECTF-- Transaction committed. ===DONE===