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

Add Kotlin support for JUnit recipes: UpdateBeforeAfterAnnotations #533

Merged
Changes from 1 commit
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
0d54471
Adding Kotlin support to the recipes, fixing the recipes to work use …
Jun 17, 2024
6abf2f3
Merge branch 'main' into feature/add-kotlin-support-junit-cleanuprule
amitojduggal Jun 17, 2024
30960c1
Do a single recipe run per unit test
timtebeek Jun 17, 2024
e07c523
Stop after pre visit, since we're only updating imports
timtebeek Jun 17, 2024
15545f1
Adding Kotlin support for the UpdateBeforeAfterAnnotations, along wit…
Jun 17, 2024
fa13722
Added kotlin tests for AddParameterizedTestAnnotation
Jun 18, 2024
f6fd008
Add Picnic AssertJ rules to AssertJ best practices (#527)
timtebeek Jun 17, 2024
64dfb10
refactor: Only publish build scans if authenticated
timtebeek Jun 18, 2024
e579694
Drop Java 17 requirement through rewrite-third-party (#531)
timtebeek Jun 19, 2024
1d22c17
Jmockit Expectations with no times or result should be transformed to…
shivanisky Jun 20, 2024
77af97e
Rewrite both JMockit `@Mocked` and `@Injectable` annotated arguments…
shivanisky Jun 20, 2024
c88a886
Adding Kotlin support for the UpdateBeforeAfterAnnotations, along wit…
Jun 17, 2024
df099f0
Added kotlin tests for AddParameterizedTestAnnotation
Jun 18, 2024
1d8d535
Merge remote-tracking branch 'origin/feature/add-kotlin-support-junit…
Jun 20, 2024
ddd9a1e
Restoring changes to issue to retain the references
Jun 20, 2024
a1eba6b
Remove trailing whitespace in text blocks
timtebeek Jun 20, 2024
b42b321
Update src/test/java/org/openrewrite/java/testing/junit5/UpdateBefore…
amitojduggal Jun 21, 2024
8423915
Removing tests for kotlin and keep one in the Documentation example. …
Jun 21, 2024
2799ad2
Removing extra tests for Kotlin, and keeping one, fixing issue with f…
Jun 21, 2024
6049913
Restored changes to the disabled test.
Jun 21, 2024
41e97e6
Minor touch up
timtebeek Jun 23, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Jmockit Expectations with no times or result should be transformed to…
… Mockito verify statement (#530)

* Ensure Jmockit expectations with no times or result transform to a mockito verify

* Minor polish to text blocks

* Make times, minTimes, maxTimes more flexible as it was originally so even if someone mistakenly puts times and minTimes together, it still migrates without issue

---------

Co-authored-by: Tim te Beek <[email protected]>
  • Loading branch information
2 people authored and Amitoj Duggal committed Jun 20, 2024
commit 1d22c17a1959455b9f4ec5376e5486a25c8bfa45
Original file line number Diff line number Diff line change
@@ -17,6 +17,7 @@

import org.openrewrite.Cursor;
import org.openrewrite.ExecutionContext;
import org.openrewrite.internal.lang.Nullable;
import org.openrewrite.java.JavaParser;
import org.openrewrite.java.JavaTemplate;
import org.openrewrite.java.JavaVisitor;
@@ -118,22 +119,31 @@ private void rewriteMethodBody(List<Statement> expectationStatements) {
return;
}
J.MethodInvocation invocation = (J.MethodInvocation) expectationStatements.get(0);
if (!mockInvocationResults.getResults().isEmpty()) {
boolean hasExpectationsResults = !mockInvocationResults.getResults().isEmpty();
if (hasExpectationsResults) {
// rewrite the statement to mockito if there are results
rewriteExpectationResult(mockInvocationResults.getResults(), invocation);
} else if (nextStatementCoordinates.isReplacement()) {
// if there are no results and the Expectations block is not yet replaced, remove it
removeExpectationsStatement();
}

boolean hasTimes = false;
if (mockInvocationResults.getTimes() != null) {
hasTimes = true;
writeMethodVerification(invocation, mockInvocationResults.getTimes(), "times");
}
if (mockInvocationResults.getMinTimes() != null) {
hasTimes = true;
writeMethodVerification(invocation, mockInvocationResults.getMinTimes(), "atLeast");
}
if (mockInvocationResults.getMaxTimes() != null) {
hasTimes = true;
writeMethodVerification(invocation, mockInvocationResults.getMaxTimes(), "atMost");
}
if (!hasExpectationsResults && !hasTimes) {
writeMethodVerification(invocation, null, null);
}
}

private void rewriteExpectationResult(List<Expression> results, J.MethodInvocation invocation) {
@@ -182,18 +192,22 @@ private void removeExpectationsStatement() {
methodBody.getStatements().get(bodyStatementIndex + numStatementsAdded).getCoordinates().after();
}

private void writeMethodVerification(J.MethodInvocation invocation, Expression times, String verificationMode) {
private void writeMethodVerification(J.MethodInvocation invocation, @Nullable Expression times, @Nullable String verificationMode) {
String fqn = getInvocationSelectFullyQualifiedClassName(invocation);
if (fqn == null) {
// cannot write a verification statement for an invocation without a select field
return;
}
visitor.maybeAddImport("org.mockito.Mockito", "verify");
visitor.maybeAddImport("org.mockito.Mockito", verificationMode);
if (verificationMode != null) {
visitor.maybeAddImport("org.mockito.Mockito", verificationMode);
}

List<Object> templateParams = new ArrayList<>();
templateParams.add(invocation.getSelect());
templateParams.add(times);
if (times != null) {
templateParams.add(times);
}
templateParams.add(invocation.getName().getSimpleName());

String verifyTemplate = getVerifyTemplate(invocation.getArguments(), fqn, verificationMode, templateParams);
@@ -251,17 +265,20 @@ private static void appendToTemplate(StringBuilder templateBuilder, boolean buil
templateBuilder.append(templateField);
}

private static String getVerifyTemplate(List<Expression> arguments, String fqn, String verificationMode, List<Object> templateParams) {
private static String getVerifyTemplate(List<Expression> arguments, String fqn, @Nullable String verificationMode, List<Object> templateParams) {
StringBuilder templateBuilder = new StringBuilder("verify(#{any(" + fqn + ")}"); // verify(object
if (verificationMode != null) {
templateBuilder.append(", ").append(verificationMode).append("(#{any(int)})"); // verify(object, times(2)
}
templateBuilder.append(").#{}("); // verify(object, times(2)).method(

if (arguments.isEmpty()) {
return "verify(#{any(" + fqn + ")}, "
+ verificationMode
+ "(#{any(int)})).#{}();";
templateBuilder.append(");"); // verify(object, times(2)).method();
return templateBuilder.toString();
}
StringBuilder templateBuilder = new StringBuilder("verify(#{any(" + fqn + ")}, "
+ verificationMode
+ "(#{any(int)})).#{}(");

boolean hasArgument = false;
for (Expression argument : arguments) {
for (Expression argument : arguments) { // verify(object, times(2).method(anyLong(), any Int()
if (argument instanceof J.Empty) {
continue;
} else if (argument instanceof J.Literal) {
@@ -276,7 +293,7 @@ private static String getVerifyTemplate(List<Expression> arguments, String fqn,
if (hasArgument) {
templateBuilder.delete(templateBuilder.length() - 2, templateBuilder.length());
}
templateBuilder.append(");");
templateBuilder.append(");"); // verify(object, times(2).method(anyLong(), any Int());
return templateBuilder.toString();
}

Loading