--TEST-- MongoDB\Driver\Monitoring\ServerHeartbeatSucceededEvent --SKIPIF-- --FILE-- isObserved) { return; } $this->isObserved = true; printf("getDurationMicros() returns an integer: %s\n", is_integer($event->getDurationMicros()) ? 'yes' : 'no'); 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("getReply() returns an object: %s\n", is_object($event->getReply()) ? 'yes' : 'no'); printf("isAwaited() returns a bool: %s\n", is_bool($event->isAwaited()) ? 'yes' : 'no'); var_dump($event); } 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 {} } $m = create_test_manager(); $m->addSubscriber(new MySubscriber); $command = new MongoDB\Driver\Command(['ping' => 1]); $m->executeCommand(DATABASE_NAME, $command); ?> ===DONE=== --EXPECTF-- getDurationMicros() returns an integer: yes getHost() returns a string: yes getPort() returns an integer: yes getReply() returns an object: yes isAwaited() returns a bool: yes object(MongoDB\Driver\Monitoring\ServerHeartbeatSucceededEvent)#%d (%d) { ["host"]=> string(%d) "%s" ["port"]=> int(%d) ["awaited"]=> bool(%s) ["reply"]=> object(stdClass)#%d (%d) {%A } } ===DONE===