From e90561997f6dabb57adeb81d9e1f072d20971ebb Mon Sep 17 00:00:00 2001 From: Manu Sridharan Date: Sat, 20 Jul 2024 16:35:18 -0700 Subject: [PATCH] Fix #996 --- .../main/java/com/uber/nullaway/NullAway.java | 1 - .../jspecify/SuggestedFixesTests.java | 53 +++++++++++++++++++ 2 files changed, 53 insertions(+), 1 deletion(-) create mode 100644 nullaway/src/test/java/com/uber/nullaway/jspecify/SuggestedFixesTests.java diff --git a/nullaway/src/main/java/com/uber/nullaway/NullAway.java b/nullaway/src/main/java/com/uber/nullaway/NullAway.java index 4cd68978b2..e481729e07 100644 --- a/nullaway/src/main/java/com/uber/nullaway/NullAway.java +++ b/nullaway/src/main/java/com/uber/nullaway/NullAway.java @@ -498,7 +498,6 @@ public Description matchAssignment(AssignmentTree tree, VisitorState state) { // logic return errorBuilder.createErrorDescription( errorMessage, - expression, buildDescription(tree), state, ASTHelpers.getSymbol(tree.getVariable())); diff --git a/nullaway/src/test/java/com/uber/nullaway/jspecify/SuggestedFixesTests.java b/nullaway/src/test/java/com/uber/nullaway/jspecify/SuggestedFixesTests.java new file mode 100644 index 0000000000..50048d30da --- /dev/null +++ b/nullaway/src/test/java/com/uber/nullaway/jspecify/SuggestedFixesTests.java @@ -0,0 +1,53 @@ +package com.uber.nullaway.jspecify; + +import com.google.errorprone.BugCheckerRefactoringTestHelper; +import com.uber.nullaway.NullAway; +import java.io.IOException; +import org.junit.Rule; +import org.junit.Test; +import org.junit.rules.TemporaryFolder; + +/** Tests for combining fix suggestions with JSpecify mode. */ +public class SuggestedFixesTests { + + @Rule public TemporaryFolder temporaryFolder = new TemporaryFolder(); + + private BugCheckerRefactoringTestHelper makeTestHelper() { + return BugCheckerRefactoringTestHelper.newInstance(NullAway.class, getClass()) + .setArgs( + "-d", + temporaryFolder.getRoot().getAbsolutePath(), + "-processorpath", + SuggestedFixesTests.class.getProtectionDomain().getCodeSource().getLocation().getPath(), + "-XepOpt:NullAway:AnnotatedPackages=com.uber", + "-XepOpt:NullAway:JSpecifyMode=true", + "-XepOpt:NullAway:SuggestSuppressions=true"); + } + + @Test + public void suggestSuppressionForAssigningNullableIntoNonNullArray() throws IOException { + makeTestHelper() + .addInputLines( + "Test.java", + "package com.uber;", + "import org.jspecify.annotations.Nullable;", + "class Test {", + " void test() {", + " Object[] arr = new Object[1];", + " arr[0] = null;", + " }", + "}") + .addOutputLines( + "out/Test.java", + "package com.uber;", + "import org.jspecify.annotations.Nullable;", + "class Test {", + " @SuppressWarnings(\"NullAway\")", + " void test() {", + " Object[] arr = new Object[1];", + " arr[0] = null;", + " }", + "}") + .doTest(); + } +}