Tests / Build Scripts: Configure PHPStan level 0#10419
Tests / Build Scripts: Configure PHPStan level 0#10419justlevine wants to merge 59 commits intoWordPress:trunkfrom
Conversation
|
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the Core Committers: Use this line as a base for the props when committing in SVN: To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
Test using WordPress PlaygroundThe changes in this pull request can previewed and tested using a WordPress Playground instance. WordPress Playground is an experimental project that creates a full WordPress instance entirely within the browser. Some things to be aware of
For more details about these limitations and more, check out the Limitations page in the WordPress Playground documentation. |
86c9442 to
0308f9e
Compare
There was a problem hiding this comment.
Pull request overview
This PR introduces PHPStan level 0 static analysis configuration to WordPress Core, establishing a foundation for catching code errors without execution. The implementation includes PHPStan configuration files, bootstrap scripts, documentation, GitHub workflows for CI integration, and inline code annotations to suppress legitimate PHPStan warnings.
Changes:
- Added PHPStan level 0 configuration with baseline support for legacy code
- Added PHPStan annotations to source files to document legitimate suppressions
- Integrated PHPStan into CI/CD via GitHub workflows and npm/composer scripts
Reviewed changes
Copilot reviewed 21 out of 22 changed files in this pull request and generated 9 comments.
Show a summary per file
| File | Description |
|---|---|
| phpstan.neon.dist | Main PHPStan configuration with level 0 rules and baseline inclusion |
| tests/phpstan/base.neon | Base configuration defining paths, exclusions, and codebase-specific settings |
| tests/phpstan/baseline.php | Empty baseline file for future tech debt tracking |
| tests/phpstan/bootstrap.php | Defines WordPress constants for PHPStan discovery |
| tests/phpstan/README.md | Documentation for running and configuring PHPStan |
| src/wp-includes/template.php | Added PHPStan annotations and removed obsolete comment |
| src/wp-includes/style-engine/class-wp-style-engine-css-rules-store.php | Added @phpstan-consistent-constructor annotation |
| src/wp-includes/media.php | Added annotation for PHP8+ GdImage class |
| src/wp-includes/functions.php | Added enhanced return type documentation for wp_die() |
| src/wp-includes/customize/*.php | Added @return documentation for overridden update() methods |
| src/wp-includes/class-wp-theme-json.php | Added null return value to match documented return type |
| src/wp-includes/class-wp-scripts.php | Removed obsolete PHPStan suppression comment |
| src/wp-admin/press-this.php | Added PHPStan annotations for plugin file includes |
| src/wp-admin/includes/class-wp-filesystem-ssh2.php | Added phpstan-ignore-next-line for unimplemented method |
| composer.json | Added phpstan/phpstan dependency and analyse script |
| package.json | Added test:php:stan npm script |
| phpcs.xml.dist | Excluded PHPStan files from coding standards checks |
| .gitignore | Added phpstan.neon to ignore list for local overrides |
| .github/workflows/php-static-analysis.yml | Main workflow for running PHPStan on pushes and PRs |
| .github/workflows/reusable-php-static-analysis.yml | Reusable workflow for PHPStan execution |
💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.
composer.json
Outdated
| "squizlabs/php_codesniffer": "3.13.5", | ||
| "wp-coding-standards/wpcs": "~3.3.0", | ||
| "phpcompatibility/phpcompatibility-wp": "~2.1.3", | ||
| "phpstan/phpstan": "~2.1.33", |
Copilot
AI
Feb 12, 2026
•
There was a problem hiding this comment.
The version constraint "~2.1.33" is very specific and may cause issues. The tilde operator (~) for a three-part version like 2.1.33 means ">=2.1.33 <2.2.0". This constraint locks to a specific patch version which may not exist or may prevent receiving important bug fixes. Consider using "^2.1" (which means ">=2.1.0 <3.0.0") or "~2.1.0" (which means ">=2.1.0 <2.2.0") instead to allow flexibility for patch updates while staying within the same minor version
| "phpstan/phpstan": "~2.1.33", | |
| "phpstan/phpstan": "~2.1.0", |
There was a problem hiding this comment.
@westonruter what are your thoughts on this one?
I definitely think we should pin at the version we commit, but I wouldn't want to Semver because contextually "nonbreaking enhancements" are breaking from an implementation POV if they create a new quality gate.
There was a problem hiding this comment.
That makes sense to me. So switching to ~2.1.0 would keep it at 2.1.x. This seems necessary because there is no composer.lock, which actually is curious since we package-lock.json. If we had a composer.lock then we'd be free to use ^2.1. But I suppose can't use it because of the different versions of PHP which may end up getting used when doing composer install.
So yeah, I guess go with ~2.1.0 and not ^2.1. When PHPStan 2.2 comes out, we'll have to manually upgrade.
There was a problem hiding this comment.
Depending on when we merge, there might be some value to pinning a minimum patch release too e.g. phpstan/phpstan#8438 (comment) . Leaving this for now, and might even bump it if this PR lingers. Keeping the issue open as a reminder to drop this as low as we think is worthwhile before we merge.
There was a problem hiding this comment.
My preference is to pin to a specific version. Patch releases do introduce changes that affect the results (probably less so at level 0 but it definitely happens at higher levels).
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
src/wp-includes/customize/class-wp-customize-background-image-setting.php
Outdated
Show resolved
Hide resolved
src/wp-includes/customize/class-wp-customize-background-image-setting.php
Show resolved
Hide resolved
src/wp-includes/customize/class-wp-customize-filter-setting.php
Outdated
Show resolved
Hide resolved
src/wp-includes/customize/class-wp-customize-filter-setting.php
Outdated
Show resolved
Hide resolved
src/wp-includes/customize/class-wp-customize-header-image-setting.php
Outdated
Show resolved
Hide resolved
|
In Update: Done in 6a46b90. |
@westonruter can you run it with (Also confirming that you're using the vanilla |
|
Actually, I was using a local wordpress-develop/tests/phpstan/base.neon Lines 62 to 63 in 75c8c54 If I change it to: paths:
- ../../src/wp-admin
- ../../src/wp-includesThen it works, aside from two errors being found: What appears to be the issue is that I use my Nevertheless, the change I made is not ideal because then it doesn't check the PHP files in the root of |
| # These files are sourced by wordpress/gutenberg in `tools/release/sync-stable-blocks.js`. | ||
| - ../../src/wp-includes/blocks |
There was a problem hiding this comment.
I suppose then this would necessitate adding PHPStan to Gutenberg to do the necessary checks?
There was a problem hiding this comment.
WordPress/gutenberg#66598 but it's been gathering dust for a while.
|
|
…into tests/phpstan/level-0
…into tests/phpstan/level-0
Co-authored-by: Weston Ruter <westonruter@gmail.com>
…into tests/phpstan/level-0
Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>
Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com>
…vor of local baseline
Co-authored-by: Jonathan Desrosiers <359867+desrosj@users.noreply.github.com>
Co-authored-by: John Blackbourn <johnbillion@git.wordpress.org>
Co-authored-by: John Blackbourn <john@johnblackbourn.com>
Co-authored-by: John Blackbourn <john@johnblackbourn.com>




Trac ticket: https://core.trac.wordpress.org/ticket/61175
This PR adds a PHPStan configuration for PHPStan level 0, along with tests and docs.
Based from #7619 - which remains in use to explore adopting future levels (alongside parallel remediation branches).
Proposal: https://make.wordpress.org/core/2025/07/11/proposal-phpstan-in-the-wordpress-core-development-workflow/
This Pull Request is for code review only. Please keep all other discussion in the Trac ticket. Do not merge this Pull Request. See GitHub Pull Requests for Code Review in the Core Handbook for more details.