NamingConventions/NamespaceName: add support for strict PSR-4 compliance checking #348
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.
As the Yoast plugin test directories will start to follow PSR-4. the
NamespaceName
sniff will need to be able to enforce this.This commit adds this ability to the sniff.
Notes:
public
psr4_paths
ruleset property via thePSR4PathsTrait
utility.Tests
/Doubles
" directories as theTests
may be part of the PSR-4 namespace.Also note that when both a
psr4_paths
as well as thesrc_directory
andprefixes
properties are set, thepsr4_paths
property will take precedence and the sniff will only fall back to the previous logic if the file is not in a path matching one of the PSR-4 directories.Includes ample tests for this new functionality.
Includes updated XML documentation.
Includes updating the YoastCS native PHPCS ruleset to indicate that the YoastCS repo follows PSR-4 (as per the PHPCS file name rules).
Note: if the name in use in the file is causing a problematic parse error (like in the test with the
#
in the namespace name), the sniff will stay silent. This is the normal behaviour for a PHPCS check when encountering parse errors.👉 The sniff changes are probably easiest to review while ignoring whitespace.