CI: migrate PHPStan to PrestaShop/.github action#32
Merged
jolelievre merged 7 commits intoJun 11, 2026
Conversation
Replace the Docker-based phpstan.sh approach with the shared PrestaShop/.github PHPStan action. The old approach was failing because the prestashop/prestashop:latest Docker image now exits immediately (due to entrypoint changes), causing "No such container: temp-ps" errors. - Add tests/php/phpstan/ with version-specific neon configs for 8.1.7, 8.2.x, 9.1.x and develop - Add prepend-constants.php for PS 9.x bootstrap constants - Replace single Docker-based phpstan job with two action-based jobs: phpstan-74 (PS 8.x, PHP 7.4-8.1) and phpstan (PS 9.x, PHP 8.1-8.5) - Remove tests/phpstan.sh (no longer needed) Fixes #ISSUE Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
Hello @mattgoud! This is your first pull request on statssearch repository of the PrestaShop project. Thank you, and welcome to this Open Source community! |
- Add missing blank line after <?php in index.php (php-cs-fixer) - Add ignoreErrors for pre-existing PHPStan errors on PS 8.x Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
Drop the 8.1.7 target to match the project-wide module cleanup Epic which standardizes native modules on PS 8.2+: - php.yml: phpstan-74 matrix now runs against 8.2.x only (PHP 7.4/8.1) - ps_versions_compliancy min bumped to 8.2.0 - remove the now-unreferenced phpstan-8.1.7.neon config Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
The neon configs carried empty ignoreErrors: keys with no entries. Drop them so each config only includes the base configuration. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
jolelievre
reviewed
Jun 8, 2026
| uses: actions/checkout@v5 | ||
| # Run PHPStan against the module (PHP 7.4 – 8.1) | ||
| phpstan-74: | ||
| name: PHPStan (PHP 7.4 - 8.1) |
| fail-fast: false | ||
| matrix: | ||
| presta-versions: ['1.7.1.2', '1.7.2.5', '1.7.3.4', '1.7.4.4', '1.7.5.1', '1.7.6', '1.7.7', '1.7.8', 'latest'] | ||
| presta_version: ['9.1.x', 'develop'] |
Contributor
There was a problem hiding this comment.
Suggested change
| presta_version: ['9.1.x', 'develop'] | |
| presta_version: ['9.0.3', '9.1.x', 'develop'] |
Contributor
Author
There was a problem hiding this comment.
ok @jolelievre done, added 9.0.3 to the matrix and created the matching tests/php/phpstan/phpstan-9.0.3.neon (the config path is resolved from presta_version, so the job would have failed without it).
…9.0.3 - php-linter: add missing intermediate syntax checks (7.3, 8.1, 8.2, 8.3, 8.4) - phpstan-74: lower floor to PHP 7.2 (real minimum for PS 8.2.x) - phpstan: add PrestaShop 9.0.3 to the matrix + version-specific neon config Part of PrestaShop/PrestaShop#41648 Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
PrestaShop 9.0.x supports PHP 8.1 up to 8.4 only, so the cross-product matrix was generating an invalid 9.0.3 x 8.5 combination. Switch to an explicit include list so each PrestaShop version tests its proper PHP floor and ceiling (9.0.3: 8.1/8.4, 9.1.x and develop: 8.1/8.5). Also make the "Prepare PHP env" step name reflect the actual matrix version. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
Contributor
Author
|
correction: this is a major bump, not a patch — version set to 3.0.0 (statssearch.php + config.xml) |
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
4f59579 to
7224161
Compare
|
PR merged, well done! Message to @PrestaShop/committers: do not forget to milestone it before the merge. |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
tests/phpstan.sh) was failing withError response from daemon: No such container: temp-psbecause theprestashop/prestashop:latestDocker image now exits immediately due to entrypoint changes, causing the volume container to disappear before PHPStan can use it.This PR migrates to the shared
PrestaShop/.githubPHPStan action (as used byps_googleanalytics,ps_emailsubscription,blockreassurance):- Adds
tests/php/phpstan/with version-specific neon configs for8.2.x,9.0.3,9.1.xanddevelop- Replaces the single Docker-based job with two action-based jobs:
phpstan-74(PS 8.2.x / PHP 7.2–8.1) andphpstan(PS 9.x —9.0.3,9.1.x,develop/ PHP 8.1–8.5, with9.0.3capped at PHP 8.4 since PS 9.0.x does not support 8.5)- Expands the
php-linterjob to check every PHP version from 7.2 to 8.5 (adds the missing 7.3, 8.1, 8.2, 8.3, 8.4 intermediates)- Removes
tests/phpstan.sh- Aligns the module on the PS 8.2+ baseline targeted by the cleanup Epic: drops the
8.1.7PHPStan target and bumpsps_versions_compliancymin to8.2.0Part of PrestaShop/PrestaShop#41648