diff --git a/.travis.yml b/.travis.yml index 46f7be3..c33fa42 100644 --- a/.travis.yml +++ b/.travis.yml @@ -7,8 +7,8 @@ php: - 7.4 env: - - SYMFONY_VERSION=3.4.0 - - SYMFONY_VERSION=4.0.* + - SYMFONY_VERSION=4.4.0 + - SYMFONY_VERSION=5.*.* before_script: - wget http://getcomposer.org/composer.phar @@ -18,3 +18,8 @@ before_script: script: - bin/coke - bin/atoum + +jobs: + exclude: + - php: 7.1 + env: SYMFONY_VERSION=5.*.* diff --git a/README.md b/README.md index 66d6c84..b304a18 100644 --- a/README.md +++ b/README.md @@ -3,8 +3,9 @@ StatsdBundle [![Build Status](https://travis-ci.org/M6Web/StatsdBundle.png?branc ## Bundle easing the [statsd](https://github.com/etsy/statsd/) usage. -This bundle currently supports `php >=7.1.3` and `symfony 3.4/4.x`. +This bundle currently supports `php >=7.1.3` and `symfony 4.4/5.x`. +If you need support for `symfony 3.4/<4.4`, use version [v3.0.0](https://github.com/M6Web/StatsdBundle/tree/v3.0.0). If you need support for `php >=5.4.0` and `symfony 2.x/3.x`, use version [v2.15.1](https://github.com/M6Web/StatsdBundle/tree/v2.15.1). * [about](doc/about.md) diff --git a/composer.json b/composer.json index 0ac350e..b8dc84a 100644 --- a/composer.json +++ b/composer.json @@ -13,18 +13,24 @@ ], "config": { "bin-dir": "bin", - "vendor-dir": "vendor" + "vendor-dir": "vendor", + "sort-packages": true }, "require": { "php": "^7.1.3", - "symfony/property-access": "^3.4 || ^4.0", + "symfony/property-access": "^4.4 || ^5.0", "m6web/statsd": "^1.3" }, "require-dev": { "atoum/atoum": "^2.8|^3.0", - "symfony/symfony": "^3.4 || ^4.0 || ^5.0", - "m6web/coke" : "~1.2", - "m6web/symfony2-coding-standard" : "~1.2" + "m6web/coke": "~1.2", + "m6web/symfony2-coding-standard": "~1.2", + "symfony/config": "^4.4 || ^5.0", + "symfony/console": "^4.4 || ^5.0", + "symfony/dependency-injection": "^4.4 || ^5.0", + "symfony/event-dispatcher-contracts": "^1.1 || ^2.1", + "symfony/http-foundation": "^4.4 || ^5.0", + "symfony/http-kernel": "^4.4 || ^5.0" }, "autoload": { "psr-4": { diff --git a/doc/usage.md b/doc/usage.md index 56ca842..2ba013d 100644 --- a/doc/usage.md +++ b/doc/usage.md @@ -72,7 +72,7 @@ On the Symfony event dispatcher, when the ```forum.read``` event is fired, our s So you can now just fire the event from a controller : ```php -$this->get('event_dispatcher')->dispatch('forum.read', new Symfony\Component\EventDispatcher\Event()); +$this->get('event_dispatcher')->dispatch(new Symfony\Contracts\EventDispatcher\Event(), 'forum.read'); ``` It's also possible to create tokens in the Symfony configuration, allowing you to pass custom value in the node. diff --git a/src/Client/Client.php b/src/Client/Client.php index 8951fa9..b83dc11 100644 --- a/src/Client/Client.php +++ b/src/Client/Client.php @@ -4,7 +4,6 @@ use M6Web\Bundle\StatsdBundle\Statsd\MonitorableEventInterface; use M6Web\Component\Statsd\Client as BaseClient; -use Symfony\Component\EventDispatcher\GenericEvent; use Symfony\Component\PropertyAccess; /** diff --git a/src/DataCollector/StatsdDataCollector.php b/src/DataCollector/StatsdDataCollector.php index 3a21999..ca34c22 100644 --- a/src/DataCollector/StatsdDataCollector.php +++ b/src/DataCollector/StatsdDataCollector.php @@ -82,9 +82,9 @@ public function addStatsdClient($clientAlias, $statsdClient) * * @param Request $request The request object * @param Response $response The response object - * @param \Exception $exception An exception + * @param \Throwable $exception An exception */ - public function collect(Request $request, Response $response, \Exception $exception = null) + public function collect(Request $request, Response $response, \Throwable $exception = null) { } diff --git a/src/Event/ConsoleEvent.php b/src/Event/ConsoleEvent.php index 3a1895b..c080b32 100644 --- a/src/Event/ConsoleEvent.php +++ b/src/Event/ConsoleEvent.php @@ -2,7 +2,7 @@ namespace M6Web\Bundle\StatsdBundle\Event; use Symfony\Component\Console\Event\ConsoleEvent as BaseConsoleEvent; -use Symfony\Component\EventDispatcher\Event; +use Symfony\Contracts\EventDispatcher\Event; /** * Base console event diff --git a/src/Listener/ConsoleListener.php b/src/Listener/ConsoleListener.php index bacf94a..3793236 100644 --- a/src/Listener/ConsoleListener.php +++ b/src/Listener/ConsoleListener.php @@ -4,7 +4,7 @@ use M6Web\Bundle\StatsdBundle\Event\ConsoleEvent; -use Symfony\Component\EventDispatcher\EventDispatcherInterface; +use Symfony\Contracts\EventDispatcher\EventDispatcherInterface; use Symfony\Component\Console\Event\ConsoleEvent as BaseConsoleEvent; use Symfony\Component\Console\Event\ConsoleTerminateEvent; @@ -43,7 +43,7 @@ public function onCommand(BaseConsoleEvent $e) { $this->startTime = microtime(true); - $this->dispatch(ConsoleEvent::COMMAND, $e); + $this->dispatch($e, ConsoleEvent::COMMAND); } /** @@ -53,10 +53,10 @@ public function onTerminate(ConsoleTerminateEvent $e) { // For non-0 exit command, fire an ERROR event if ($e->getExitCode() != 0) { - $this->dispatch(ConsoleEvent::ERROR, $e); + $this->dispatch($e, ConsoleEvent::ERROR); } - $this->dispatch(ConsoleEvent::TERMINATE, $e); + $this->dispatch($e, ConsoleEvent::TERMINATE); } /** @@ -64,18 +64,18 @@ public function onTerminate(ConsoleTerminateEvent $e) */ public function onException(BaseConsoleEvent $e) { - $this->dispatch(ConsoleEvent::EXCEPTION, $e); + $this->dispatch($e, ConsoleEvent::EXCEPTION); } /** * Dispatch custom event * - * @param string $eventName * @param BaseConsoleEvent $e + * @param string $eventName * * @return boolean */ - protected function dispatch($eventName, BaseConsoleEvent $e) + protected function dispatch(BaseConsoleEvent $e, $eventName) { if (!is_null($this->eventDispatcher)) { $class = str_replace( @@ -90,7 +90,7 @@ protected function dispatch($eventName, BaseConsoleEvent $e) !is_null($this->startTime) ? microtime(true) - $this->startTime : null ); - return $this->eventDispatcher->dispatch($eventName, $finaleEvent); + return $this->eventDispatcher->dispatch($finaleEvent, $eventName); } else { return false; } diff --git a/src/Resources/views/Collector/statsd.html.twig b/src/Resources/views/Collector/statsd.html.twig index 3426f57..20a4879 100644 --- a/src/Resources/views/Collector/statsd.html.twig +++ b/src/Resources/views/Collector/statsd.html.twig @@ -19,9 +19,7 @@ {% block menu %} - {% spaceless %} - Statsd - {% endspaceless %} + Statsd Statsd {{ collector.operations }} diff --git a/src/Statsd/Listener.php b/src/Statsd/Listener.php index 7a3fe76..28d2eac 100644 --- a/src/Statsd/Listener.php +++ b/src/Statsd/Listener.php @@ -3,9 +3,9 @@ namespace M6Web\Bundle\StatsdBundle\Statsd; use Symfony\Component\Console\Event\ConsoleTerminateEvent; -use Symfony\Component\EventDispatcher\EventDispatcherInterface; -use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent; -use Symfony\Component\HttpKernel\Event\PostResponseEvent; +use Symfony\Contracts\EventDispatcher\EventDispatcherInterface; +use Symfony\Component\HttpKernel\Event\ExceptionEvent; +use Symfony\Component\HttpKernel\Event\TerminateEvent; use Symfony\Component\HttpKernel\Exception\HttpExceptionInterface; use M6Web\Component\Statsd\Client; @@ -32,30 +32,30 @@ public function __construct(Client $statsdClient, EventDispatcherInterface $even /** * onKernelException * - * @param GetResponseForExceptionEvent $event + * @param ExceptionEvent $event */ - public function onKernelException(GetResponseForExceptionEvent $event) + public function onKernelException(ExceptionEvent $event) { - $exception = $event->getException(); + $exception = $event->getThrowable(); if ($exception instanceof HttpExceptionInterface) { - $code = $event->getException()->getStatusCode(); + $code = $event->getThrowable()->getStatusCode(); } else { $code = 'unknown'; } $this->eventDispatcher->dispatch( - 'statsd.exception', - new StatsdEvent($code) + new StatsdEvent($code), + 'statsd.exception' ); } /** * method called on the kernel.terminate event * - * @param PostResponseEvent $event event + * @param TerminateEvent $event event * * @return void */ - public function onKernelTerminate(PostResponseEvent $event) + public function onKernelTerminate(TerminateEvent $event) { $this->statsdClient->send(); } @@ -76,9 +76,9 @@ public function onConsoleTerminate(ConsoleTerminateEvent $event) * method called if base_collectors = true in config to dispatch base events * (you still have to catch them) * - * @param PostResponseEvent $event + * @param TerminateEvent $event */ - public function dispatchBaseEvents(PostResponseEvent $event) + public function dispatchBaseEvents(TerminateEvent $event) { $this->dispatchMemory(); $this->dispatchRequestTime($event); @@ -93,8 +93,8 @@ private function dispatchMemory() $memory = ($memory > 1024 ? intval($memory / 1024) : 0); $this->eventDispatcher->dispatch( - 'statsd.memory_usage', - new StatsdEvent($memory) + new StatsdEvent($memory), + 'statsd.memory_usage' ); } @@ -103,9 +103,9 @@ private function dispatchMemory() * This time is a "fake" one, because some actions are performed before the initialization of the request * It is ~100ms smaller than the real kernel time. * - * @param PostResponseEvent $event + * @param TerminateEvent $event */ - private function dispatchRequestTime(PostResponseEvent $event) + private function dispatchRequestTime(TerminateEvent $event) { $request = $event->getRequest(); $startTime = $request->server->get('REQUEST_TIME_FLOAT', $request->server->get('REQUEST_TIME')); @@ -113,8 +113,8 @@ private function dispatchRequestTime(PostResponseEvent $event) $time = round($time * 1000); $this->eventDispatcher->dispatch( - 'statsd.time', - new StatsdEvent($time) + new StatsdEvent($time), + 'statsd.time' ); } } diff --git a/src/Tests/Units/Client/Client.php b/src/Tests/Units/Client/Client.php index c8b5576..76cb73e 100644 --- a/src/Tests/Units/Client/Client.php +++ b/src/Tests/Units/Client/Client.php @@ -35,7 +35,7 @@ public function testHandleEventWithValidConfigIncrement() $client = $this->getMockedClient(); - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $client->addEventToListen('test', array( 'increment' => 'stats.' @@ -59,7 +59,7 @@ public function testHandleEventWithValidConfigDecrement() { $client = $this->getMockedClient(); - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $client->addEventToListen('test', array( 'decrement' => 'stats.' @@ -83,7 +83,7 @@ public function testHandleEventWithImmediateSend() $client = $this->getMockedClient(); - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $client->addEventToListen('test', array( 'increment' => 'stats.', @@ -109,7 +109,7 @@ public function testHandleEventWithToSendLimit() $client = $this->getMockedClient(); $client->setToSendLimit(3); - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $queue = new \SPLQueue; @@ -148,7 +148,7 @@ public function testHandleEventWithInvalidConfigIncrement() )); $this->exception(function () use ($client) { - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $client->handleEvent($event, 'test'); }); @@ -166,7 +166,7 @@ public function testHandleEventWithInvalidEventTiming() )); $this->exception(function () use ($client) { - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $client->handleEvent($event, 'test'); }); @@ -178,7 +178,7 @@ public function testHandleEventWithInvalidEventTiming() )); $this->exception(function () use ($client) { - $event = new \Symfony\Component\EventDispatcher\Event(); + $event = new \Symfony\Contracts\EventDispatcher\Event(); $client->handleEvent($event, 'test'); }); @@ -253,7 +253,7 @@ public function testHandleEventCallsConfiguredTiming() $dispatcher->addListener('test.event.name', [$client, 'handleEvent']); $this - ->if($dispatcher->dispatch('test.event.name', $event)) + ->if($dispatcher->dispatch($event, 'test.event.name')) ->mock($client) ->call('timing') ->withArguments('my.statsd.node', 101, 1.0) @@ -278,7 +278,7 @@ public function testHandleEventDontCallTimingOnUnconfiguredEvent() $dispatcher->addListener('test.event.name', [$client, 'handleEvent']); $this - ->if($dispatcher->dispatch('test.event.other.name', $event)) + ->if($dispatcher->dispatch($event, 'test.event.other.name')) ->mock($client) ->call('timing') ->never(); diff --git a/src/Tests/Units/Client/Event.php b/src/Tests/Units/Client/Event.php index 453bebc..036467d 100644 --- a/src/Tests/Units/Client/Event.php +++ b/src/Tests/Units/Client/Event.php @@ -2,7 +2,7 @@ namespace M6Web\Bundle\StatsdBundle\Tests\Units\Client; -class Event extends \Symfony\Component\EventDispatcher\Event +class Event extends \Symfony\Contracts\EventDispatcher\Event { private $name = ''; diff --git a/src/Tests/Units/DependencyInjection/M6WebStatsdExtension.php b/src/Tests/Units/DependencyInjection/M6WebStatsdExtension.php index 141537b..f1ba377 100644 --- a/src/Tests/Units/DependencyInjection/M6WebStatsdExtension.php +++ b/src/Tests/Units/DependencyInjection/M6WebStatsdExtension.php @@ -19,7 +19,7 @@ class M6WebStatsdExtension extends atoum\test protected function initContainer($resource, $debug = false) { $this->container = new ContainerBuilder(); - $this->container->register('event_dispatcher', new EventDispatcher()); + $this->container->register('event_dispatcher', EventDispatcher::class); $this->container->registerExtension(new BaseM6WebStatsdExtension()); $this->loadConfiguration($this->container, $resource); $this->container->setParameter('kernel.debug', $debug);