diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index bbbd800..031cede 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -15,13 +15,16 @@ jobs: - 8.1 symfony-version: - 4.4.* - - 5.3.* - 5.4.* include: - php-version: 7.1 symfony-version: 4.4.* - php-version: 8.1 symfony-version: 6.0.* + - php-version: 8.2 + symfony-version: 5.4.* + - php-version: 8.2 + symfony-version: 6.0.* steps: - uses: actions/checkout@v2 diff --git a/.gitignore b/.gitignore index bdf7918..25aa5d6 100644 --- a/.gitignore +++ b/.gitignore @@ -6,3 +6,4 @@ vendor/ bin/ .php-cs-fixer.cache composer.lock +phpstan.neon diff --git a/composer.json b/composer.json index 1026dbf..766d376 100644 --- a/composer.json +++ b/composer.json @@ -30,7 +30,7 @@ "require-dev": { "atoum/atoum": "^3.4 || ^4.0", "m6web/php-cs-fixer-config": "2.1.0", - "phpstan/phpstan": "1.4.10", + "phpstan/phpstan": "^1.4.10", "symfony/console": "^4.4 || ^5.0 || ^6.0", "symfony/http-foundation": "^4.4 || ^5.0 || ^6.0" }, diff --git a/phpstan-baseline.neon b/phpstan-baseline.neon new file mode 100644 index 0000000..201ca99 --- /dev/null +++ b/phpstan-baseline.neon @@ -0,0 +1,102 @@ +parameters: + ignoreErrors: + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:addEventToListen\\(\\) has parameter \\$eventConfig with no value type specified in iterable type array\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:addTiming\\(\\) has parameter \\$tags with no value type specified in iterable type array\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:getEventValue\\(\\) has no return type specified\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:getListenedEvents\\(\\) return type has no value type specified in iterable type array\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:mergeTags\\(\\) has parameter \\$config with no value type specified in iterable type array\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:mergeTags\\(\\) has parameter \\$event with no type specified\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:mergeTags\\(\\) return type has no value type specified in iterable type array\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Property M6Web\\\\Bundle\\\\StatsdBundle\\\\Client\\\\Client\\:\\:\\$listenedEvents type has no value type specified in iterable type array\\.$#" + count: 1 + path: src/Client/Client.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\DataCollector\\\\StatsdDataCollector\\:\\:getClients\\(\\) return type has no value type specified in iterable type array\\.$#" + count: 1 + path: src/DataCollector/StatsdDataCollector.php + + - + message: "#^Property M6Web\\\\Bundle\\\\StatsdBundle\\\\DataCollector\\\\StatsdDataCollector\\:\\:\\$statsdClients type has no value type specified in iterable type array\\.$#" + count: 1 + path: src/DataCollector/StatsdDataCollector.php + + - + message: "#^Call to an undefined method Symfony\\\\Component\\\\Config\\\\Definition\\\\Builder\\\\NodeDefinition\\:\\:children\\(\\)\\.$#" + count: 2 + path: src/DependencyInjection/Configuration.php + + - + message: "#^Call to an undefined method Symfony\\\\Component\\\\Config\\\\Definition\\\\Builder\\\\NodeParentInterface\\:\\:booleanNode\\(\\)\\.$#" + count: 1 + path: src/DependencyInjection/Configuration.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\DependencyInjection\\\\M6WebStatsdExtension\\:\\:load\\(\\) has parameter \\$configs with no value type specified in iterable type array\\.$#" + count: 1 + path: src/DependencyInjection/M6WebStatsdExtension.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\DependencyInjection\\\\M6WebStatsdExtension\\:\\:loadClient\\(\\) has parameter \\$config with no value type specified in iterable type array\\.$#" + count: 1 + path: src/DependencyInjection/M6WebStatsdExtension.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\DependencyInjection\\\\M6WebStatsdExtension\\:\\:loadClient\\(\\) has parameter \\$servers with no value type specified in iterable type array\\.$#" + count: 1 + path: src/DependencyInjection/M6WebStatsdExtension.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Event\\\\ConsoleEvent\\:\\:__call\\(\\) has no return type specified\\.$#" + count: 1 + path: src/Event/ConsoleEvent.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Event\\\\ConsoleEvent\\:\\:__call\\(\\) has parameter \\$parameters with no value type specified in iterable type array\\.$#" + count: 1 + path: src/Event/ConsoleEvent.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Statsd\\\\MonitorableEventInterface\\:\\:getValue\\(\\) has no return type specified\\.$#" + count: 1 + path: src/Statsd/MonitorableEventInterface.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Statsd\\\\StatsdEvent\\:\\:getTiming\\(\\) has no return type specified\\.$#" + count: 1 + path: src/Statsd/StatsdEvent.php + + - + message: "#^Method M6Web\\\\Bundle\\\\StatsdBundle\\\\Statsd\\\\StatsdEvent\\:\\:getValue\\(\\) has no return type specified\\.$#" + count: 1 + path: src/Statsd/StatsdEvent.php + diff --git a/phpstan.neon b/phpstan.neon.dist similarity index 56% rename from phpstan.neon rename to phpstan.neon.dist index ee46ab0..5b376a1 100644 --- a/phpstan.neon +++ b/phpstan.neon.dist @@ -1,7 +1,10 @@ +includes: + - phpstan-baseline.neon parameters: - level: 5 + level: 6 paths: - src excludePaths: - src/Tests + - src/Statsd/Listener.php treatPhpDocTypesAsCertain: false diff --git a/src/Client/Client.php b/src/Client/Client.php index 512be27..0dce131 100644 --- a/src/Client/Client.php +++ b/src/Client/Client.php @@ -39,7 +39,7 @@ public function getListenedEvents() * @param string $eventName The event name to listen * @param array $eventConfig The event handler configuration */ - public function addEventToListen($eventName, $eventConfig) + public function addEventToListen($eventName, $eventConfig): void { $this->listenedEvents[$eventName] = $eventConfig; } @@ -160,7 +160,7 @@ private function getEventValue($event, $method) * * @throws Exception */ - private function addTiming($event, $timingMethod, $node, $tags = []) + private function addTiming($event, $timingMethod, $node, $tags = []): void { $timing = $this->getEventValue($event, $timingMethod); if ($timing > 0) { @@ -200,7 +200,7 @@ private function replaceConfigPlaceholder($event, $eventName, $string) * * @return array of tags */ - private function mergeTags($event, $config) + private function mergeTags($event, $config): array { $configTags = isset($config['tags']) ? $config['tags'] : []; diff --git a/src/DataCollector/StatsdDataCollector.php b/src/DataCollector/StatsdDataCollector.php index e208442..f0969e1 100644 --- a/src/DataCollector/StatsdDataCollector.php +++ b/src/DataCollector/StatsdDataCollector.php @@ -16,6 +16,7 @@ */ class StatsdDataCollector extends DataCollector { + /** @var array */ private $statsdClients; /** @@ -29,7 +30,7 @@ public function __construct() /** * Reset the data collector to initial state */ - public function reset() + public function reset(): void { $this->statsdClients = []; $this->data = [ @@ -43,7 +44,7 @@ public function reset() * * @param Event $event The received event */ - public function onKernelResponse($event) + public function onKernelResponse($event): void { if ($event instanceof KernelEvent && HttpKernelInterface::MASTER_REQUEST == $event->getRequestType()) { foreach ($this->statsdClients as $clientName => $client) { @@ -76,7 +77,7 @@ public function onKernelResponse($event) * @param string $clientAlias The client alias * @param object $statsdClient A statsd client instance */ - public function addStatsdClient($clientAlias, $statsdClient) + public function addStatsdClient($clientAlias, $statsdClient): void { $this->statsdClients[$clientAlias] = $statsdClient; } @@ -84,9 +85,11 @@ public function addStatsdClient($clientAlias, $statsdClient) /** * Collect the data * - * @param Request $request The request object - * @param Response $response The response object - * @param \Throwable $exception An exception + * @param Request $request The request object + * @param Response $response The response object + * @param \Throwable|null $exception An exception + * + * @return void */ public function collect(Request $request, Response $response, \Throwable $exception = null) { @@ -97,7 +100,7 @@ public function collect(Request $request, Response $response, \Throwable $except * * @return array operations list */ - public function getClients() + public function getClients(): array { return $this->data['clients']; } diff --git a/src/DependencyInjection/Configuration.php b/src/DependencyInjection/Configuration.php index dc63f40..ea50959 100644 --- a/src/DependencyInjection/Configuration.php +++ b/src/DependencyInjection/Configuration.php @@ -4,6 +4,7 @@ namespace M6Web\Bundle\StatsdBundle\DependencyInjection; +use Symfony\Component\Config\Definition\Builder\ArrayNodeDefinition; use Symfony\Component\Config\Definition\Builder\TreeBuilder; use Symfony\Component\Config\Definition\ConfigurationInterface; @@ -15,9 +16,13 @@ */ class Configuration implements ConfigurationInterface { + /** + * @return TreeBuilder + */ public function getConfigTreeBuilder() { $treeBuilder = new TreeBuilder('m6_statsd'); + /** @var ArrayNodeDefinition $rootNode */ $rootNode = $treeBuilder->getRootNode(); $this->addServersSection($rootNode); @@ -27,7 +32,10 @@ public function getConfigTreeBuilder() return $treeBuilder; } - private function addServersSection($rootNode) + /** + * @param ArrayNodeDefinition $rootNode + */ + private function addServersSection($rootNode): void { $rootNode ->children() @@ -53,7 +61,10 @@ function ($v) { ->end(); } - private function addClientsSection($rootNode) + /** + * @param ArrayNodeDefinition $rootNode + */ + private function addClientsSection($rootNode): void { $rootNode ->children() @@ -97,8 +108,10 @@ private function addClientsSection($rootNode) /** * addDefaultEventSection + * + * @param ArrayNodeDefinition $rootNode */ - private function addDefaultEventSection($rootNode) + private function addDefaultEventSection($rootNode): void { $rootNode ->children() diff --git a/src/DependencyInjection/M6WebStatsdExtension.php b/src/DependencyInjection/M6WebStatsdExtension.php index 6d1146b..cb512c8 100644 --- a/src/DependencyInjection/M6WebStatsdExtension.php +++ b/src/DependencyInjection/M6WebStatsdExtension.php @@ -19,6 +19,11 @@ */ class M6WebStatsdExtension extends Extension { + /** + * @return void + * + * @throws \Exception + */ public function load(array $configs, ContainerBuilder $container) { $configuration = new Configuration(); diff --git a/src/Listener/ConsoleListener.php b/src/Listener/ConsoleListener.php index 4b4ac89..a762d32 100644 --- a/src/Listener/ConsoleListener.php +++ b/src/Listener/ConsoleListener.php @@ -34,19 +34,19 @@ public function __construct() /** * Define event dispatch */ - public function setEventDispatcher(EventDispatcherInterface $ev) + public function setEventDispatcher(EventDispatcherInterface $ev): void { $this->eventDispatcher = $ev; } - public function onCommand(BaseConsoleEvent $e) + public function onCommand(BaseConsoleEvent $e): void { $this->startTime = microtime(true); $this->dispatch($e, ConsoleEvent::COMMAND); } - public function onTerminate(ConsoleTerminateEvent $e) + public function onTerminate(ConsoleTerminateEvent $e): void { // For non-0 exit command, fire an ERROR event if ($e->getExitCode() != 0) { @@ -56,7 +56,7 @@ public function onTerminate(ConsoleTerminateEvent $e) $this->dispatch($e, ConsoleEvent::TERMINATE); } - public function onException(BaseConsoleEvent $e) + public function onException(BaseConsoleEvent $e): void { $this->dispatch($e, ConsoleEvent::EXCEPTION); } diff --git a/src/Statsd/Listener.php b/src/Statsd/Listener.php index 6525490..27d8827 100644 --- a/src/Statsd/Listener.php +++ b/src/Statsd/Listener.php @@ -16,7 +16,10 @@ */ class Listener { + /** @var Client */ protected $statsdClient; + + /** @var EventDispatcherInterface */ protected $eventDispatcher; /** @@ -34,7 +37,7 @@ public function __construct(Client $statsdClient, EventDispatcherInterface $even /** * onKernelException */ - public function onKernelException(ExceptionEvent $event) + public function onKernelException(ExceptionEvent $event): void { $exception = $event->getThrowable(); @@ -52,10 +55,8 @@ public function onKernelException(ExceptionEvent $event) * method called on the kernel.terminate event * * @param TerminateEvent $event event - * - * @return void */ - public function onKernelTerminate(TerminateEvent $event) + public function onKernelTerminate(TerminateEvent $event): void { $this->statsdClient->send(); } @@ -64,10 +65,8 @@ public function onKernelTerminate(TerminateEvent $event) * method called on the console.terminate event * * @param ConsoleTerminateEvent $event event - * - * @return void */ - public function onConsoleTerminate(ConsoleTerminateEvent $event) + public function onConsoleTerminate(ConsoleTerminateEvent $event): void { $this->statsdClient->send(); } @@ -76,7 +75,7 @@ public function onConsoleTerminate(ConsoleTerminateEvent $event) * method called if base_collectors = true in config to dispatch base events * (you still have to catch them) */ - public function dispatchBaseEvents(TerminateEvent $event) + public function dispatchBaseEvents(TerminateEvent $event): void { $this->dispatchMemory(); $this->dispatchRequestTime($event); @@ -85,7 +84,7 @@ public function dispatchBaseEvents(TerminateEvent $event) /** * dispatchMemory dispatch a memory event */ - private function dispatchMemory() + private function dispatchMemory(): void { $memory = memory_get_peak_usage(true); $memory = ($memory > 1024 ? intval($memory / 1024) : 0); @@ -101,7 +100,7 @@ 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. */ - private function dispatchRequestTime(TerminateEvent $event) + private function dispatchRequestTime(TerminateEvent $event): void { $request = $event->getRequest(); $startTime = $request->server->get('REQUEST_TIME_FLOAT', $request->server->get('REQUEST_TIME')); diff --git a/src/Statsd/MonitorableEventInterface.php b/src/Statsd/MonitorableEventInterface.php index ddca5fe..81751fc 100644 --- a/src/Statsd/MonitorableEventInterface.php +++ b/src/Statsd/MonitorableEventInterface.php @@ -17,7 +17,7 @@ public function getValue(); /** * array of tags [key => value] * - * @return array + * @return array|mixed */ public function getTags(); } diff --git a/src/Statsd/StatsdEvent.php b/src/Statsd/StatsdEvent.php index acdc3ec..c2be1d7 100644 --- a/src/Statsd/StatsdEvent.php +++ b/src/Statsd/StatsdEvent.php @@ -11,17 +11,11 @@ */ class StatsdEvent extends GenericEvent implements MonitorableEventInterface { - /** - * getTiming - */ public function getTiming() { return $this->getSubject(); } - /** - * getValue - */ public function getValue() { return $this->getSubject(); @@ -30,7 +24,7 @@ public function getValue() /** * array of tags [key => value] * - * @return array + * @return array|mixed */ public function getTags() { diff --git a/src/Validator/Constraints/Node.php b/src/Validator/Constraints/Node.php index cea19ec..4c4a4bc 100755 --- a/src/Validator/Constraints/Node.php +++ b/src/Validator/Constraints/Node.php @@ -13,13 +13,4 @@ */ class Node extends Constraint { - /** - * constraint constructor - * - * @param array $options options - */ - public function __construct($options = null) - { - parent::__construct($options); - } } diff --git a/src/Validator/Constraints/NodeValidator.php b/src/Validator/Constraints/NodeValidator.php index 4c03884..6998286 100755 --- a/src/Validator/Constraints/NodeValidator.php +++ b/src/Validator/Constraints/NodeValidator.php @@ -15,6 +15,9 @@ */ class NodeValidator extends ConstraintValidator { + /** + * @return void + */ public function validate($value, Constraint $constraint) { if (!is_scalar($value) && !(is_object($value) && method_exists($value, '__toString'))) { @@ -31,8 +34,6 @@ public function validate($value, Constraint $constraint) if (!self::validatePattern($value)) { $this->context->addViolation('the node : '.$value.' isn\'t suitable for graphite'); - - return; } }