--TEST-- MongoDB\Driver\Monitoring\TopologyChangedEvent --SKIPIF-- --FILE-- isObserved) { return; } $this->isObserved = true; printf("getTopologyId() returns an ObjectId: %s\n", ($event->getTopologyId() instanceof MongoDB\BSON\ObjectId) ? 'yes' : 'no'); printf("getNewDescription() returns a TopologyDescription: %s\n", ($event->getNewDescription() instanceof MongoDB\Driver\TopologyDescription) ? 'yes' : 'no'); printf("getPreviousDescription() returns a TopologyDescription: %s\n", ($event->getPreviousDescription() instanceof MongoDB\Driver\TopologyDescription) ? 'yes' : 'no'); var_dump($event); } public function topologyClosed(MongoDB\Driver\Monitoring\TopologyClosedEvent $event): void {} public function topologyOpening(MongoDB\Driver\Monitoring\TopologyOpeningEvent $event): void {} } $m = create_test_manager(); $m->addSubscriber(new MySubscriber); $command = new MongoDB\Driver\Command(['ping' => 1]); $m->executeCommand(DATABASE_NAME, $command); ?> ===DONE=== --EXPECTF-- getTopologyId() returns an ObjectId: yes getNewDescription() returns a TopologyDescription: yes getPreviousDescription() returns a TopologyDescription: yes object(MongoDB\Driver\Monitoring\TopologyChangedEvent)#%d (%d) { ["topologyId"]=> object(MongoDB\BSON\ObjectId)#%d (%d) { ["oid"]=> string(24) "%x" } ["newDescription"]=> object(MongoDB\Driver\TopologyDescription)#%d (%d) {%A } ["oldDescription"]=> object(MongoDB\Driver\TopologyDescription)#%d (%d) {%A } } ===DONE===