/* * Copyright (c) 2015, 2022, 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.
*/
publicvoid classesRedeclaration2() {
assertEval("class A { }");
assertClasses(clazz(KullaTesting.ClassType.CLASS, "A"));
assertActiveKeys();
Snippet b = classKey(assertEval("class B extends A { }"));
assertClasses(clazz(KullaTesting.ClassType.CLASS, "A"),
clazz(KullaTesting.ClassType.CLASS, "B"));
assertActiveKeys();
Snippet c = classKey(assertEval("class C extends B { }"));
assertClasses(clazz(KullaTesting.ClassType.CLASS, "A"),
clazz(KullaTesting.ClassType.CLASS, "B"), clazz(KullaTesting.ClassType.CLASS, "C"));
assertActiveKeys();
//8154496: test3 update: sig change should false publicvoid classesRedeclaration3() {
Snippet a = classKey(assertEval("class A { }"));
assertClasses(clazz(KullaTesting.ClassType.CLASS, "A"));
assertActiveKeys();
publicvoid classesCyclic1() {
Snippet b = classKey(assertEval("class B extends A { }",
added(RECOVERABLE_NOT_DEFINED)));
Snippet a = classKey(assertEval("class A extends B { }", DiagCheck.DIAG_IGNORE, DiagCheck.DIAG_IGNORE,
added(REJECTED))); /*** assertDeclareFail("class A extends B { }", "****", added(REJECTED), ste(b, RECOVERABLE_NOT_DEFINED, RECOVERABLE_NOT_DEFINED, false, MAIN_SNIPPET));
***/ // It is random which one it shows up in, but cyclic error should be there
List<Diag> diagsA = getState().diagnostics(a).collect(toList());
List<Diag> diagsB = getState().diagnostics(b).collect(toList());
List<Diag> diags; if (diagsA.isEmpty()) {
diags = diagsB;
} else {
diags = diagsA;
assertTrue(diagsB.isEmpty());
}
assertEquals(diags.size(), 1, "Expected one error");
assertEquals(diags.get(0).getCode(), "compiler.err.cyclic.inheritance", "Expected cyclic inheritance error");
assertActiveKeys();
}
publicvoid classesCyclic2() {
Snippet d = classKey(assertEval("class D extends E { }", added(RECOVERABLE_NOT_DEFINED)));
assertEval("class E { D d; }",
added(VALID),
ste(d, RECOVERABLE_NOT_DEFINED, VALID, true, MAIN_SNIPPET));
assertActiveKeys();
}
publicvoid classesIgnoredModifiers() {
assertEval("public interface A { }");
assertEval("static class B implements A { }");
assertEval("static interface C extends A { }");
assertActiveKeys();
}
publicvoid classesIgnoredModifiersAnnotation() {
assertEval("public @interface X { }");
assertEval("@X public interface A { }");
assertEval("@X static class B implements A { }");
assertEval("@X static interface C extends A { }");
assertActiveKeys();
}
publicvoid classesIgnoredModifiersOtherModifiers() {
assertEval("strictfp public interface A { }");
assertEval("strictfp static class B implements A { }");
assertEval("strictfp static interface C extends A { }");
assertActiveKeys();
}
publicvoid ignoreModifierSpaceIssue() {
assertEval("interface I { void f(); } "); // there should not be a space between 'I' and '{' to reproduce the failure
assertEval("class C implements I{ public void f() {}}");
assertClasses(clazz(KullaTesting.ClassType.CLASS, "C"), clazz(KullaTesting.ClassType.INTERFACE, "I"));
assertActiveKeys();
}
@DataProvider(name = "innerClasses") public Object[][] innerClasses() {
List<Object[]> list = new ArrayList<>(); for (ClassType outerClassType : ClassType.values()) { for (ClassType innerClassType : ClassType.values()) {
list.add(new Object[]{outerClassType, innerClassType});
}
} return list.toArray(new Object[list.size()][]);
}
publicvoid testInnerClassesCrash() {
Snippet a = classKey(assertEval("class A { class B extends A {} }"));
Snippet a2 = classKey(assertEval("class A { interface I1 extends I2 {} interface I2 {} }",
ste(MAIN_SNIPPET, VALID, VALID, true, null),
ste(a, VALID, OVERWRITTEN, false, MAIN_SNIPPET)));
assertEval("class A { A a = new A() {}; }",
ste(MAIN_SNIPPET, VALID, VALID, true, null),
ste(a2, VALID, OVERWRITTEN, false, MAIN_SNIPPET));
}
publicvoid testInnerClassesCrash1() {
assertEval("class A { class B extends A {} B getB() { return new B();} }");
assertEquals(varKey(assertEval("A a = new A();")).name(), "a");
VarSnippet variableKey = varKey(assertEval("a.getB();"));
assertEquals(variableKey.typeName(), "A.B");
}
publicvoid testInnerClassesCrash2() {
assertEval("class A { interface I1 extends I2 {} interface I2 {} I1 x; }");
assertEquals(varKey(assertEval("A a = new A();")).name(), "a");
VarSnippet variableKey = varKey(assertEval("a.x;"));
assertEquals(variableKey.typeName(), "A.I1");
}
publicvoid testCircular() {
assertEval("import java.util.function.Supplier;");
TypeDeclSnippet aClass =
classKey(assertEval("public class A {\n" + " private class SomeClass {}\n" + " public Supplier m() {\n" + " return new B<>(this);\n" + " }\n" + "}",
added(RECOVERABLE_DEFINED)));
assertEval("public class B implements Supplier {\n" + " public B(A a) {}\n" + " public T get() {return null;}\n" + "}",
added(VALID),
ste(aClass, Status.RECOVERABLE_DEFINED, Status.VALID, false, null));
assertEval("new A()");
}
publicvoid testCircular8282160() {
TypeDeclSnippet classKey = classKey(assertEval(""" class B {
C c; publicvoid run() {}
} """,
added(RECOVERABLE_NOT_DEFINED)));
assertEval(""" class C extends B {
@Override publicvoid run() {}
} """,
added(VALID),
ste(classKey, Status.RECOVERABLE_NOT_DEFINED, Status.VALID, true, null));
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.