-
Notifications
You must be signed in to change notification settings - Fork 11
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
Writing authorisation tests for more than 3 roles #70
Comments
In situations where there are common behaviours on multiple different conditions I have used loops. In your case: for [guest, user, editor] do { login, do something, get access denied } |
Parametrized tests are the way to go for such cases. See @Provider annotation from phpunit for more info. |
Those looks like neat solutions, thank you both: @hulkur & @vpratfr I was thinking about mocking the authorisation method and just checking it was called while testing the action and then unit testing the authorisation method in a separate unit test. I like that solution because I imagine it'd be faster but not having the integration/application test makes me feel uneasy. |
There will be no conditionals and the test will be small, but it will accept parameters and be executed repeatedly:
Something like that if I understood the suggestion :) |
Exactly. Where badBadRoles could be named provideUnauthorizedRoles for clarity ;) |
I'm also thinking that with a little bit of ingenuity, it'd be easy to provide a list of all the actions in the app and the kind of users who have access to them :D |
I think having the problem of too many tests means a problem at the root of the design of the code.
For example if you have a guest, a subscribed user and an admin and the two first do the same thing on some endpoints, you shouldn't be testing 2 different things because there should be something that have them in common and that very thing should be tested.
Say there's a free feature that anyone can use but only admins can edit it, then the concept of guest or subscribed user doesn't fit anymore, they're only regular users. So in the test you'd act as a regular user to test the endpoint, and that'd test both lower layer components.
TLDR : use a higher layer abstraction for stuff that multiple classes have in common :)
Le 23 oct. 2017 à 18:03, Duilio Palacios <[email protected]<mailto:[email protected]>> a écrit :
I'm also thinking that with a little bit of ingenuity, it'd be easy to provide a list of all the actions in the app and the kind of users who have access to them :D
—
You are receiving this because you are subscribed to this thread.
Reply to this email directly, view it on GitHub<#70 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/AHUtzFH-B0ms8C24LJZWI7JqMgFs1pD_ks5svLjPgaJpZM4QCreh>.
|
I can see why it is important to write different tests that hit the same URL with different kind of users (guests, promoters, admins, etc.)
But what should we do when working in a project that includes more than 5 roles. For example: guests, subscribers, collaborators, editors, admins, superadmins.
Should we write 1 test for each role in each URL?
I've been thinking quite a lot about this problem and I have some ideas:
Create more test helpers to simplify the tests.
Test the middleware / authorisation rule in isolation and then test the routes / actions contain / call the middleware or authorisation rules.
Test the boundary scenarios (for example test the admin can access but the editor cannot, or the editor can access but the collaborators cannot)
The text was updated successfully, but these errors were encountered: