Skip to content

Commit 48fa169

Browse files
SONARJAVA-4233 Constants accessed with member-select are not supported by MinMaxRangeCheck
1 parent a630731 commit 48fa169

File tree

2 files changed

+9
-0
lines changed

2 files changed

+9
-0
lines changed

java-checks-test-sources/src/main/java/symbolicexecution/checks/MinMaxRangeCheck.java

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -68,6 +68,11 @@ public double doRangeCheckNOK9(long num) {
6868
return Math.max(result, upper); // Noncompliant
6969
}
7070

71+
public int doRangeCheckNOK10(int num) {
72+
int result = Math.min(MinMaxRangeCheck.LOWER_INT, num);
73+
return Math.max(MinMaxRangeCheck.UPPER_INT, result); // Noncompliant {{Change these chained max/min methods invocations, as final results will always be the upper bound.}}
74+
}
75+
7176
public int doRangeCheckOK1(int num) { // Let's say num = 12
7277
int result = Math.min(UPPER_INT, num); // result = 12
7378
return Math.max(LOWER_INT, result); // Compliant; result is still 12

java-symbolic-execution/src/main/java/org/sonar/java/se/checks/MinMaxRangeCheck.java

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@
1919
*/
2020
package org.sonar.java.se.checks;
2121

22+
2223
import java.util.Collections;
2324
import java.util.List;
2425
import java.util.Set;
@@ -40,6 +41,7 @@
4041
import org.sonar.plugins.java.api.semantic.Type;
4142
import org.sonar.plugins.java.api.tree.ExpressionTree;
4243
import org.sonar.plugins.java.api.tree.IdentifierTree;
44+
import org.sonar.plugins.java.api.tree.MemberSelectExpressionTree;
4345
import org.sonar.plugins.java.api.tree.MethodInvocationTree;
4446
import org.sonar.plugins.java.api.tree.Tree;
4547
import org.sonar.plugins.java.api.tree.UnaryExpressionTree;
@@ -152,6 +154,8 @@ public ProgramState checkPostStatement(CheckerContext context, Tree syntaxNode)
152154
return handleNumericalLiteral(context, (UnaryExpressionTree) syntaxNode);
153155
case IDENTIFIER:
154156
return handleNumericalConstant(context, (IdentifierTree) syntaxNode);
157+
case MEMBER_SELECT:
158+
return handleNumericalConstant(context, ((MemberSelectExpressionTree) syntaxNode).identifier());
155159
case METHOD_INVOCATION:
156160
return handleMinMaxInvocation(context, (MethodInvocationTree) syntaxNode);
157161
default:

0 commit comments

Comments
 (0)