From af1e2741062fa3664cce9ba5de0e8405aa544e24 Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Tue, 5 Dec 2023 09:36:41 +0100 Subject: [PATCH 1/8] Support for Symfony 7 --- composer.json | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/composer.json b/composer.json index 357653c..1189adc 100644 --- a/composer.json +++ b/composer.json @@ -14,18 +14,18 @@ ], "require": { "php": "^7.1 | ^8.0", - "symfony/config": "^3.4|^4.0|^5.0|^6.0", - "symfony/console": "^3.4|^4.0|^5.0|^6.0", - "symfony/dependency-injection": "^3.4|^4.0|^5.0|^6.0", - "symfony/event-dispatcher": "^3.4|^4.0|^5.0|^6.0", - "symfony/http-kernel": "^3.4|^4.0|^5.0|^6.0" + "symfony/config": "^3.4|^4.0|^5.0|^6.0|^7.0", + "symfony/console": "^3.4|^4.0|^5.0|^6.0|^7.0", + "symfony/dependency-injection": "^3.4|^4.0|^5.0|^6.0|^7.0", + "symfony/event-dispatcher": "^3.4|^4.0|^5.0|^6.0|^7.0", + "symfony/http-kernel": "^3.4|^4.0|^5.0|^6.0|^7.0" }, "require-dev": { "matthiasnoback/symfony-dependency-injection-test": "^3.1|^4.0", - "symfony/framework-bundle": "^3.4|^4.0|^5.0|^6.0", - "symfony/phpunit-bridge": "^5.3", + "symfony/framework-bundle": "^3.4|^4.0|^5.0|^6.0|^7.0", + "symfony/phpunit-bridge": "^5.3|^6.0|^7.0", "symfony/debug": ">3.4.21", - "twig/twig": "^1.32|^2.4", + "twig/twig": "^1.32|^2.4|^3.0", "symfony/monolog-bundle": "^3.2" }, "conflict": { From 53c4b4a42147bc8a1f55b465347610c365aabddf Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 29 Apr 2024 12:19:54 +0200 Subject: [PATCH 2/8] Update CI to remove old PHP versions --- .github/workflows/ci.yml | 20 ++++++++++---------- composer.json | 24 ++++++++++-------------- 2 files changed, 20 insertions(+), 24 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 2ec23cd..dc9b240 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -21,7 +21,7 @@ jobs: strategy: fail-fast: false matrix: - php: ['7.1', '7.2', '7.3', '7.4', '8.0'] + php: ['7.4', '8.0', '8.1', '8.2', '8.3'] composer: [''] phpunit: [''] deprecation: [''] @@ -32,25 +32,25 @@ jobs: - php: 8.0 composer: --prefer-stable --prefer-lowest deprecation: max[direct]=0 - - php: 7.1 + - php: 7.4 composer: --prefer-stable --prefer-lowest deprecation: max[direct]=0 # symfony version - - php: 8.0 - symfony: '^3.0' - - php: 8.0 - symfony: '^4.0' - - php: 8.0 - symfony: '^5.0' + - php: 8.3 + symfony: '^5.4' + - php: 8.3 + symfony: '^6.4' + - php: 8.3 + symfony: '^7.0' # dev - - php: 8.0 + - php: 8.3 stability: 'dev' steps: - name: Set up PHP - uses: shivammathur/setup-php@2.7.0 + uses: shivammathur/setup-php@2 with: php-version: ${{ matrix.php }} coverage: none diff --git a/composer.json b/composer.json index 1189adc..a65dc33 100644 --- a/composer.json +++ b/composer.json @@ -13,26 +13,22 @@ } ], "require": { - "php": "^7.1 | ^8.0", - "symfony/config": "^3.4|^4.0|^5.0|^6.0|^7.0", - "symfony/console": "^3.4|^4.0|^5.0|^6.0|^7.0", - "symfony/dependency-injection": "^3.4|^4.0|^5.0|^6.0|^7.0", - "symfony/event-dispatcher": "^3.4|^4.0|^5.0|^6.0|^7.0", - "symfony/http-kernel": "^3.4|^4.0|^5.0|^6.0|^7.0" + "php": "^7.4|^8.0", + "symfony/config": "^5.4|^6.4|^7.0", + "symfony/console": "^5.4|^6.4|^7.0", + "symfony/dependency-injection": "^5.4|^6.4|^7.0", + "symfony/event-dispatcher": "^5.4|^6.4|^7.0", + "symfony/http-kernel": "^5.4|^6.4|^7.0" }, "require-dev": { - "matthiasnoback/symfony-dependency-injection-test": "^3.1|^4.0", - "symfony/framework-bundle": "^3.4|^4.0|^5.0|^6.0|^7.0", + "matthiasnoback/symfony-dependency-injection-test": "^5.1", + "symfony/framework-bundle": "^5.4|^6.4|^7.0", "symfony/phpunit-bridge": "^5.3|^6.0|^7.0", - "symfony/debug": ">3.4.21", "twig/twig": "^1.32|^2.4|^3.0", - "symfony/monolog-bundle": "^3.2" - }, - "conflict": { - "twig/twig": "<1.32" + "symfony/monolog-bundle": "^3.10" }, "suggest": { - "symfony/monolog-bundle": "^3.2" + "symfony/monolog-bundle": "^3.10" }, "autoload": { "psr-4": { "Ekino\\NewRelicBundle\\": "" }, From 0dfd5f9f0241290361c3f7753de681738eef39e0 Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 29 Apr 2024 12:28:15 +0200 Subject: [PATCH 3/8] Try to fix CI --- .github/workflows/ci.yml | 6 +++--- Logging/AdaptiveHandler.php | 3 ++- composer.json | 2 +- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index dc9b240..724e6dc 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -11,13 +11,13 @@ jobs: name: PHP-CS-Fixer runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v4 - name: PHP-CS-Fixer uses: docker://oskarstark/php-cs-fixer-ga build: name: Build - runs-on: Ubuntu-20.04 + runs-on: Ubuntu-22.04 strategy: fail-fast: false matrix: @@ -50,7 +50,7 @@ jobs: steps: - name: Set up PHP - uses: shivammathur/setup-php@2 + uses: shivammathur/setup-php@v2 with: php-version: ${{ matrix.php }} coverage: none diff --git a/Logging/AdaptiveHandler.php b/Logging/AdaptiveHandler.php index 396fa67..1d0ee3a 100644 --- a/Logging/AdaptiveHandler.php +++ b/Logging/AdaptiveHandler.php @@ -14,6 +14,7 @@ namespace Ekino\NewRelicBundle\Logging; use Monolog\Handler\NewRelicHandler; +use Monolog\LogRecord; use Psr\Log\LogLevel; class AdaptiveHandler extends NewRelicHandler @@ -28,7 +29,7 @@ public function __construct( parent::__construct($level, $bubble, $appName, $explodeArrays, $transactionName); } - protected function write(array $record): void + protected function write(LogRecord $record): void { if (!$this->isNewRelicEnabled()) { return; diff --git a/composer.json b/composer.json index a65dc33..8ac55e3 100644 --- a/composer.json +++ b/composer.json @@ -21,7 +21,7 @@ "symfony/http-kernel": "^5.4|^6.4|^7.0" }, "require-dev": { - "matthiasnoback/symfony-dependency-injection-test": "^5.1", + "matthiasnoback/symfony-dependency-injection-test": "^4.3|^5.1", "symfony/framework-bundle": "^5.4|^6.4|^7.0", "symfony/phpunit-bridge": "^5.3|^6.0|^7.0", "twig/twig": "^1.32|^2.4|^3.0", From e6c994a5d0afd945d66723ca7afeebe805d2070a Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 29 Apr 2024 12:48:56 +0200 Subject: [PATCH 4/8] Drop support for PHP < 8.1 for Monolog 3 requirements --- .github/workflows/ci.yml | 9 +++------ composer.json | 2 +- 2 files changed, 4 insertions(+), 7 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 724e6dc..1aa87c8 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -21,7 +21,7 @@ jobs: strategy: fail-fast: false matrix: - php: ['7.4', '8.0', '8.1', '8.2', '8.3'] + php: ['8.1', '8.2', '8.3'] composer: [''] phpunit: [''] deprecation: [''] @@ -29,10 +29,7 @@ jobs: stability: [''] include: # Minimum supported dependencies with the latest and oldest PHP version - - php: 8.0 - composer: --prefer-stable --prefer-lowest - deprecation: max[direct]=0 - - php: 7.4 + - php: 8.1 composer: --prefer-stable --prefer-lowest deprecation: max[direct]=0 @@ -57,7 +54,7 @@ jobs: tools: flex - name: Checkout code - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: Setup stability if: matrix.stability != '' diff --git a/composer.json b/composer.json index 8ac55e3..ff74bcc 100644 --- a/composer.json +++ b/composer.json @@ -13,7 +13,7 @@ } ], "require": { - "php": "^7.4|^8.0", + "php": "^8.1", "symfony/config": "^5.4|^6.4|^7.0", "symfony/console": "^5.4|^6.4|^7.0", "symfony/dependency-injection": "^5.4|^6.4|^7.0", From 23b50471c28a74f9c0890a8e378ee3e2fb0a3a06 Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 6 May 2024 12:53:47 +0200 Subject: [PATCH 5/8] Try to fix PHPUnit tests --- EkinoNewRelicBundle.php | 6 +-- Listener/ExceptionListener.php | 9 +--- Listener/RequestListener.php | 9 +--- Listener/ResponseListener.php | 30 +++--------- Tests/AppKernel.php | 4 +- Tests/BundleInitializationTest.php | 4 +- Tests/Listener/CommandListenerTest.php | 8 ++-- Tests/Listener/DeprecationListenerTest.php | 12 ++--- Tests/Listener/ExceptionListenerTest.php | 6 +-- Tests/Listener/RequestListenerTest.php | 35 +++++++------- Tests/Listener/ResponseListenerTest.php | 56 +++++++++++++--------- 11 files changed, 81 insertions(+), 98 deletions(-) diff --git a/EkinoNewRelicBundle.php b/EkinoNewRelicBundle.php index 3c2b092..5f19205 100644 --- a/EkinoNewRelicBundle.php +++ b/EkinoNewRelicBundle.php @@ -20,14 +20,14 @@ class EkinoNewRelicBundle extends Bundle { - public function build(ContainerBuilder $container) + public function build(ContainerBuilder $container): void { parent::build($container); $container->addCompilerPass(new MonologHandlerPass()); } - public function boot() + public function boot(): void { parent::boot(); @@ -36,7 +36,7 @@ public function boot() } } - public function shutdown() + public function shutdown(): void { if ($this->container->has(DeprecationListener::class)) { $this->container->get(DeprecationListener::class)->unregister(); diff --git a/Listener/ExceptionListener.php b/Listener/ExceptionListener.php index c083859..9facb78 100644 --- a/Listener/ExceptionListener.php +++ b/Listener/ExceptionListener.php @@ -16,7 +16,6 @@ use Ekino\NewRelicBundle\NewRelic\NewRelicInteractorInterface; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Symfony\Component\HttpKernel\Event\ExceptionEvent; -use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent; use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface; use Symfony\Component\HttpKernel\KernelEvents; @@ -44,7 +43,7 @@ public static function getSubscribedEvents(): array */ public function onKernelException(KernelExceptionEvent $event): void { - $exception = method_exists($event, 'getThrowable') ? $event->getThrowable() : $event->getException(); + $exception = $event->getThrowable(); if (!$exception instanceof HttpExceptionInterface) { $this->interactor->noticeThrowable($exception); } @@ -52,9 +51,5 @@ public function onKernelException(KernelExceptionEvent $event): void } if (!class_exists(KernelExceptionEvent::class)) { - if (class_exists(ExceptionEvent::class)) { - class_alias(ExceptionEvent::class, KernelExceptionEvent::class); - } else { - class_alias(GetResponseForExceptionEvent::class, KernelExceptionEvent::class); - } + class_alias(ExceptionEvent::class, KernelExceptionEvent::class); } diff --git a/Listener/RequestListener.php b/Listener/RequestListener.php index f8fa6a8..02d30d7 100644 --- a/Listener/RequestListener.php +++ b/Listener/RequestListener.php @@ -17,7 +17,6 @@ use Ekino\NewRelicBundle\NewRelic\NewRelicInteractorInterface; use Ekino\NewRelicBundle\TransactionNamingStrategy\TransactionNamingStrategyInterface; use Symfony\Component\EventDispatcher\EventSubscriberInterface; -use Symfony\Component\HttpKernel\Event\GetResponseEvent; use Symfony\Component\HttpKernel\Event\RequestEvent; use Symfony\Component\HttpKernel\HttpKernelInterface; use Symfony\Component\HttpKernel\KernelEvents; @@ -112,14 +111,10 @@ public function setIgnoreTransaction(KernelRequestEvent $event): void */ private function isEventValid(KernelRequestEvent $event): bool { - return HttpKernelInterface::MASTER_REQUEST === $event->getRequestType(); + return HttpKernelInterface::MAIN_REQUEST === $event->getRequestType(); } } if (!class_exists(KernelRequestEvent::class)) { - if (class_exists(RequestEvent::class)) { - class_alias(RequestEvent::class, KernelRequestEvent::class); - } else { - class_alias(GetResponseEvent::class, KernelRequestEvent::class); - } + class_alias(RequestEvent::class, KernelRequestEvent::class); } diff --git a/Listener/ResponseListener.php b/Listener/ResponseListener.php index a299abc..26e29a3 100644 --- a/Listener/ResponseListener.php +++ b/Listener/ResponseListener.php @@ -18,30 +18,18 @@ use Ekino\NewRelicBundle\Twig\NewRelicExtension; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Symfony\Component\HttpFoundation\StreamedResponse; -use Symfony\Component\HttpKernel\Event\FilterResponseEvent; use Symfony\Component\HttpKernel\Event\ResponseEvent; use Symfony\Component\HttpKernel\KernelEvents; class ResponseListener implements EventSubscriberInterface { - private $newRelic; - private $interactor; - private $instrument; - private $symfonyCache; - private $newRelicTwigExtension; - public function __construct( - Config $newRelic, - NewRelicInteractorInterface $interactor, - bool $instrument = false, - bool $symfonyCache = false, - NewRelicExtension $newRelicTwigExtension = null + private Config $newRelic, + private NewRelicInteractorInterface $interactor, + private bool $instrument = false, + private bool $symfonyCache = false, + private ?NewRelicExtension $newRelicTwigExtension = null, ) { - $this->newRelic = $newRelic; - $this->interactor = $interactor; - $this->instrument = $instrument; - $this->symfonyCache = $symfonyCache; - $this->newRelicTwigExtension = $newRelicTwigExtension; } public static function getSubscribedEvents(): array @@ -55,7 +43,7 @@ public static function getSubscribedEvents(): array public function onKernelResponse(KernelResponseEvent $event): void { - $isMainRequest = method_exists($event, 'isMainRequest') ? $event->isMainRequest() : $event->isMasterRequest(); + $isMainRequest = $event->isMainRequest(); if (!$isMainRequest) { return; @@ -113,9 +101,5 @@ public function onKernelResponse(KernelResponseEvent $event): void } if (!class_exists(KernelResponseEvent::class)) { - if (class_exists(ResponseEvent::class)) { - class_alias(ResponseEvent::class, KernelResponseEvent::class); - } else { - class_alias(FilterResponseEvent::class, KernelResponseEvent::class); - } + class_alias(ResponseEvent::class, KernelResponseEvent::class); } diff --git a/Tests/AppKernel.php b/Tests/AppKernel.php index 9e3b397..c16f2cd 100644 --- a/Tests/AppKernel.php +++ b/Tests/AppKernel.php @@ -89,7 +89,7 @@ public function registerBundles(): iterable * (From MicroKernelTrait) * {@inheritdoc} */ - public function registerContainerConfiguration(LoaderInterface $loader) + public function registerContainerConfiguration(LoaderInterface $loader): void { $loader->load(function (ContainerBuilder $container) { $container->loadFromExtension('framework', [ @@ -140,7 +140,7 @@ protected function buildContainer(): ContainerBuilder $container = parent::buildContainer(); $container->addCompilerPass(new class() implements CompilerPassInterface { - public function process(ContainerBuilder $container) + public function process(ContainerBuilder $container): void { foreach ($container->getDefinitions() as $id => $definition) { if (preg_match('|Ekino.*|i', $id)) { diff --git a/Tests/BundleInitializationTest.php b/Tests/BundleInitializationTest.php index 27a07a0..256717b 100644 --- a/Tests/BundleInitializationTest.php +++ b/Tests/BundleInitializationTest.php @@ -27,12 +27,12 @@ */ class BundleInitializationTest extends TestCase { - protected function getBundleClass() + protected function getBundleClass(): string { return EkinoNewRelicBundle::class; } - public function testInitBundle() + public function testInitBundle(): void { $kernel = new AppKernel(uniqid('cache')); $kernel->boot(); diff --git a/Tests/Listener/CommandListenerTest.php b/Tests/Listener/CommandListenerTest.php index 9e250bf..af0c79d 100644 --- a/Tests/Listener/CommandListenerTest.php +++ b/Tests/Listener/CommandListenerTest.php @@ -28,7 +28,7 @@ class CommandListenerTest extends TestCase { - public function testCommandMarkedAsBackgroundJob() + public function testCommandMarkedAsBackgroundJob(): void { if (!class_exists('Symfony\Component\Console\Event\ConsoleCommandEvent')) { $this->markTestSkipped('Console Events is only available from Symfony 2.3'); @@ -68,7 +68,7 @@ public function testCommandMarkedAsBackgroundJob() $listener->onConsoleCommand($event); } - public function testIgnoreBackgroundJob() + public function testIgnoreBackgroundJob(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->never())->method('startTransaction'); @@ -84,7 +84,7 @@ public function testIgnoreBackgroundJob() $listener->onConsoleCommand($event); } - public function testConsoleError() + public function testConsoleError(): void { $exception = new \Exception('', 1); @@ -103,7 +103,7 @@ public function testConsoleError() $listener->onConsoleError($event); } - public function testConsoleErrorsWithThrowable() + public function testConsoleErrorsWithThrowable(): void { $exception = new \Error(); diff --git a/Tests/Listener/DeprecationListenerTest.php b/Tests/Listener/DeprecationListenerTest.php index 5354bcf..169f45d 100644 --- a/Tests/Listener/DeprecationListenerTest.php +++ b/Tests/Listener/DeprecationListenerTest.php @@ -20,7 +20,7 @@ class DeprecationListenerTest extends TestCase { - public function testDeprecationIsReported() + public function testDeprecationIsReported(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('noticeThrowable')->with( @@ -39,7 +39,7 @@ public function testDeprecationIsReported() } } - public function testDeprecationIsReportedRegardlessErrorReporting() + public function testDeprecationIsReportedRegardlessErrorReporting(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('noticeThrowable'); @@ -58,7 +58,7 @@ public function testDeprecationIsReportedRegardlessErrorReporting() } } - public function testOtherErrorAreIgnored() + public function testOtherErrorAreIgnored(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->never())->method('noticeThrowable'); @@ -75,7 +75,7 @@ public function testOtherErrorAreIgnored() } } - public function testInitialHandlerIsCalled() + public function testInitialHandlerIsCalled(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('noticeThrowable'); @@ -95,7 +95,7 @@ public function testInitialHandlerIsCalled() } } - public function testUnregisterRemovesHandler() + public function testUnregisterRemovesHandler(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->never())->method('noticeThrowable'); @@ -112,7 +112,7 @@ public function testUnregisterRemovesHandler() } } - public function testUnregisterRestorePreviousHandler() + public function testUnregisterRestorePreviousHandler(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); diff --git a/Tests/Listener/ExceptionListenerTest.php b/Tests/Listener/ExceptionListenerTest.php index a1b59f1..6cb88a4 100644 --- a/Tests/Listener/ExceptionListenerTest.php +++ b/Tests/Listener/ExceptionListenerTest.php @@ -34,14 +34,14 @@ public function testOnKernelException() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); $request = new Request(); - $eventClass = class_exists(ExceptionEvent::class) ? ExceptionEvent::class : GetResponseForExceptionEvent::class; + $eventClass = ExceptionEvent::class; $event = new $eventClass($kernel, $request, HttpKernelInterface::SUB_REQUEST, $exception); $listener = new ExceptionListener($interactor); $listener->onKernelException($event); } - public function testOnKernelExceptionWithHttp() + public function testOnKernelExceptionWithHttp(): void { $exception = new BadRequestHttpException('Boom'); @@ -51,7 +51,7 @@ public function testOnKernelExceptionWithHttp() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); $request = new Request(); - $eventClass = class_exists(ExceptionEvent::class) ? ExceptionEvent::class : GetResponseForExceptionEvent::class; + $eventClass = ExceptionEvent::class; $event = new $eventClass($kernel, $request, HttpKernelInterface::SUB_REQUEST, $exception); $listener = new ExceptionListener($interactor); diff --git a/Tests/Listener/RequestListenerTest.php b/Tests/Listener/RequestListenerTest.php index 72a4bd4..0c061d2 100644 --- a/Tests/Listener/RequestListenerTest.php +++ b/Tests/Listener/RequestListenerTest.php @@ -26,7 +26,7 @@ class RequestListenerTest extends TestCase { - public function testSubRequest() + public function testSubRequest(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->never())->method('setTransactionName'); @@ -35,14 +35,13 @@ public function testSubRequest() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); - $eventClass = class_exists(RequestEvent::class) ? RequestEvent::class : GetResponseEvent::class; - $event = new $eventClass($kernel, new Request(), HttpKernelInterface::SUB_REQUEST, new Response()); + $event = new RequestEvent($kernel, new Request(), HttpKernelInterface::SUB_REQUEST); $listener = new RequestListener(new Config('App name', 'Token'), $interactor, [], [], $namingStrategy); $listener->setApplicationName($event); } - public function testMasterRequest() + public function testMasterRequest(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('setTransactionName'); @@ -54,14 +53,14 @@ public function testMasterRequest() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); - $eventClass = class_exists(RequestEvent::class) ? RequestEvent::class : GetResponseEvent::class; - $event = new $eventClass($kernel, new Request(), HttpKernelInterface::MASTER_REQUEST, new Response()); + $eventClass = RequestEvent::class; + $event = new $eventClass($kernel, new Request(), HttpKernelInterface::MAIN_REQUEST, new Response()); $listener = new RequestListener(new Config('App name', 'Token'), $interactor, [], [], $namingStrategy); $listener->setTransactionName($event); } - public function testPathIsIgnored() + public function testPathIsIgnored(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('ignoreTransaction'); @@ -71,14 +70,14 @@ public function testPathIsIgnored() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); $request = new Request([], [], [], [], [], ['REQUEST_URI' => '/ignored_path']); - $eventClass = class_exists(RequestEvent::class) ? RequestEvent::class : GetResponseEvent::class; - $event = new $eventClass($kernel, $request, HttpKernelInterface::MASTER_REQUEST, new Response()); + $eventClass = RequestEvent::class; + $event = new $eventClass($kernel, $request, HttpKernelInterface::MAIN_REQUEST, new Response()); $listener = new RequestListener(new Config('App name', 'Token'), $interactor, [], ['/ignored_path'], $namingStrategy); $listener->setIgnoreTransaction($event); } - public function testRouteIsIgnored() + public function testRouteIsIgnored(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('ignoreTransaction'); @@ -88,14 +87,14 @@ public function testRouteIsIgnored() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); $request = new Request([], [], ['_route' => 'ignored_route']); - $eventClass = class_exists(RequestEvent::class) ? RequestEvent::class : GetResponseEvent::class; - $event = new $eventClass($kernel, $request, HttpKernelInterface::MASTER_REQUEST, new Response()); + $eventClass = RequestEvent::class; + $event = new $eventClass($kernel, $request, HttpKernelInterface::MAIN_REQUEST, new Response()); $listener = new RequestListener(new Config('App name', 'Token'), $interactor, ['ignored_route'], [], $namingStrategy); $listener->setIgnoreTransaction($event); } - public function testSymfonyCacheEnabled() + public function testSymfonyCacheEnabled(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->once())->method('startTransaction'); @@ -104,14 +103,14 @@ public function testSymfonyCacheEnabled() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); - $eventClass = class_exists(RequestEvent::class) ? RequestEvent::class : GetResponseEvent::class; - $event = new $eventClass($kernel, new Request(), HttpKernelInterface::MASTER_REQUEST, new Response()); + $eventClass = RequestEvent::class; + $event = new $eventClass($kernel, new Request(), HttpKernelInterface::MAIN_REQUEST, new Response()); $listener = new RequestListener(new Config('App name', 'Token'), $interactor, [], [], $namingStrategy, true); $listener->setApplicationName($event); } - public function testSymfonyCacheDisabled() + public function testSymfonyCacheDisabled(): void { $interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); $interactor->expects($this->never())->method('startTransaction'); @@ -120,8 +119,8 @@ public function testSymfonyCacheDisabled() $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); - $eventClass = class_exists(RequestEvent::class) ? RequestEvent::class : GetResponseEvent::class; - $event = new $eventClass($kernel, new Request(), HttpKernelInterface::MASTER_REQUEST, new Response()); + $eventClass = RequestEvent::class; + $event = new $eventClass($kernel, new Request(), HttpKernelInterface::MAIN_REQUEST, new Response()); $listener = new RequestListener(new Config('App name', 'Token'), $interactor, [], [], $namingStrategy, false); $listener->setApplicationName($event); diff --git a/Tests/Listener/ResponseListenerTest.php b/Tests/Listener/ResponseListenerTest.php index b8107d7..05e5c9d 100644 --- a/Tests/Listener/ResponseListenerTest.php +++ b/Tests/Listener/ResponseListenerTest.php @@ -18,14 +18,21 @@ use Ekino\NewRelicBundle\NewRelic\NewRelicInteractorInterface; use Ekino\NewRelicBundle\Twig\NewRelicExtension; use PHPUnit\Framework\TestCase; +use Symfony\Component\HttpFoundation\ParameterBag; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; -use Symfony\Component\HttpKernel\Event\FilterResponseEvent; +use Symfony\Component\HttpFoundation\ResponseHeaderBag; use Symfony\Component\HttpKernel\Event\ResponseEvent; use Symfony\Component\HttpKernel\HttpKernelInterface; class ResponseListenerTest extends TestCase { + private NewRelicInteractorInterface $interactor; + + private Config $newRelic; + + private NewRelicExtension $extension; + protected function setUp(): void { $this->interactor = $this->getMockBuilder(NewRelicInteractorInterface::class)->getMock(); @@ -39,7 +46,7 @@ protected function setUp(): void ->getMock(); } - public function testOnKernelResponseOnlyMasterRequestsAreProcessed() + public function testOnKernelResponseOnlyMasterRequestsAreProcessed(): void { $event = $this->createFilterResponseEventDummy(null, null, HttpKernelInterface::SUB_REQUEST); @@ -49,7 +56,7 @@ public function testOnKernelResponseOnlyMasterRequestsAreProcessed() $this->newRelic->expects($this->never())->method('getCustomMetrics'); } - public function testOnKernelResponseWithOnlyCustomMetricsAndParameters() + public function testOnKernelResponseWithOnlyCustomMetricsAndParameters(): void { $events = [ 'WidgetSale' => [ @@ -103,7 +110,7 @@ public function testOnKernelResponseWithOnlyCustomMetricsAndParameters() $object->onKernelResponse($event); } - public function testOnKernelResponseInstrumentDisabledInRequest() + public function testOnKernelResponseInstrumentDisabledInRequest(): void { $this->setupNoCustomMetricsOrParameters(); @@ -115,7 +122,7 @@ public function testOnKernelResponseInstrumentDisabledInRequest() $object->onKernelResponse($event); } - public function testSymfonyCacheEnabled() + public function testSymfonyCacheEnabled(): void { $this->setupNoCustomMetricsOrParameters(); @@ -127,7 +134,7 @@ public function testSymfonyCacheEnabled() $object->onKernelResponse($event); } - public function testSymfonyCacheDisabled() + public function testSymfonyCacheDisabled(): void { $this->setupNoCustomMetricsOrParameters(); @@ -142,7 +149,7 @@ public function testSymfonyCacheDisabled() /** * @dataProvider providerOnKernelResponseOnlyInstrumentHTMLResponses */ - public function testOnKernelResponseOnlyInstrumentHTMLResponses($content, $expectsSetContent, $contentType) + public function testOnKernelResponseOnlyInstrumentHTMLResponses($content, $expectsSetContent, $contentType): void { $this->setupNoCustomMetricsOrParameters(); @@ -157,7 +164,7 @@ public function testOnKernelResponseOnlyInstrumentHTMLResponses($content, $expec $object->onKernelResponse($event); } - public function providerOnKernelResponseOnlyInstrumentHTMLResponses() + public function providerOnKernelResponseOnlyInstrumentHTMLResponses(): array { return [ // unsupported content types @@ -179,7 +186,7 @@ public function providerOnKernelResponseOnlyInstrumentHTMLResponses() ]; } - public function testInteractionWithTwigExtensionHeader() + public function testInteractionWithTwigExtensionHeader(): void { $this->newRelic->expects($this->never())->method('getCustomMetrics'); $this->newRelic->expects($this->never())->method('getCustomParameters'); @@ -201,7 +208,7 @@ public function testInteractionWithTwigExtensionHeader() $object->onKernelResponse($event); } - public function testInteractionWithTwigExtensionFooter() + public function testInteractionWithTwigExtensionFooter(): void { $this->newRelic->expects($this->never())->method('getCustomMetrics'); $this->newRelic->expects($this->never())->method('getCustomParameters'); @@ -223,7 +230,7 @@ public function testInteractionWithTwigExtensionFooter() $object->onKernelResponse($event); } - public function testInteractionWithTwigExtensionHeaderFooter() + public function testInteractionWithTwigExtensionHeaderFooter(): void { $this->newRelic->expects($this->never())->method('getCustomMetrics'); $this->newRelic->expects($this->never())->method('getCustomParameters'); @@ -245,7 +252,7 @@ public function testInteractionWithTwigExtensionHeaderFooter() $object->onKernelResponse($event); } - private function setUpNoCustomMetricsOrParameters() + private function setUpNoCustomMetricsOrParameters(): void { $this->newRelic->expects($this->once())->method('getCustomEvents')->willReturn([]); $this->newRelic->expects($this->once())->method('getCustomMetrics')->willReturn([]); @@ -256,24 +263,27 @@ private function setUpNoCustomMetricsOrParameters() $this->interactor->expects($this->never())->method('addCustomParameter'); } - private function createRequestMock($instrumentEnabled = true) + private function createRequestMock($instrumentEnabled = true): Request { $mock = $this->getMockBuilder(Request::class) ->setMethods(['get']) ->getMock(); - $mock->attributes = $mock; + $mock->attributes = new ParameterBag(['_instrument' => $instrumentEnabled]); $mock->expects($this->any())->method('get')->willReturn($instrumentEnabled); return $mock; } - private function createResponseMock($content = null, $expectsSetContent = null, $contentType = 'text/html') - { + private function createResponseMock( + $content = null, + $expectsSetContent = null, + $contentType = 'text/html', + ): Response { $mock = $this->getMockBuilder(Response::class) ->setMethods(['get', 'getContent', 'setContent']) ->getMock(); - $mock->headers = $mock; + $mock->headers = new ResponseHeaderBag(['Content-Type' => $contentType]); $mock->expects($this->any())->method('get')->willReturn($contentType); $mock->expects($content ? $this->any() : $this->never())->method('getContent')->willReturn($content ?? false); @@ -287,13 +297,13 @@ private function createResponseMock($content = null, $expectsSetContent = null, return $mock; } - private function createFilterResponseEventDummy(Request $request = null, Response $response = null, int $requestType = HttpKernelInterface::MASTER_REQUEST) - { + private function createFilterResponseEventDummy( + Request $request = null, + Response $response = null, + int $requestType = HttpKernelInterface::MAIN_REQUEST, + ): ResponseEvent { $kernel = $this->getMockBuilder(HttpKernelInterface::class)->getMock(); - $eventClass = class_exists(ResponseEvent::class) ? ResponseEvent::class : FilterResponseEvent::class; - $event = new $eventClass($kernel, $request ?? new Request(), $requestType, $response ?? new Response()); - - return $event; + return new ResponseEvent($kernel, $request ?? new Request(), $requestType, $response ?? new Response()); } } From 035ab6c361214fd0131a1f6f4c8016a29f069bb5 Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 6 May 2024 12:56:22 +0200 Subject: [PATCH 6/8] Try to fix tests --- composer.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/composer.json b/composer.json index ff74bcc..f429ae1 100644 --- a/composer.json +++ b/composer.json @@ -18,7 +18,8 @@ "symfony/console": "^5.4|^6.4|^7.0", "symfony/dependency-injection": "^5.4|^6.4|^7.0", "symfony/event-dispatcher": "^5.4|^6.4|^7.0", - "symfony/http-kernel": "^5.4|^6.4|^7.0" + "symfony/http-kernel": "^5.4|^6.4|^7.0", + "monolog/monolog": "^3.0" }, "require-dev": { "matthiasnoback/symfony-dependency-injection-test": "^4.3|^5.1", From b096bd926eb5d26ba1589b32162718994916dc18 Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 6 May 2024 13:00:22 +0200 Subject: [PATCH 7/8] Drop support for Symfony 5 due to incompatibility with monolog 3 --- .github/workflows/ci.yml | 2 -- Command/NotifyDeploymentCommand.php | 4 +--- composer.json | 12 ++++++------ 3 files changed, 7 insertions(+), 11 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 1aa87c8..1a49a9e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -34,8 +34,6 @@ jobs: deprecation: max[direct]=0 # symfony version - - php: 8.3 - symfony: '^5.4' - php: 8.3 symfony: '^6.4' - php: 8.3 diff --git a/Command/NotifyDeploymentCommand.php b/Command/NotifyDeploymentCommand.php index d6e5ab7..a57b5d0 100644 --- a/Command/NotifyDeploymentCommand.php +++ b/Command/NotifyDeploymentCommand.php @@ -25,15 +25,13 @@ class NotifyDeploymentCommand extends Command public const EXIT_UNAUTHORIZED = 2; public const EXIT_HTTP_ERROR = 3; - protected static $defaultName = 'newrelic:notify-deployment'; - private $newrelic; public function __construct(Config $newrelic) { $this->newrelic = $newrelic; - parent::__construct(); + parent::__construct('newrelic:notify-deployment'); } protected function configure(): void diff --git a/composer.json b/composer.json index f429ae1..b5fa5f1 100644 --- a/composer.json +++ b/composer.json @@ -14,16 +14,16 @@ ], "require": { "php": "^8.1", - "symfony/config": "^5.4|^6.4|^7.0", - "symfony/console": "^5.4|^6.4|^7.0", - "symfony/dependency-injection": "^5.4|^6.4|^7.0", - "symfony/event-dispatcher": "^5.4|^6.4|^7.0", - "symfony/http-kernel": "^5.4|^6.4|^7.0", + "symfony/config": "^6.4|^7.0", + "symfony/console": "^6.4|^7.0", + "symfony/dependency-injection": "^6.4|^7.0", + "symfony/event-dispatcher": "^6.4|^7.0", + "symfony/http-kernel": "^6.4|^7.0", "monolog/monolog": "^3.0" }, "require-dev": { "matthiasnoback/symfony-dependency-injection-test": "^4.3|^5.1", - "symfony/framework-bundle": "^5.4|^6.4|^7.0", + "symfony/framework-bundle": "^6.4|^7.0", "symfony/phpunit-bridge": "^5.3|^6.0|^7.0", "twig/twig": "^1.32|^2.4|^3.0", "symfony/monolog-bundle": "^3.10" From 2cd9951c163bda2d18a1515b43ee574e51aac871 Mon Sep 17 00:00:00 2001 From: Lorenzo Ruozzi Date: Mon, 6 May 2024 14:52:23 +0200 Subject: [PATCH 8/8] Fix deprecations --- Tests/AppKernel.php | 26 ++++++++++++-------------- 1 file changed, 12 insertions(+), 14 deletions(-) diff --git a/Tests/AppKernel.php b/Tests/AppKernel.php index c16f2cd..a9262ae 100644 --- a/Tests/AppKernel.php +++ b/Tests/AppKernel.php @@ -100,21 +100,19 @@ public function registerContainerConfiguration(LoaderInterface $loader): void ], ]); - // Not setting the router to utf8 is deprecated in symfony 5.1 - if (Kernel::VERSION_ID >= 50100) { + // Fix deprecations in symfony 6 + if (Kernel::VERSION_ID >= 60100) { $container->loadFromExtension('framework', [ - 'router' => ['utf8' => true], - ]); - } - - // Not setting the "framework.session.storage_factory_id" configuration option is deprecated in symfony 5.3 - if (Kernel::VERSION_ID >= 50300) { - $container->loadFromExtension('framework', [ - 'session' => ['storage_factory_id' => 'session.storage.factory.mock_file'], - ]); - } else { - $container->loadFromExtension('framework', [ - 'session' => ['storage_id' => 'session.storage.mock_file'], + 'http_method_override' => false, + 'handle_all_throwables' => true, + 'session' => [ + 'cookie_secure' => 'auto', + 'cookie_samesite' => 'lax', + 'handler_id' => null, + ], + 'php_errors' => [ + 'log' => true, + ], ]); }