PHPStan uses type declarations to determine the type of variables, properties and other expression. Sometimes it's hard to see what PHPStan errors are the important ones among thousands of others.
Instead of fixing all PHPStan errors at once, we can start with minimal require type coverage.
What is the type coverage you ask? We have 4 type possible declarations in total here:
final class ConferenceFactory
{
const SPEAKER_TAG = 'speaker';
private $talkFactory;
public function createConference(array $data)
{
$talks = $this->talkFactory->create($data);
return new Conference($talks);
}
}
Note: Class constant types require PHP 8.3 to run.
The param type is defined. But the property, return and constant types are missing.
- 1 out of 4 = 25 % coverage
Our code quality is only at one-quarter of its potential. Let's get to 100 %!
final class ConferenceFactory
{
- public const SPEAKER_TAG = 'speaker';
+ public const string SPEAKER_TAG = 'speaker';
- private $talkFactory;
+ private TalkFactory $talkFactory;
- public function createConference(array $data)
+ public function createConference(array $data): Conference
{
$talks = $this->talkFactory->create($data);
return new Conference($talks);
}
}
This technique is very simple to start even on legacy project. Also, you're now aware exactly how high coverage your project has.
composer require tomasvotruba/type-coverage --dev
The package is available on PHP 7.2+ version in tagged releases.
With PHPStan extension installer, everything is ready to run.
Enable each item on their own:
# phpstan.neon
parameters:
type_coverage:
return: 50
param: 35.5
property: 70
constant: 85
Once you've reached 100 % type coverage, make sure your code is strict and uses types:
<?php
declare(strict_types=1);
Again, raise level percent by percent in your own pace:
parameters:
type_coverage:
declare: 40
If you run PHPStan only on some subpaths that are different from your setup in phpstan.neon
, e.g.:
vendor/bin/phpstan analyze src/Controller
This package could show false positives, as classes in the src/Controller
could be slightly less typed. This would be spamming whole PHPStan output and make hard to see any other errors you look for.
That's why this package only triggers if there are full paths, e.g.:
vendor/bin/phpstan
Happy coding!