From 6a918bdc58daa1f1788ceea3bd8d54d13724976e Mon Sep 17 00:00:00 2001 From: Liam Miller-Cushon Date: Sat, 19 Oct 2024 11:52:59 -0700 Subject: [PATCH] Check that `--should-stop=ifError=FLOW` is set when EP is set up using the `-Xplugin` integration See https://github.com/google/error-prone/issues/4595#issuecomment-2424140062 PiperOrigin-RevId: 687659943 --- .../BaseErrorProneJavaCompiler.java | 16 +++-- .../ErrorProneCompilerIntegrationTest.java | 2 +- .../errorprone/ErrorProneJavacPluginTest.java | 60 +++++++++++++++++-- .../google/errorprone/VisitorStateTest.java | 3 +- .../bugpatterns/UnicodeInCodeTest.java | 3 +- 5 files changed, 72 insertions(+), 12 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 0d81955c2fe5..9515aa0ebca4 100644 --- a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java +++ b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java @@ -84,6 +84,7 @@ static void addTaskListener( JavacTask javacTask, ScannerSupplier scannerSupplier, ErrorProneOptions errorProneOptions) { Context context = ((BasicJavacTask) javacTask).getContext(); checkCompilePolicy(Options.instance(context).get("compilePolicy")); + checkShouldStopIfErrorPolicy(Options.instance(context).get("should-stop.ifError")); setupMessageBundle(context); RefactoringCollection[] refactoringCollection = {null}; javacTask.addTaskListener( @@ -196,13 +197,19 @@ private static ImmutableList setCompilePolicyToByFile(ImmutableListbuilder().addAll(args).add("-XDcompilePolicy=simple").build(); } - private static void checkShouldStopIfErrorPolicy(String arg) { - String value = arg.substring(arg.lastIndexOf('=') + 1); + private static void checkShouldStopIfErrorPolicy(String value) { + if (value == null) { + throw new InvalidCommandLineOptionException( + "The default --should-stop=ifError policy (INIT) is not supported by Error Prone," + + " pass --should-stop=ifError=FLOW instead"); + } CompileState state = CompileState.valueOf(value); if (CompileState.FLOW.isAfter(state)) { throw new InvalidCommandLineOptionException( String.format( - "%s is not supported by Error Prone, pass --should-stop=ifError=FLOW instead", arg)); + "--should-stop=ifError=%s is not supported by Error Prone, pass" + + " --should-stop=ifError=FLOW instead", + value)); } } @@ -210,7 +217,8 @@ private static ImmutableList setShouldStopIfErrorPolicyToFlow( ImmutableList args) { for (String arg : args) { if (arg.startsWith("--should-stop=ifError") || arg.startsWith("-XDshould-stop.ifError")) { - checkShouldStopIfErrorPolicy(arg); + String value = arg.substring(arg.lastIndexOf('=') + 1); + checkShouldStopIfErrorPolicy(value); return args; // don't do anything if a valid policy is already set } } diff --git a/core/src/test/java/com/google/errorprone/ErrorProneCompilerIntegrationTest.java b/core/src/test/java/com/google/errorprone/ErrorProneCompilerIntegrationTest.java index 0574fb186cd0..560f8e403d58 100644 --- a/core/src/test/java/com/google/errorprone/ErrorProneCompilerIntegrationTest.java +++ b/core/src/test/java/com/google/errorprone/ErrorProneCompilerIntegrationTest.java @@ -758,6 +758,6 @@ public void stopPolicy_init_xD() { InvalidCommandLineOptionException.class, () -> compiler.compile(new String[] {"-XDshould-stop.ifError=INIT"}, ImmutableList.of())); - assertThat(e).hasMessageThat().contains("-XDshould-stop.ifError=INIT is not supported"); + assertThat(e).hasMessageThat().contains("--should-stop=ifError=INIT is not supported"); } } diff --git a/core/src/test/java/com/google/errorprone/ErrorProneJavacPluginTest.java b/core/src/test/java/com/google/errorprone/ErrorProneJavacPluginTest.java index b50eef04927d..a86f04c13b3a 100644 --- a/core/src/test/java/com/google/errorprone/ErrorProneJavacPluginTest.java +++ b/core/src/test/java/com/google/errorprone/ErrorProneJavacPluginTest.java @@ -100,7 +100,8 @@ public void hello() throws IOException { null, fileManager, diagnosticCollector, - ImmutableList.of("-Xplugin:ErrorProne", "-XDcompilePolicy=byfile"), + ImmutableList.of( + "-Xplugin:ErrorProne", "-XDcompilePolicy=byfile", "--should-stop=ifError=FLOW"), ImmutableList.of(), fileManager.getJavaFileObjects(source)); assertThat(task.call()).isFalse(); @@ -144,7 +145,8 @@ public void applyFixes() throws IOException { ImmutableList.of( "-Xplugin:ErrorProne" + " -XepPatchChecks:MissingOverride -XepPatchLocation:IN_PLACE", - "-XDcompilePolicy=byfile"), + "-XDcompilePolicy=byfile", + "--should-stop=ifError=FLOW"), ImmutableList.of(), fileManager.getJavaFileObjects(fileA, fileB)); assertWithMessage(Joiner.on('\n').join(diagnosticCollector.getDiagnostics())) @@ -203,7 +205,8 @@ public void applyToPatchFile() throws IOException { "-Xplugin:ErrorProne" + " -XepPatchChecks:MissingOverride -XepPatchLocation:" + patchDir, - "-XDcompilePolicy=byfile"), + "-XDcompilePolicy=byfile", + "--should-stop=ifError=FLOW"), ImmutableList.of(), fileManager.getJavaFileObjects(fileA, fileB)); assertWithMessage(Joiner.on('\n').join(diagnosticCollector.getDiagnostics())) @@ -254,7 +257,8 @@ public void explicitBadPolicyGiven() throws IOException { new PrintWriter(sw, true), fileManager, diagnosticCollector, - ImmutableList.of("-XDcompilePolicy=bytodo", "-Xplugin:ErrorProne"), + ImmutableList.of( + "-XDcompilePolicy=bytodo", "--should-stop=ifError=FLOW", "-Xplugin:ErrorProne"), ImmutableList.of(), fileManager.getJavaFileObjects(source)); RuntimeException expected = assertThrows(RuntimeException.class, () -> task.call()); @@ -375,7 +379,8 @@ public void compilesWithFix() throws IOException { diagnosticCollector, ImmutableList.of( "-Xplugin:ErrorProne -XepDisableAllChecks -Xep:TestCompilesWithFix:ERROR", - "-XDcompilePolicy=byfile"), + "-XDcompilePolicy=byfile", + "--should-stop=ifError=FLOW"), ImmutableList.of(), fileManager.getJavaFileObjects(source)); assertThat(task.call()).isFalse(); @@ -385,4 +390,49 @@ public void compilesWithFix() throws IOException { .collect(onlyElement()); assertThat(diagnostic.getMessage(ENGLISH)).contains("[TestCompilesWithFix]"); } + + @Test + public void noShouldStopIfErrorPolicy() throws IOException { + FileSystem fileSystem = Jimfs.newFileSystem(Configuration.unix()); + Path source = fileSystem.getPath("Test.java"); + Files.writeString(source, "class Test {}"); + JavacFileManager fileManager = new JavacFileManager(new Context(), false, UTF_8); + DiagnosticCollector diagnosticCollector = new DiagnosticCollector<>(); + StringWriter sw = new StringWriter(); + JavacTask task = + JavacTool.create() + .getTask( + new PrintWriter(sw, true), + fileManager, + diagnosticCollector, + ImmutableList.of("-Xplugin:ErrorProne", "-XDcompilePolicy=byfile"), + ImmutableList.of(), + fileManager.getJavaFileObjects(source)); + RuntimeException expected = assertThrows(RuntimeException.class, task::call); + assertThat(expected) + .hasMessageThat() + .contains("The default --should-stop=ifError policy (INIT) is not supported"); + } + + @Test + public void shouldStopIfErrorPolicyInit() throws IOException { + FileSystem fileSystem = Jimfs.newFileSystem(Configuration.unix()); + Path source = fileSystem.getPath("Test.java"); + Files.writeString(source, "class Test {}"); + JavacFileManager fileManager = new JavacFileManager(new Context(), false, UTF_8); + DiagnosticCollector diagnosticCollector = new DiagnosticCollector<>(); + StringWriter sw = new StringWriter(); + JavacTask task = + JavacTool.create() + .getTask( + new PrintWriter(sw, true), + fileManager, + diagnosticCollector, + ImmutableList.of( + "-Xplugin:ErrorProne", "-XDcompilePolicy=byfile", "--should-stop=ifError=INIT"), + ImmutableList.of(), + fileManager.getJavaFileObjects(source)); + RuntimeException expected = assertThrows(RuntimeException.class, task::call); + assertThat(expected).hasMessageThat().contains("--should-stop=ifError=INIT is not supported"); + } } diff --git a/core/src/test/java/com/google/errorprone/VisitorStateTest.java b/core/src/test/java/com/google/errorprone/VisitorStateTest.java index b0cde5a0ca87..d90b912fb96f 100644 --- a/core/src/test/java/com/google/errorprone/VisitorStateTest.java +++ b/core/src/test/java/com/google/errorprone/VisitorStateTest.java @@ -180,7 +180,8 @@ public void memoizeCannotAccessTreePath() throws IOException { ImmutableList.of( "-Xplugin:ErrorProne -XepDisableAllChecks" + " -Xep:CheckThatTriesToMemoizeBasedOnTreePath:ERROR", - "-XDcompilePolicy=byfile"), + "-XDcompilePolicy=byfile", + "--should-stop=ifError=FLOW"), ImmutableList.of(), fileManager.getJavaFileObjects(source)); assertThat(task.call()).isFalse(); diff --git a/core/src/test/java/com/google/errorprone/bugpatterns/UnicodeInCodeTest.java b/core/src/test/java/com/google/errorprone/bugpatterns/UnicodeInCodeTest.java index 9d3a31ec78b8..aa080d70f371 100644 --- a/core/src/test/java/com/google/errorprone/bugpatterns/UnicodeInCodeTest.java +++ b/core/src/test/java/com/google/errorprone/bugpatterns/UnicodeInCodeTest.java @@ -162,7 +162,8 @@ public void asciiSub() { null, fileManager, diagnosticCollector, - ImmutableList.of("-Xplugin:ErrorProne", "-XDcompilePolicy=simple"), + ImmutableList.of( + "-Xplugin:ErrorProne", "-XDcompilePolicy=simple", "--should-stop=ifError=FLOW"), ImmutableList.of(), ImmutableList.of( new SimpleJavaFileObject(