-
Notifications
You must be signed in to change notification settings - Fork 39
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
Introduce ExplicitArgumentEnumeration
check
#985
base: master
Are you sure you want to change the base?
Conversation
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
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.
(I see there a more mutants to be handled; will review in the ~coming days.)
// XXX: Once we target JDK 14+, drop this method in favour of `Symbol#isPublic()`. | ||
private static boolean isPublic(Symbol symbol) { | ||
return symbol.getModifiers().contains(Modifier.PUBLIC); | ||
} |
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.
Also present in #972, but a separate utility method doesn't seem worth it. (Or we can just drop JDK 11 support 🙃.)
d3877c5
to
a74fd35
Compare
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
a74fd35
to
9e7ac68
Compare
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
9e7ac68
to
714713b
Compare
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.
Rebased and added a commit with some improvements. I think this is now properly ready for review.
if (tree.getArguments().size() != 1) { | ||
return Description.NO_MATCH; | ||
} |
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.
Pitest reports that this if
-statement can be mutated away. That's correct: it's a performance optimization. While we haven't done so in the past, it may be good to start documenting such cases. Will do for this case.
private static boolean isUnaryIterableAcceptingMethod(MethodSymbol method, VisitorState state) { | ||
List<VarSymbol> params = method.params(); | ||
return !method.isVarArgs() | ||
&& params.size() == 1 | ||
&& ASTHelpers.isSubtype(params.get(0).type, state.getSymtab().iterableType, state); | ||
} |
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.
Pitest flags that the params.size() == 1
can be mutated away. This is true thanks to the initial tree.getArguments().size() != 1
check, but it doesn't seem right to drop this condition; it makes the code less clear, IMHO.
Quality Gate passedIssues Measures |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
714713b
to
6ae584f
Compare
Quality Gate passedIssues Measures |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
1 similar comment
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
6ae584f
to
4101867
Compare
Quality Gate passedIssues Measures |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
4101867
to
5f14738
Compare
Quality Gate passedIssues Measures |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
5f14738
to
d6e65b6
Compare
/integration-test |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
From the IT ☝🏻. Not checking the error in depth right now, but curious 🤔. |
And this....
|
I filed #1455 for this. |
Same also happened for a |
Oops, sorry, don't know what happened there 😓. |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
/integration-test |
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.
Only one small typo and a suggestion :). Nice check @Stephan202 . Sorry for the slow review 🐌.
<dependency> | ||
<groupId>org.jooq</groupId> | ||
<artifactId>jooq</artifactId> | ||
<version>3.16.23</version> |
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.
There is a higher version, a specific reason to not use that yet?
" assertThat(ImmutableList.of()).containsExactlyInAnyOrderElementsOf(Set.of());", | ||
" assertThat(ImmutableList.of()).containsSequence(Arrays.asList());", | ||
" assertThat(ImmutableList.of()).containsSubsequence(ImmutableList.of(1));", | ||
" assertThat(ImmutableList.of()).doesNotContainAnyElementsOf(ImmutableMultiset.of(1));", |
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.
No incrementing numbers this time? 😋
I see that the methods are different but might be "more" consistent 🤔
.flatMap(e -> trySuggestCallingCustomAlternative(tree, argument, state, e.getValue())); | ||
} | ||
|
||
private static Optional<SuggestedFix> trySuggestCallingCustomAlternative( |
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.
Probably the only exception where VisitorState
is not the last parameter :).
.build()); | ||
} | ||
|
||
private static boolean isAtLeastAsVisible(Element symbol, Element reference) { |
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.
Was thinking that the name modifier
in this method name would be nice as addition, but also fine with leaving it as is.
Quality Gate passedIssues Measures |
Mutation testing report by Pitest. Review any surviving mutants by inspecting the line comments under Files changed. |
Suggested commit message:
I found this on an old branch from early last year. Extended it a bit and now putting it up for review. Perhaps we can find a better name. Likely this code should also be tested against the internal code base before landing. But it's certainly ready for review.