mirror of
https://github.com/macintoshplus/mongo-php-driver.git
synced 2026-03-25 17:32:28 +01:00
* Remove redundant params in create_test_manager() calls * Use disableClientPersistence in session test requiring different clients
177 lines
5.9 KiB
PHP
177 lines
5.9 KiB
PHP
--TEST--
|
|
MongoDB\Driver\Session spec test: $clusterTime in commands
|
|
--DESCRIPTION--
|
|
Session spec prose test #3: $clusterTime in commands
|
|
https://github.com/mongodb/specifications/blob/master/source/sessions/tests/README.rst#clustertime-in-commands
|
|
--SKIPIF--
|
|
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
|
|
<?php skip_if_not_libmongoc_crypto(); ?>
|
|
<?php skip_if_load_balanced(); /* TODO: CDRIVER-4174 */ ?>
|
|
<?php skip_if_not_replica_set_or_sharded_cluster_with_replica_set(); ?>
|
|
<?php skip_if_not_clean(); ?>
|
|
--FILE--
|
|
<?php
|
|
require_once __DIR__ . "/../utils/basic.inc";
|
|
|
|
class Test implements MongoDB\Driver\Monitoring\CommandSubscriber
|
|
{
|
|
private $lastSeenClusterTime;
|
|
|
|
public function aggregate()
|
|
{
|
|
$this->lastSeenClusterTime = null;
|
|
|
|
MongoDB\Driver\Monitoring\addSubscriber($this);
|
|
|
|
$manager = create_test_manager();
|
|
$session = $manager->startSession();
|
|
|
|
$command = new MongoDB\Driver\Command([
|
|
'aggregate' => COLLECTION_NAME,
|
|
'pipeline' => [],
|
|
'cursor' => new stdClass(),
|
|
]);
|
|
$manager->executeReadWriteCommand(DATABASE_NAME, $command, ['session' => $session]);
|
|
$manager->executeReadWriteCommand(DATABASE_NAME, $command, ['session' => $session]);
|
|
|
|
printf("Session reports last seen \$clusterTime: %s\n", ($session->getClusterTime() == $this->lastSeenClusterTime) ? 'yes' : 'no');
|
|
|
|
MongoDB\Driver\Monitoring\removeSubscriber($this);
|
|
}
|
|
|
|
public function find()
|
|
{
|
|
$this->lastSeenClusterTime = null;
|
|
|
|
MongoDB\Driver\Monitoring\addSubscriber($this);
|
|
|
|
$manager = create_test_manager();
|
|
$session = $manager->startSession();
|
|
|
|
$query = new MongoDB\Driver\Query([]);
|
|
$manager->executeQuery(NS, $query, ['session' => $session]);
|
|
$manager->executeQuery(NS, $query, ['session' => $session]);
|
|
|
|
printf("Session reports last seen \$clusterTime: %s\n", ($session->getClusterTime() == $this->lastSeenClusterTime) ? 'yes' : 'no');
|
|
|
|
MongoDB\Driver\Monitoring\removeSubscriber($this);
|
|
}
|
|
|
|
public function insert()
|
|
{
|
|
$this->lastSeenClusterTime = null;
|
|
|
|
MongoDB\Driver\Monitoring\addSubscriber($this);
|
|
|
|
$manager = create_test_manager();
|
|
$session = $manager->startSession();
|
|
|
|
$bulk = new MongoDB\Driver\BulkWrite();
|
|
$bulk->insert(['x' => 1]);
|
|
$manager->executeBulkWrite(NS, $bulk, ['session' => $session]);
|
|
|
|
$bulk = new MongoDB\Driver\BulkWrite();
|
|
$bulk->insert(['x' => 2]);
|
|
$manager->executeBulkWrite(NS, $bulk, ['session' => $session]);
|
|
|
|
printf("Session reports last seen \$clusterTime: %s\n", ($session->getClusterTime() == $this->lastSeenClusterTime) ? 'yes' : 'no');
|
|
|
|
MongoDB\Driver\Monitoring\removeSubscriber($this);
|
|
}
|
|
|
|
public function ping()
|
|
{
|
|
$this->lastSeenClusterTime = null;
|
|
|
|
MongoDB\Driver\Monitoring\addSubscriber($this);
|
|
|
|
$manager = create_test_manager();
|
|
$session = $manager->startSession();
|
|
|
|
$command = new MongoDB\Driver\Command(['ping' => 1]);
|
|
$manager->executeCommand(DATABASE_NAME, $command, ['session' => $session]);
|
|
$manager->executeCommand(DATABASE_NAME, $command, ['session' => $session]);
|
|
|
|
printf("Session reports last seen \$clusterTime: %s\n", ($session->getClusterTime() == $this->lastSeenClusterTime) ? 'yes' : 'no');
|
|
|
|
MongoDB\Driver\Monitoring\removeSubscriber($this);
|
|
}
|
|
|
|
public function commandStarted(MongoDB\Driver\Monitoring\CommandStartedEvent $event): void
|
|
{
|
|
$command = $event->getCommand();
|
|
$hasClusterTime = isset($command->{'$clusterTime'});
|
|
|
|
printf("%s command includes \$clusterTime: %s\n", $event->getCommandName(), $hasClusterTime ? 'yes' : 'no');
|
|
|
|
if ($hasClusterTime && $this->lastSeenClusterTime !== null) {
|
|
printf("%s command uses last seen \$clusterTime: %s\n", $event->getCommandName(), ($command->{'$clusterTime'} == $this->lastSeenClusterTime) ? 'yes' : 'no');
|
|
}
|
|
}
|
|
|
|
public function commandSucceeded(MongoDB\Driver\Monitoring\CommandSucceededEvent $event): void
|
|
{
|
|
$reply = $event->getReply();
|
|
$hasClusterTime = isset($reply->{'$clusterTime'});
|
|
|
|
printf("%s command reply includes \$clusterTime: %s\n", $event->getCommandName(), $hasClusterTime ? 'yes' : 'no');
|
|
|
|
if ($hasClusterTime) {
|
|
$this->lastSeenClusterTime = $reply->{'$clusterTime'};
|
|
}
|
|
}
|
|
|
|
public function commandFailed(MongoDB\Driver\Monitoring\CommandFailedEvent $event): void
|
|
{
|
|
}
|
|
}
|
|
|
|
echo "\nTesting aggregate command\n";
|
|
(new Test)->aggregate();
|
|
|
|
echo "\nTesting find command\n";
|
|
(new Test)->find();
|
|
|
|
echo "\nTesting insert command\n";
|
|
(new Test)->insert();
|
|
|
|
echo "\nTesting ping command\n";
|
|
(new Test)->ping();
|
|
|
|
?>
|
|
===DONE===
|
|
<?php exit(0); ?>
|
|
--EXPECT--
|
|
Testing aggregate command
|
|
aggregate command includes $clusterTime: yes
|
|
aggregate command reply includes $clusterTime: yes
|
|
aggregate command includes $clusterTime: yes
|
|
aggregate command uses last seen $clusterTime: yes
|
|
aggregate command reply includes $clusterTime: yes
|
|
Session reports last seen $clusterTime: yes
|
|
|
|
Testing find command
|
|
find command includes $clusterTime: yes
|
|
find command reply includes $clusterTime: yes
|
|
find command includes $clusterTime: yes
|
|
find command uses last seen $clusterTime: yes
|
|
find command reply includes $clusterTime: yes
|
|
Session reports last seen $clusterTime: yes
|
|
|
|
Testing insert command
|
|
insert command includes $clusterTime: yes
|
|
insert command reply includes $clusterTime: yes
|
|
insert command includes $clusterTime: yes
|
|
insert command uses last seen $clusterTime: yes
|
|
insert command reply includes $clusterTime: yes
|
|
Session reports last seen $clusterTime: yes
|
|
|
|
Testing ping command
|
|
ping command includes $clusterTime: yes
|
|
ping command reply includes $clusterTime: yes
|
|
ping command includes $clusterTime: yes
|
|
ping command uses last seen $clusterTime: yes
|
|
ping command reply includes $clusterTime: yes
|
|
Session reports last seen $clusterTime: yes
|
|
===DONE===
|