-
-
Notifications
You must be signed in to change notification settings - Fork 60
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix tokenizer bug - Heredoc in if
condition broke scope mapping
#295
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for this PR @fredden !
I haven't done a proper review yet, but am wondering if squizlabs/PHP_CodeSniffer#3750 could be addressed as well as it seems like a related case ?
For now, I've just left a few small notes inline.
I would love to see more extensive tests for this method, preferably pulled & merged before this PR, but will accept this PR with the current tests as it's better than none anyway.
|
||
use PHP_CodeSniffer\Tests\Core\AbstractMethodUnitTest; | ||
|
||
final class ScopeOwnerTest extends AbstractMethodUnitTest |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you please change this to use the Tokenizer specific testcase I introduced in #314 ? That should allow code coverage to be recorded for this.
* @param int $conditionWidth How many tokens wide the 'if' condition should be. | ||
* | ||
* @dataProvider dataIfCondition | ||
* @covers PHP_CodeSniffer\Tokenizers\PHP::tokenize |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this @covers
tag correct ? The change is in the Tokenizer::recurseScopeMap()
method ?
* | ||
* @see testIfCondition() | ||
* | ||
* @return array<string, array<string, int>> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
* @return array<string, array<string, int>> | |
* @return array<string, array<string, int|string>> |
This code change introduces a bug where context conditions are no longer being added applied to the heredoc. More tests covering the existing behaviour are required to safeguard changes in the tokenizer. I'll mark this pull request as draft until we have better confidence in the tests for the tokenizer. |
Description
I have been looking into #149. I started by creating a failing test which demonstrated the problem, and then worked on making that test pass. This pull request should fix the problem described in #149.
When the tokenizer creates its map of scopes, goes through each token in turn until it finds another scope opener. It then uses recursion to map each set of open/close parenthesises to the corresponding opener (eg,
if
statement). The case of a heredoc embedded within an open/close pair of parenthesises was not handled. There are already special cases foruse
andnamespace
. I have added to this list so that heredocs are also acceptable in this context.PHP_CodeSniffer/src/Tokenizers/Tokenizer.php
Lines 1128 to 1144 in c4251a1
If the scope opener isn't handled, the code assumes that a closer will never be found, and that there must be a parse error. This isn't the case with a heredoc. Adding support for heredocs seems to make sense in this context.
PHP_CodeSniffer/src/Tokenizers/Tokenizer.php
Lines 1194 to 1195 in c4251a1
The tests here could be much more robust / extensive. I've opted for a simple test here, and will leave writing very verbose tests for #146 for now. If it would be preferable to add more tests here, please let me know.
Suggested changelog entry
if
conditions orfunction
definitions).Related issues/external references
Fixes #149
Types of changes
PR checklist