Since version 0.12.87 PHPStan analyses and checks
thrown exceptions - hooray! pepakriz/phpstan-exception-rules
does the same thing
(and more), but it's nice to have this out of the box.
However, there are some cases that are "too dynamic" for static analysis to work automatically and thus require additional extensions.
This one aims to provide support for Symfony's Event Dispatcher.
Every time you dispatch an event, any of the handlers can throw an exception - since PHPStan doesn't know anything about them you can:
- ignore them
- remember which event throws which exceptions
- analyse handlers
- do not throw any exceptions in handlers
- catch everything
If you don't choose first or last option, you have to be very careful when modifying handlers - new exceptions can cause problems. If you do - well, you probably do not need this extension.
Solution to above problem is to annotate exceptions with @throws
tag on class level for every event:
/**
* @throws RuntimeException
*/
class SomeEvent
{
}
Having exceptions assigned to events analysis can be more complete and warn about new problems.
From now on PHPStan knows that dispatching that event can throw RuntimeException
:
try {
$eventDispatcher->dispatch(new SomeEvent());
} catch (RuntimeException $exception) { // no more error!
// handle exception
}
// new exceptions needs to be handled or annotated at function level - you will not miss them
There is also a rule to monitor exceptions thrown in subscribers:
class SomeEventSubscriber implements \Symfony\Component\EventDispatcher\EventSubscriberInterface
{
public static function getSubscribedEvents()
{
return [SomeEvent::class => 'handleEvent'];
}
/**
* @throws RuntimeException <-- this is fine
* @throws LogicException <-- this is not (unless LogicException is unchecked)
*/
public function handleEvent(): void
{
}
}
Require extension in composer:
composer require --dev hxv/phpstan-event-dispatcher-exceptions
If you have PHPStan Extension Installer - that's all!
If not - you have to manually add extension to your phpstan.neon
:
includes:
- vendor/hxv/phpstan-event-dispatcher-exceptions/extension.neon