-
Notifications
You must be signed in to change notification settings - Fork 3
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
Add exclude directive for maybe-ASP-open rule #3
base: main
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.
I'm not sure I understand this exclusion. This is not a false positive. This is Magento using an placeholder delimiter which will break on PHP < 7.0 with the asp_tags
ini directive set to 1
.
This is not something which Magento can polyfill or change at run-time either as the asp_tags
directive cannot be changed at run-time.
And while the latest versions of Magento2 do not support PHP < 7.0 anymore, Magento 2.0 and 2.1 still did.
For this to be added/accepted, it would have to be made clear in the README that the ruleset is only applicable for a certain Magento x version and up, which I'm not sure is wise in the context of Magento extensions ?
Yes, that's a fair response. I agree that this isn't a false positive. I do however think it should be excluded from the rule-set here, and without a corresponding note in the README. Turning off
and recommended on this support page: https://support.magento.com/hc/en-us/articles/360034599631-PHP-settings-errors This particular rule is already specifically disabled in certain files, for example: https://github.com/magento/magento2/pull/31913/files. It's also already disabled in the official Magento2 coding standard (see https://github.com/magento/magento-coding-standard/blob/0f81833b28d6fc3d799986ebcfa7fee659927ff4/Magento2/ruleset.xml#L766) and has been since that standard started using PHPCompatibility (see magento/magento-coding-standard@39de3e6). As part of our automated pipeline, we run PHPCompatibility across our Magento modules and projects. Currently I'm using the I think it makes sense for the Magento2 coding standard to use this rule-set instead of pulling in all of PHPCompatibility and making the exclusion locally (links above). |
Listing something as a requirement and actively enforcing it (by, for instance, checking the ini value and exiting out if the value does not comply with the requirements) are two different things. Keep in mind, this ruleset is not just for Magento Core, but like the other CMS rulesets, also intended for extension/plugin/theme authors in the context of Magento and even for end-users of Magento (who may want to check if the setup they have, including all extras, can be safely moved to a server running a higher PHP version). While Magento Core does not want to see the notice as they've covered the issue with a recommendation in the docs (and I do understand that), it may still be important for extension/plugin authors and end-users of Magento to see the message and verify that their settings are correct. |
Oh and I'm also thinking: should this ruleset by renamed |
This directive is currently being excluded individually in the Magento2 ruleset. Moving it here will allow us to use this ruleset instead of maintaining the main PHP Compatibility ruleset going forward.
https://github.com/magento/magento-coding-standard/blob/0f81833b28d6fc3d799986ebcfa7fee659927ff4/Magento2/ruleset.xml#L765-L766