diff --git a/src/Agent.php b/src/Agent.php index fdf75c34..b8f8377f 100644 --- a/src/Agent.php +++ b/src/Agent.php @@ -29,6 +29,7 @@ use Scoutapm\Extension\ExtentionCapabilities; use Scoutapm\Extension\PotentiallyAvailableExtensionCapabilities; use Scoutapm\Logger\FilteredLogLevelDecorator; +use Throwable; use function is_string; use function json_encode; use function sprintf; @@ -353,16 +354,19 @@ private function sendMetadataIfRequired() : void return; } - if (! $this->connector->sendCommand(new Metadata( - new DateTimeImmutable('now', new DateTimeZone('UTC')), - $this->config - ))) { - $this->logger->debug('Send command returned false for Metadata'); + try { + $this->connector->sendCommand(new Metadata( + new DateTimeImmutable('now', new DateTimeZone('UTC')), + $this->config + )); - return; + $this->markMetadataSent(); + } catch (Throwable $exception) { + $this->logger->notice( + sprintf('Sending metadata raised an exception: %s', $exception->getMessage()), + ['exception' => $exception] + ); } - - $this->markMetadataSent(); } private function metadataWasSent() : bool diff --git a/tests/Unit/AgentTest.php b/tests/Unit/AgentTest.php index 9e13fb0e..98e0917a 100644 --- a/tests/Unit/AgentTest.php +++ b/tests/Unit/AgentTest.php @@ -4,20 +4,28 @@ namespace Scoutapm\UnitTests; +use OutOfBoundsException; use PHPUnit\Framework\MockObject\MockObject; use PHPUnit\Framework\TestCase; use Psr\Log\LoggerInterface; use Psr\Log\LogLevel; use Psr\Log\NullLogger; +use Psr\Log\Test\TestLogger; use Scoutapm\Agent; +use Scoutapm\Cache\DevNullCache; use Scoutapm\Config; use Scoutapm\Config\ConfigKey; +use Scoutapm\Connector\Connector; +use Scoutapm\Events\Metadata; +use Scoutapm\Events\RegisterMessage; +use Scoutapm\Events\Request\Request; use Scoutapm\Events\Span\Span; use Scoutapm\Events\Tag\TagRequest; use function array_map; use function count; use function end; use function sprintf; +use function uniqid; /** @covers \Scoutapm\Agent */ final class AgentTest extends TestCase @@ -271,6 +279,43 @@ public function testIgnoredEndpoints() : void self::assertFalse($agent->ignored('/bar')); } + public function testMetadataExceptionsAreLogged() : void + { + $logger = new TestLogger(); + $connector = $this->createMock(Connector::class); + + $agent = Agent::fromConfig( + Config::fromArray([ + ConfigKey::APPLICATION_NAME => 'My test app', + ConfigKey::APPLICATION_KEY => uniqid('applicationKey', true), + ConfigKey::MONITORING_ENABLED => true, + ConfigKey::LOG_LEVEL => LogLevel::NOTICE, + ]), + $logger, + new DevNullCache(), + $connector + ); + + $connector->method('connected')->willReturn(true); + + $connector->expects(self::at(1)) + ->method('sendCommand') + ->with(self::isInstanceOf(RegisterMessage::class)) + ->willReturn('{"Register":"success"}'); + $connector->expects(self::at(2)) + ->method('sendCommand') + ->with(self::isInstanceOf(Metadata::class)) + ->willThrowException(new OutOfBoundsException('Some obscure exception happened')); + $connector->expects(self::at(3)) + ->method('sendCommand') + ->with(self::isInstanceOf(Request::class)) + ->willReturn('{"Request":"success"}'); + + $agent->send(); + + self::assertTrue($logger->hasNoticeThatContains('Sending metadata raised an exception: Some obscure exception happened')); + } + /** * Many instrumentation calls are NOOPs when ignore is called. Make sure the sequence works as expected */