관리-도구
편집 파일: serverClosedEvent-001.phpt
--TEST-- MongoDB\Driver\Monitoring\ServerClosedEvent --SKIPIF-- <?php require __DIR__ . "/../utils/basic-skipif.inc"; ?> <?php skip_if_not_load_balanced(); ?> --FILE-- <?php require_once __DIR__ . "/../utils/basic.inc"; class MySubscriber implements MongoDB\Driver\Monitoring\SDAMSubscriber { private $isObserved = false; public function serverChanged(MongoDB\Driver\Monitoring\ServerChangedEvent $event): void {} public function serverClosed(MongoDB\Driver\Monitoring\ServerClosedEvent $event): void { // Ignore multiple events for the purpose of this test if ($this->isObserved) { return; } $this->isObserved = true; printf("getHost() returns a string: %s\n", is_string($event->getHost()) ? 'yes' : 'no'); printf("getPort() returns an integer: %s\n", is_integer($event->getPort()) ? 'yes' : 'no'); printf("getTopologyId() returns an ObjectId: %s\n", ($event->getTopologyId() instanceof MongoDB\BSON\ObjectId) ? 'yes' : 'no'); var_dump($event); } public function serverHeartbeatFailed(MongoDB\Driver\Monitoring\ServerHeartbeatFailedEvent $event): void {} public function serverHeartbeatStarted(MongoDB\Driver\Monitoring\serverHeartbeatStartedEvent $event): void {} public function serverHeartbeatSucceeded(MongoDB\Driver\Monitoring\ServerHeartbeatSucceededEvent $event): void {} public function serverOpening(MongoDB\Driver\Monitoring\ServerOpeningEvent $event): void {} public function topologyChanged(MongoDB\Driver\Monitoring\TopologyChangedEvent $event): void {} public function topologyClosed(MongoDB\Driver\Monitoring\TopologyClosedEvent $event): void {} public function topologyOpening(MongoDB\Driver\Monitoring\TopologyOpeningEvent $event): void {} } /* Note: load balanced topologies will always emit ServerClosedEvent before * TopologyClosedEvent. That is easier than adding a non-member to a replica set * URI. A non-persistent client is used to make observation possible. */ $m = create_test_manager(URI, [], ['disableClientPersistence' => true]); $m->addSubscriber(new MySubscriber); $command = new MongoDB\Driver\Command(['ping' => 1]); $m->executeCommand(DATABASE_NAME, $command); /* Events dispatched during mongoc_client_destroy can only be observed before * RSHUTDOWN. This means that we must use a non-persistent client and free it * before the script ends. */ unset($m); ?> ===DONE=== <?php exit(0); ?> --EXPECTF-- getHost() returns a string: yes getPort() returns an integer: yes getTopologyId() returns an ObjectId: yes object(MongoDB\Driver\Monitoring\ServerClosedEvent)#%d (%d) { ["host"]=> string(%d) "%s" ["port"]=> int(%d) ["topologyId"]=> object(MongoDB\BSON\ObjectId)#%d (%d) { ["oid"]=> string(24) "%x" } } ===DONE===