8198315: Incomplete classpath causes NPE in TransTypes
Avoid symbol completion while constructing error message. Reviewed-by: mcimadamore
This commit is contained in:
parent
47d634e453
commit
c3cdecd32b
@ -556,7 +556,7 @@ public class RichDiagnosticFormatter extends
|
||||
//has not been attributed the bound is not set
|
||||
List<Type> bounds = (bound != null) &&
|
||||
(bound.hasTag(CLASS) || bound.hasTag(TYPEVAR)) ?
|
||||
types.getBounds(t) :
|
||||
getBounds(bound) :
|
||||
List.nil();
|
||||
|
||||
nameSimplifier.addUsage(t.tsym);
|
||||
@ -584,6 +584,10 @@ public class RichDiagnosticFormatter extends
|
||||
}
|
||||
return null;
|
||||
}
|
||||
//where:
|
||||
private List<Type> getBounds(Type bound) {
|
||||
return bound.isCompound() ? types.directSupertypes(bound) : List.of(bound);
|
||||
}
|
||||
};
|
||||
// </editor-fold>
|
||||
|
||||
|
161
test/langtools/tools/javac/diags/CompletionFailureInDiags.java
Normal file
161
test/langtools/tools/javac/diags/CompletionFailureInDiags.java
Normal file
@ -0,0 +1,161 @@
|
||||
/*
|
||||
* Copyright (c) 2018, 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 8198315
|
||||
* @summary Verify that diagnostics can be printed without throwing CompletionFailures
|
||||
* @library /tools/lib
|
||||
* @modules jdk.compiler/com.sun.tools.javac.api
|
||||
* jdk.compiler/com.sun.tools.javac.main
|
||||
* @build toolbox.TestRunner toolbox.ToolBox CompletionFailureInDiags
|
||||
* @run main CompletionFailureInDiags
|
||||
*/
|
||||
|
||||
import java.nio.file.Files;
|
||||
import java.nio.file.Path;
|
||||
import java.nio.file.Paths;
|
||||
import java.util.List;
|
||||
import java.util.Objects;
|
||||
|
||||
import toolbox.JavacTask;
|
||||
import toolbox.Task.Expect;
|
||||
import toolbox.Task.OutputKind;
|
||||
import toolbox.TestRunner;
|
||||
import toolbox.TestRunner.Test;
|
||||
import toolbox.ToolBox;
|
||||
|
||||
public class CompletionFailureInDiags extends TestRunner {
|
||||
|
||||
public static void main(String... args) throws Exception {
|
||||
new CompletionFailureInDiags().runTests(m -> new Object[] { Paths.get(m.getName()) });
|
||||
}
|
||||
|
||||
private final ToolBox tb = new ToolBox();
|
||||
|
||||
public CompletionFailureInDiags() {
|
||||
super(System.err);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCrashInDiagReport(Path outerBase) throws Exception {
|
||||
int c = 0;
|
||||
|
||||
for (Bound bound : Bound.values()) {
|
||||
for (AdditionalParams params : AdditionalParams.values()) {
|
||||
for (Delete delete : Delete.values()) {
|
||||
doRunCrashTest(outerBase.resolve(String.valueOf(c++)), bound, params, delete);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private enum Bound {
|
||||
A("A"),
|
||||
AA2("A&A2");
|
||||
private final String bound;
|
||||
|
||||
private Bound(String bound) {
|
||||
this.bound = bound;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private enum AdditionalParams {
|
||||
NONE(new String[0], null),
|
||||
RAD_DIAGS(new String[] {"-XDrawDiagnostics"},
|
||||
List.of("Test.java:3:10: compiler.err.cant.apply.symbol: kindname.method, " +
|
||||
"f, " +
|
||||
"java.lang.String, " +
|
||||
"compiler.misc.type.null,compiler.misc.type.null, " +
|
||||
"kindname.class, " +
|
||||
"D<T>, " +
|
||||
"(compiler.misc.arg.length.mismatch)",
|
||||
"1 error"));
|
||||
private final String[] options;
|
||||
private final List<String> expected;
|
||||
|
||||
private AdditionalParams(String[] options, List<String> expected) {
|
||||
this.options = options;
|
||||
this.expected = expected;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private enum Delete {
|
||||
NONE(),
|
||||
A("A.class"),
|
||||
AA2("A.class", "A2.class");
|
||||
private final String[] toDelete;
|
||||
|
||||
private Delete(String... toDelete) {
|
||||
this.toDelete = toDelete;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private void doRunCrashTest(Path outerBase, Bound bound, AdditionalParams params, Delete delete) throws Exception {
|
||||
Path libSrc = outerBase.resolve("lib-src");
|
||||
tb.writeJavaFiles(libSrc,
|
||||
"public class A {}",
|
||||
"public interface A2 {}",
|
||||
"public class B extends A implements A2 {}",
|
||||
"public class C extends D<B> {}\n",
|
||||
"public class D<T extends " + bound.bound + "> {\n" +
|
||||
" public void f(String s) {}\n" +
|
||||
"}");
|
||||
Path lib = outerBase.resolve("lib");
|
||||
Files.createDirectories(lib);
|
||||
new JavacTask(tb)
|
||||
.outdir(lib.toString())
|
||||
.files(tb.findJavaFiles(libSrc))
|
||||
.run()
|
||||
.writeAll();
|
||||
for (String del : delete.toDelete) {
|
||||
Files.delete(lib.resolve(del));
|
||||
}
|
||||
Path src = outerBase.resolve("src");
|
||||
tb.writeJavaFiles(src,
|
||||
"public class Test {\n" +
|
||||
" public void test(C c) {\n" +
|
||||
" c.f(null, null);\n" +
|
||||
" }\n" +
|
||||
"}");
|
||||
Path classes = outerBase.resolve("classes");
|
||||
Files.createDirectories(classes);
|
||||
List<String> actual = new JavacTask(tb)
|
||||
.options(params.options)
|
||||
.classpath(lib)
|
||||
.outdir(classes.toString())
|
||||
.sourcepath()
|
||||
.files(tb.findJavaFiles(src))
|
||||
.run(Expect.FAIL)
|
||||
.writeAll()
|
||||
.getOutputLines(OutputKind.DIRECT);
|
||||
|
||||
if (params.expected != null && !Objects.equals(params.expected, actual)) {
|
||||
throw new AssertionError("Unexpected output!");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user