-
-
Notifications
You must be signed in to change notification settings - Fork 45
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
Abstracthelper accept method fix #203
Conversation
Signed-off-by: Joey Smith <[email protected]> Signed-off-by: Joey Smith <[email protected]>
instance has been set. Allows for disabling the acl if flag is modified. Signed-off-by: Joey Smith <[email protected]> Signed-off-by: Joey Smith <[email protected]>
Signed-off-by: Joey Smith <[email protected]> Signed-off-by: Joey Smith <[email protected]>
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.
This kind of test requires test additions .
Every method that is being used is covered. Every class member that is being used is covered. I referenced those test in the information above. The only reliable way I see to test this change is to verify that isAllowed() is not called from accept(). I will gladly write the test if someone would just point me in the correct direction of how to accomplish that with PhpUnit. I read the PhpUnit docs for about 2 hours last night trying to figure out a way to test this. |
If you have found a bug, you have observed it somewhere: we should reproduce that, at first without mocking. |
Do you have a suggestion as to the best way to Unit test if one method calls another? Is there a way to Unit test that? |
I'm trying to understand when |
This is the original code
WIthout first calling $helper->setUseAcl(false) in user land then AbstractHelper->isAllowed() would always be called because the AbtractHelper->useAcl flag is defined as true by the AbstractHelper in the prop definition. I referenced that above. If a user installs both laminas view and laminas navigation but is not using the Acl component they should not have to explicitly call AbstractHelper->setUseAcl(false) to prevent AbstractHelper->isAllowed() from being ran, or at least I would not think so. I covered this in issue #202 when I reported it. The issue boils down to this. Why call AbstractHelper->isAllowed() if an Acl component is not even installed? It should not. If there is not one installed, and set on the helper then it could not possibly, or should not possibly, have any influence on whether a page is accepted or not. By default, and in the current code it is called because AbstractHelper->useAcl is defined as true. In the change I use $this->hasAcl() && $this->getUseAcl to first make sure a Acl instance has been set, then to allow overriding that if the user has called AbstractHelper->setUseAcl(false) to bypass the Acl, since that is the current usage the check should respect that. Now, how to reproduce that in a Unittest.... That's the problem I am struggling with... I suppose maybe a listener could be attached to see if AclListener::accept() is triggered?? AbstractHelper->isAllowed() triggers an accept event, but really, the code execution should never get to there. Why kick off that workflow if the governing component is not available to check against? The accept method in the AclListener simply checks if(! $acl) returns a another flag that is defined as true. |
@Ocramius |
@tyrsson laminas-view/src/Helper/Navigation/Listener/AclListener.php Lines 15 to 17 in 198f594
This also allows a custom listener to handle this situation itself. Therefore, this change cannot simply be adopted, even though I would prefer to remove the entire permission check from the view layer. |
@froschdesign |
Description
This change prevents the accept method calling isAllowed unless an ACL instance has been set for the Helper
In addition to #202 Please reference the following:
AbstractHelper:
line 112:
AbstractHelperTest
line# 40
line#50
MenuTest:
line#125
line#137