From 5865373adabf4492a0b72e9bb54dcd20a12d0b2b Mon Sep 17 00:00:00 2001 From: Gijs de Jong Date: Mon, 17 Jul 2023 12:29:28 +0200 Subject: [PATCH 1/2] Ignore disabled checks passed to `-XepPatchChecks` Rather than throwing an `NoSuchElementException`. Fixes #3908. --- .../errorprone/BaseErrorProneJavaCompiler.java | 6 ++---- .../google/errorprone/scanner/ScannerTest.java | 16 ++++++++++++++++ 2 files changed, 18 insertions(+), 4 deletions(-) diff --git a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java index eff5d443bc9..51cf7c94f95 100644 --- a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java +++ b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java @@ -224,14 +224,12 @@ static ErrorProneAnalyzer createAnalyzer( .customRefactorer() .or( () -> { - ScannerSupplier toUse = - ErrorPronePlugins.loadPlugins(scannerSupplier, context) - .applyOverrides(epOptions); + ScannerSupplier toUse = ErrorPronePlugins.loadPlugins(scannerSupplier, context); ImmutableSet namedCheckers = epOptions.patchingOptions().namedCheckers(); if (!namedCheckers.isEmpty()) { toUse = toUse.filter(bci -> namedCheckers.contains(bci.canonicalName())); } - return ErrorProneScannerTransformer.create(toUse.get()); + return ErrorProneScannerTransformer.create(toUse.applyOverrides(epOptions).get()); }) .get(); diff --git a/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java b/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java index 39648b552df..0a1a1899c8f 100644 --- a/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java +++ b/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java @@ -95,6 +95,22 @@ public void suppressionAnnotationIgnoredWithOptions() { .doTest(); } + @Test + public void dontRunPatchForDisabledChecks() { + compilationHelper + .addSourceLines( + "Test.java", + "import com.google.errorprone.scanner.ScannerTest.Foo;", + "class Test {", + " Foo foo;", + "}") + .setArgs( + "-XepPatchLocation:IN_PLACE", + "-XepPatchChecks:ShouldNotUseFoo", + "-Xep:ShouldNotUseFoo:OFF") + .doTest(); + } + @OkToUseFoo // Foo can use itself. But this shouldn't suppress errors on *usages* of Foo. public static final class Foo {} From 3a75f22f587cad5250648c646b01f292b3480784 Mon Sep 17 00:00:00 2001 From: Gijs de Jong Date: Fri, 1 Mar 2024 10:32:24 +0100 Subject: [PATCH 2/2] apply suggestions --- .../errorprone/BaseErrorProneJavaCompiler.java | 4 +++- .../google/errorprone/scanner/ScannerTest.java | 17 ++++++++++++++++- 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java index 51cf7c94f95..1747559e0b0 100644 --- a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java +++ b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java @@ -228,8 +228,10 @@ static ErrorProneAnalyzer createAnalyzer( ImmutableSet namedCheckers = epOptions.patchingOptions().namedCheckers(); if (!namedCheckers.isEmpty()) { toUse = toUse.filter(bci -> namedCheckers.contains(bci.canonicalName())); + } else { + toUse = toUse.applyOverrides(epOptions); } - return ErrorProneScannerTransformer.create(toUse.applyOverrides(epOptions).get()); + return ErrorProneScannerTransformer.create(toUse.get()); }) .get(); diff --git a/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java b/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java index 0a1a1899c8f..09fce873315 100644 --- a/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java +++ b/core/src/test/java/com/google/errorprone/scanner/ScannerTest.java @@ -106,11 +106,26 @@ public void dontRunPatchForDisabledChecks() { "}") .setArgs( "-XepPatchLocation:IN_PLACE", - "-XepPatchChecks:ShouldNotUseFoo", + "-XepPatchChecks:", "-Xep:ShouldNotUseFoo:OFF") .doTest(); } + @Test + public void dontRunPatchUnlessRequested() { + compilationHelper.addSourceLines( + "Test.java", + "import com.google.errorprone.scanner.ScannerTest.Foo;", + "class Test {", + " Foo foo;", + "}") + .setArgs( + "-XepPatchLocation:IN_PLACE", + "-Xep:ShouldNotUseFoo:WARN", + "-XepPatchChecks:DeadException" + ).doTest(); + } + @OkToUseFoo // Foo can use itself. But this shouldn't suppress errors on *usages* of Foo. public static final class Foo {}