-
Notifications
You must be signed in to change notification settings - Fork 79
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
Handle multiple blocks in JMockit Expectations #596
Handle multiple blocks in JMockit Expectations #596
Conversation
…tions declaration. This is a rare and bizzare way to "better" readability because it "groups" related statements together, but there's nothing wrong with the syntax.
src/main/java/org/openrewrite/java/testing/jmockit/SetupStatementsRewriter.java
Outdated
Show resolved
Hide resolved
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
…ions' of github.com:yurii-yu/rewrite-testing-frameworks into bugfix/handle_multiple_curly_braces_in_jmockit_expectations
@timtebeek Hello Amigo. I saw the latest commit from you. Those changes do make sense. You are so nice and so patient, thank you. |
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 a lot for the fix here and the detailed explanation of your work and considerations. Much appreciated that you're contributing back here!
We'll do a new release tomorrow, so you only need to wait a day to get to use this in practice. Hope this helps you make the switch to Mockito. Do let us know if you stumble across any other issues!
Thanks so much! You're welcome; glad to have you contribute back to the project. :) |
@timtebeek new Verifications() {
{
myObject.wait(anyLong, anyInt);
times = 3;
}
{
myObject.wait(anyLong, anyInt);
times = 4;
}
}; I will create another pull-request for that in the next couple of days. |
Awesome, thanks! Looking forward to it. Enjoy your weekend as well. :) |
What's changed?
Cope with a corner case in refactoring JMockit Expectations.
Sometimes programmers will use more than one curly braces in one Expectation block. This looks bizarre and confusing, but it is syntactically correct. It will be ideal if such code can also be refactored automatically.
usually people write code like this:
while some programmers prefer grouping related statements with redundant curly braces
I made changes in two places.
On
line 39
inJMockitUtils.java
, this criterion need to be changed, or else OpenRewrite will just ignore such blocks.On
line 53
inSetupStatementsRewriter.java
, this rewrite logic need to be able to loop over all statements, instead of only the first one, in the Expectations block.I also added one test case in
JMockitExpectationsToMockitoTest.java
What's your motivation?
We encountered problem in dealing with several legacy projects.
Unfortunately, OpenWrite just kept most of those test cases untouched. It took us a couple of days to locate the problem.
Benefited a lot from the OpenRewrite project previously, we believe that more people and more legacy projects should be able to take advantage of it.
Anything in particular you'd like reviewers to focus on?
I read the best practice so I kept the LST untouched.
Moreover, I tried my best not to affect the previous logic, so I limit my changes to "curly brace blocks in one Expectations" specifically.
The change has been tested by the entire test suite. As far as I can see, everything works fine.
Have you considered any alternatives or workarounds?
Maybe changing the LST is a better solution, but I do not think it is worthy since we only need to handle a rare case.
Users can also use a script to remove the curly braces before applying this recipe, but that is an invasive way.
Checklist