be4614eb5e
Reviewed-by: prappo
242 lines
8.8 KiB
Java
242 lines
8.8 KiB
Java
/*
|
|
* Copyright (c) 2002, 2024, Oracle and/or its affiliates. All rights reserved.
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
* accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU General Public License version
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
* questions.
|
|
*/
|
|
|
|
/*
|
|
* @test
|
|
* @bug 8169676 8175055 8323016
|
|
* @summary boolean result of Option.process is often ignored
|
|
* @modules jdk.compiler/com.sun.tools.javac.api
|
|
* @modules jdk.compiler/com.sun.tools.javac.main
|
|
* @modules jdk.javadoc/jdk.javadoc.internal.api
|
|
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
|
* @library /tools/lib
|
|
* @build toolbox.JavacTask toolbox.JavadocTask toolbox.TestRunner toolbox.ToolBox
|
|
* @run main BadOptionsTest
|
|
*/
|
|
|
|
import java.io.IOException;
|
|
import java.nio.file.Path;
|
|
import java.nio.file.Paths;
|
|
|
|
import toolbox.JavadocTask;
|
|
import toolbox.ModuleBuilder;
|
|
import toolbox.Task;
|
|
import toolbox.TestRunner;
|
|
import toolbox.ToolBox;
|
|
|
|
/*
|
|
* This is primarily a test of the error reporting mechanisms
|
|
* for bad options provided by javac and utilized by javadoc.
|
|
* It is not an exhaustive test of all bad option forms detected
|
|
* by javac/javadoc.
|
|
*/
|
|
public class BadOptionsTest extends TestRunner {
|
|
|
|
public static void main(String... args) throws Exception {
|
|
BadOptionsTest t = new BadOptionsTest();
|
|
t.runTests();
|
|
}
|
|
|
|
private final ToolBox tb = new ToolBox();
|
|
private final Path src = Paths.get("src");
|
|
|
|
BadOptionsTest() throws IOException {
|
|
super(System.err);
|
|
init();
|
|
}
|
|
|
|
void init() throws IOException {
|
|
tb.writeJavaFiles(src,
|
|
"public class C { }");
|
|
|
|
}
|
|
|
|
@Test
|
|
public void testAddModulesEmptyArg() {
|
|
Task.Result result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--add-modules=")
|
|
.files(src.resolve("C.java"))
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"error: no value for --add-modules option");
|
|
checkNotFound(result, "Exception", "at jdk.javadoc/");
|
|
}
|
|
|
|
@Test
|
|
public void testAddModulesBadName() {
|
|
Task.Result result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("-quiet",
|
|
"--add-modules", "123")
|
|
.files(src.resolve("C.java"))
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"error: bad name in value for --add-modules option: '123'");
|
|
checkNotFound(result, "Exception", "at jdk.javadoc/");
|
|
}
|
|
|
|
@Test
|
|
public void testAddExportsEmptyArg() {
|
|
Task.Result result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--add-exports=")
|
|
.files(src.resolve("C.java"))
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"error: no value for --add-exports option");
|
|
checkNotFound(result, "Exception", "at jdk.javadoc/");
|
|
}
|
|
|
|
@Test
|
|
public void testAddExportsBadArg() {
|
|
Task.Result result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--add-exports=m/p")
|
|
.files(src.resolve("C.java"))
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"error: bad value for --add-exports option: 'm/p'");
|
|
checkNotFound(result, "Exception", "at jdk.javadoc/");
|
|
}
|
|
|
|
@Test
|
|
public void testAddExportsBadName() {
|
|
Task.Result result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--add-exports", "m!/p1=m2")
|
|
.files(src.resolve("C.java"))
|
|
.run()
|
|
.writeAll();
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"warning: bad name in value for --add-exports option: 'm!'");
|
|
checkNotFound(result, "Exception", "at jdk.javadoc/");
|
|
}
|
|
|
|
@Test
|
|
public void testSourcePathAndModuleSourceConflict() throws IOException {
|
|
Path msrc = Paths.get("msrc");
|
|
new ModuleBuilder(tb, "m1")
|
|
.exports("p1")
|
|
.classes("package p1; public class C1 { }")
|
|
.write(msrc);
|
|
Task.Result result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("-sourcepath", "src",
|
|
"--module-source-path", msrc.getFileName().toString(),
|
|
"--module", "m1")
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"error: cannot specify both --source-path and --module-source-path");
|
|
checkFound(result.getOutput(Task.OutputKind.DIRECT),
|
|
"1 error");
|
|
}
|
|
|
|
@Test
|
|
public void testOptionNotFound_NoSuggestions() {
|
|
var result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--not-a-path")
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(String.join("\n", result.getOutputLines(Task.OutputKind.DIRECT)),
|
|
"""
|
|
error: invalid flag: --not-a-path
|
|
For more details on available options, use --help or --help-extra"""
|
|
);
|
|
}
|
|
|
|
@Test
|
|
public void testOptionNotFound_OneSuggestion() {
|
|
var result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--middle-path")
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(String.join("\n", result.getOutputLines(Task.OutputKind.DIRECT)),
|
|
"""
|
|
error: invalid flag: --middle-path
|
|
Did you mean: --module-path
|
|
For more details on available options, use --help or --help-extra"""
|
|
);
|
|
}
|
|
|
|
@Test
|
|
public void testOptionNotFound_TwoSuggestions() {
|
|
var result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--sourcepath")
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(String.join("\n", result.getOutputLines(Task.OutputKind.DIRECT)),
|
|
"""
|
|
error: invalid flag: --sourcepath
|
|
Did you mean one of: --source-path -sourcepath
|
|
For more details on available options, use --help or --help-extra"""
|
|
);
|
|
}
|
|
|
|
@Test
|
|
public void testOptionNotFound_ThreeSuggestions() {
|
|
var result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("--classpath")
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(String.join("\n", result.getOutputLines(Task.OutputKind.DIRECT)),
|
|
"""
|
|
error: invalid flag: --classpath
|
|
Did you mean one of: --class-path -classpath -bootclasspath
|
|
For more details on available options, use --help or --help-extra"""
|
|
);
|
|
}
|
|
|
|
@Test
|
|
public void testOptionNotFound_DocletOption() {
|
|
var result = new JavadocTask(tb, Task.Mode.CMDLINE)
|
|
.options("-tiglet")
|
|
.run(Task.Expect.FAIL)
|
|
.writeAll();
|
|
checkFound(String.join("\n", result.getOutputLines(Task.OutputKind.DIRECT)),
|
|
"""
|
|
error: invalid flag: -tiglet
|
|
Did you mean: -taglet
|
|
For more details on available options, use --help or --help-extra"""
|
|
);
|
|
}
|
|
|
|
private void checkFound(String log, String... expect) {
|
|
for (String e : expect) {
|
|
if (!log.contains(e)) {
|
|
error("Expected string not found: '" + e + "'");
|
|
}
|
|
}
|
|
}
|
|
|
|
private void checkNotFound(Task.Result result, String... unexpected) {
|
|
for (Task.OutputKind k : Task.OutputKind.values()) {
|
|
String r = result.getOutput(k);
|
|
for (String u : unexpected) {
|
|
if (r.contains(u)) {
|
|
error("Unexpected string found: '" + u + "'");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|