Skip to content
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

RESTWS-885: Reset password REST endpoint requires privileges #590

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

IamMujuziMoses
Copy link
Contributor

Issue I worked on

see https://issues.openmrs.org/browse/RESTWS-885

Checklist: I completed these to help reviewers :)

  • My IDE is configured to follow the code style of this project.

    No? Unsure? -> configure your IDE, format the code and add the changes with git add . && git commit --amend

  • I have added tests to cover my changes. (If you refactored
    existing code that was well tested you do not have to add tests)

    No? -> write tests and add them to this commit git add . && git commit --amend

  • I ran mvn clean package right before creating this pull request and
    added all formatting changes to my commit.

    No? -> execute above command

  • All new and existing tests passed.

    No? -> figure out why and add the fix to your commit. It is your responsibility to make sure your code works.

  • My pull request is based on the latest changes of the master branch.

    No? Unsure? -> execute command git pull --rebase upstream master

@IamMujuziMoses
Copy link
Contributor Author

@mseaton @dkayiwa please review

Context.removeProxyPrivilege(PrivilegeConstants.GET_USERS);
}

if (user == null || user.getUserId() == null ) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If the previous implementation did not throw an exception if user is null, we shouldn't do so here either. For example, if you try to hit this, and get an exception, you know that username / email doesn't exist. That may not be information we want to expose.

Just simplify this method and do everything inside of the try/finally block. No need to declare the user outside of this block, and then use this user outside of this block. Something like:

try {
  Context.addProxyPrivilege(PrivilegeConstants.GET_USERS);
  User user = userService.getUserByUsernameOrEmail(usernameOrEmail);
  if (user != null {
    userService.setUserActivationKey(user);
  }
}
finally {
  Context.removeProxyPrivilege(PrivilegeConstants.GET_USERS);
}

@@ -68,6 +68,16 @@ public void requestPasswordReset_shouldCreateUserActivationKeyGivenEmail() throw
handle(newPostRequest(RESET_PASSWORD_URI, "{\"usernameOrEmail\":\"" + user.getEmail() + "\"}"));
assertNotNull(dao.getLoginCredential(user).getActivationKey());
}

@Test(expected = MessageException.class)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why is there a MessageException expected here? Are you sure this method will even get to the final assertion? If a MessageException is thrown from posting to the URL, then wrap this in a try/catch block, confirm that this is a message exception that is expected, and then move onto the other assertions.

Copy link
Member

@mseaton mseaton left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, thanks!

@Test
public void requestPasswordReset_shouldCreateUserActivationKeyGivenUsernameOrEmail() throws Exception {
User user = userService.getUserByUuid("c98a1558-e131-11de-babe-001e378eb67e");
user.setEmail("fanyuih@gmail.com");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The test method name says username or email. But the test body is dealing with only email.

exception = me;
}
assertNotNull(exception);
assertNotNull(dao.getLoginCredential(user).getActivationKey());
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you assert that this was null before the REST call?

@dkayiwa
Copy link
Member

dkayiwa commented Sep 23, 2023

@IamMujuziMoses your test is not testing the changes in PasswordResetController2_2 because it passes without those changes.

@mherman22
Copy link
Member

@IamMujuziMoses is this still on your radar?

@IamMujuziMoses
Copy link
Contributor Author

@mherman22, you can pick it up and work on it

@mherman22
Copy link
Member

@IamMujuziMoses your test is not testing the changes in PasswordResetController2_2 because it passes without those changes.

@dkayiwa I have reverted the PasswordResetController2_2 to its originality and ran the tests and the two tests that were added are failing with somewhere along the lines of org.openmrs.api.APIAuthenticationException: error.privilegesRequired

And when i add the changes in that class, the tests pass.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants