Path: blob/master/test/langtools/jdk/jshell/ForwardReferenceTest.java
40931 views
/*1* Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation.7*8* This code is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License11* version 2 for more details (a copy is included in the LICENSE file that12* accompanied this code).13*14* You should have received a copy of the GNU General Public License version15* 2 along with this work; if not, write to the Free Software Foundation,16* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.17*18* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA19* or visit www.oracle.com if you need additional information or have any20* questions.21*/2223/*24* @test 8173232 801031925* @summary Test of forward referencing of snippets.26* @build KullaTesting TestingInputStream27* @run testng ForwardReferenceTest28*/2930import java.util.List;31import jdk.jshell.Snippet;32import jdk.jshell.MethodSnippet;33import jdk.jshell.VarSnippet;34import jdk.jshell.DeclarationSnippet;35import org.testng.annotations.Test;3637import jdk.jshell.SnippetEvent;38import jdk.jshell.UnresolvedReferenceException;39import static org.testng.Assert.assertEquals;40import static jdk.jshell.Snippet.Status.*;41import static org.testng.Assert.assertTrue;4243@Test44public class ForwardReferenceTest extends KullaTesting {4546public void testOverwriteMethodForwardReferenceClass() {47Snippet k1 = methodKey(assertEval("int q(Boo b) { return b.x; }",48added(RECOVERABLE_NOT_DEFINED)));49assertUnresolvedDependencies1((MethodSnippet) k1, RECOVERABLE_NOT_DEFINED, "class Boo");50assertEval("class Boo { int x = 55; }",51added(VALID),52ste(k1, RECOVERABLE_NOT_DEFINED, VALID, true, null));53assertMethodDeclSnippet((MethodSnippet) k1, "q", "(Boo)int", VALID, 0, 0);54assertEval("q(new Boo());", "55");55assertActiveKeys();56}5758public void testOverwriteMethodForwardReferenceClassImport() {59MethodSnippet k1 = methodKey(assertEval("int ff(List lis) { return lis.size(); }",60added(RECOVERABLE_NOT_DEFINED)));61assertUnresolvedDependencies1(k1, RECOVERABLE_NOT_DEFINED, "class List");62assertEval("import java.util.*;",63added(VALID),64ste(k1, RECOVERABLE_NOT_DEFINED, VALID, true, null));65assertMethodDeclSnippet(k1, "ff", "(List)int", VALID, 0, 0);66assertEval("ff(new ArrayList());", "0");67assertActiveKeys();68}6970public void testForwardVarToMethod() {71DeclarationSnippet t = methodKey(assertEval("int t() { return x; }", added(RECOVERABLE_DEFINED)));72assertUnresolvedDependencies1(t, RECOVERABLE_DEFINED, "variable x");73assertEvalUnresolvedException("t();", "t", 1, 0);74Snippet x = varKey(assertEval("int x = 33;", "33",75added(VALID),76ste(t, RECOVERABLE_DEFINED, VALID, false, null)));77assertEval("t();", "33");78assertEval("double x = 0.88;",79"0.88", null,80DiagCheck.DIAG_OK,81DiagCheck.DIAG_ERROR,82ste(MAIN_SNIPPET, VALID, VALID, true, null),83ste(x, VALID, OVERWRITTEN, false, MAIN_SNIPPET),84ste(t, VALID, RECOVERABLE_DEFINED, false, MAIN_SNIPPET));85assertEvalUnresolvedException("t();", "t", 0, 1);86assertActiveKeys();87}8889public void testForwardMethodToMethod() {90Snippet t = methodKey(assertEval("int t() { return f(); }", added(RECOVERABLE_DEFINED)));91Snippet f = methodKey(assertEval("int f() { return g(); }",92added(RECOVERABLE_DEFINED),93ste(t, RECOVERABLE_DEFINED, VALID, false, null)));94assertUnresolvedDependencies1((DeclarationSnippet) f, RECOVERABLE_DEFINED, "method g()");95assertEvalUnresolvedException("t();", "f", 1, 0);96Snippet g = methodKey(assertEval("int g() { return 55; }",97added(VALID),98ste(f, RECOVERABLE_DEFINED, VALID, false, null)));99assertEval("t();", "55");100assertEval("double g() { return 3.14159; }",101DiagCheck.DIAG_OK,102DiagCheck.DIAG_ERROR,103ste(MAIN_SNIPPET, VALID, VALID, true, null),104ste(g, VALID, OVERWRITTEN, false, MAIN_SNIPPET),105ste(f, VALID, RECOVERABLE_DEFINED, false, MAIN_SNIPPET));106DeclarationSnippet exsn = assertEvalUnresolvedException("t();", "f", 0, 1);107assertTrue(exsn == f, "Identity must not change");108assertActiveKeys();109}110111public void testForwardClassToMethod() {112DeclarationSnippet t = methodKey(assertEval("int t() { return new A().f(); }", added(RECOVERABLE_DEFINED)));113assertUnresolvedDependencies1(t, RECOVERABLE_DEFINED, "class A");114assertEvalUnresolvedException("t();", "t", 1, 0);115Snippet a = classKey(assertEval(116"class A {\n" +117" int f() { return 10; }\n" +118"}",119added(VALID),120ste(t, RECOVERABLE_DEFINED, VALID, false, null)));121assertEval("t();", "10");122assertEval(123"class A {\n" +124" double f() { return 88.0; }\n" +125"}",126DiagCheck.DIAG_OK,127DiagCheck.DIAG_ERROR,128ste(MAIN_SNIPPET, VALID, VALID, true, null),129ste(a, VALID, OVERWRITTEN, false, MAIN_SNIPPET),130ste(t, VALID, RECOVERABLE_DEFINED, false, MAIN_SNIPPET));131assertEvalUnresolvedException("t();", "t", 0, 1);132assertActiveKeys();133}134135public void testForwardVarToClass() {136DeclarationSnippet a = classKey(assertEval("class A { int f() { return g; } }", added(RECOVERABLE_DEFINED)));137assertUnresolvedDependencies1(a, RECOVERABLE_DEFINED, "variable g");138Snippet g = varKey(assertEval("int g = 10;", "10",139added(VALID),140ste(a, RECOVERABLE_DEFINED, VALID, false, null)));141assertEval("new A().f();", "10");142assertEval("double g = 10;", "10.0", null,143DiagCheck.DIAG_OK,144DiagCheck.DIAG_ERROR,145ste(MAIN_SNIPPET, VALID, VALID, true, null),146ste(g, VALID, OVERWRITTEN, false, MAIN_SNIPPET),147ste(a, VALID, RECOVERABLE_DEFINED, false, MAIN_SNIPPET));148assertUnresolvedDependencies(a, 0);149assertActiveKeys();150}151152public void testForwardVarToClassGeneric() {153DeclarationSnippet a = classKey(assertEval("class A<T> { final T x; A(T v) { this.x = v; } ; T get() { return x; } int core() { return g; } }", added(RECOVERABLE_DEFINED)));154assertUnresolvedDependencies1(a, RECOVERABLE_DEFINED, "variable g");155156List<SnippetEvent> events = assertEval("A<String> as = new A<>(\"hi\");", null,157UnresolvedReferenceException.class, DiagCheck.DIAG_OK, DiagCheck.DIAG_OK, null);158SnippetEvent ste = events.get(0);159Snippet assn = ste.snippet();160DeclarationSnippet unsn = ((UnresolvedReferenceException) ste.exception()).getSnippet();161assertEquals(unsn.name(), "A", "Wrong with unresolved");162assertEquals(getState().unresolvedDependencies(unsn).count(), 1, "Wrong size unresolved");163assertEquals(getState().diagnostics(unsn).count(), 0L, "Expected no diagnostics");164165Snippet g = varKey(assertEval("int g = 10;", "10",166added(VALID),167ste(a, RECOVERABLE_DEFINED, VALID, false, MAIN_SNIPPET)));168assertEval("A<String> as = new A<>(\"low\");",169ste(MAIN_SNIPPET, VALID, VALID, false, null),170ste(assn, VALID, OVERWRITTEN, false, MAIN_SNIPPET));171assertEval("as.get();", "\"low\"");172assertUnresolvedDependencies(a, 0);173assertActiveKeys();174}175176public void testForwardVarToClassExtendsImplements() {177DeclarationSnippet ik = classKey(assertEval("interface I { default int ii() { return 1; } }", added(VALID)));178DeclarationSnippet jk = classKey(assertEval("interface J { default int jj() { return 2; } }", added(VALID)));179DeclarationSnippet ck = classKey(assertEval("class C { int cc() { return 3; } }", added(VALID)));180DeclarationSnippet dk = classKey(assertEval("class D extends C implements I,J { int dd() { return g; } }", added(RECOVERABLE_DEFINED)));181DeclarationSnippet ek = classKey(assertEval("class E extends D { int ee() { return 5; } }", added(VALID)));182assertUnresolvedDependencies1(dk, RECOVERABLE_DEFINED, "variable g");183assertEvalUnresolvedException("new D();", "D", 1, 0);184assertEvalUnresolvedException("new E();", "D", 1, 0);185VarSnippet g = varKey(assertEval("int g = 10;", "10",186added(VALID),187ste(dk, RECOVERABLE_DEFINED, VALID, false, MAIN_SNIPPET)));188assertEval("E e = new E();");189assertDrop(g,190ste(g, VALID, DROPPED, true, null),191ste(dk, VALID, RECOVERABLE_DEFINED, false, g));192assertEvalUnresolvedException("new D();", "D", 1, 0);193assertEvalUnresolvedException("new E();", "D", 1, 0);194assertEval("e.ee();", "5");195assertEvalUnresolvedException("e.dd();", "D", 1, 0);196assertEval("e.cc();", "3");197assertEval("e.jj();", "2");198assertEval("e.ii();", "1");199assertActiveKeys();200}201202public void testForwardVarToInterface() {203DeclarationSnippet i = classKey(assertEval("interface I { default int f() { return x; } }", added(RECOVERABLE_DEFINED)));204assertUnresolvedDependencies1(i, RECOVERABLE_DEFINED, "variable x");205DeclarationSnippet c = classKey(assertEval("class C implements I { int z() { return 2; } }", added(VALID)));206assertEval("C c = new C();");207assertEval("c.z();", "2");208assertEvalUnresolvedException("c.f()", "I", 1, 0);209Snippet g = varKey(assertEval("int x = 55;", "55",210added(VALID),211ste(i, RECOVERABLE_DEFINED, VALID, false, null)));212assertEval("c.f();", "55");213assertUnresolvedDependencies(i, 0);214assertActiveKeys();215}216217public void testForwardVarToEnum() {218DeclarationSnippet a = classKey(assertEval("enum E { Q, W, E; float ff() { return fff; } }", added(RECOVERABLE_DEFINED)));219assertUnresolvedDependencies1(a, RECOVERABLE_DEFINED, "variable fff");220Snippet g = varKey(assertEval("float fff = 4.5f;", "4.5",221added(VALID),222ste(a, RECOVERABLE_DEFINED, VALID, false, null)));223assertEval("E.Q.ff();", "4.5");224assertEval("double fff = 3.3;", "3.3", null,225DiagCheck.DIAG_OK,226DiagCheck.DIAG_ERROR,227ste(MAIN_SNIPPET, VALID, VALID, true, null),228ste(g, VALID, OVERWRITTEN, false, MAIN_SNIPPET),229ste(a, VALID, RECOVERABLE_DEFINED, false, MAIN_SNIPPET));230assertUnresolvedDependencies(a, 0);231assertActiveKeys();232}233234public void testForwardMethodToClass() {235DeclarationSnippet a = classKey(assertEval("class A { int f() { return g(); } }", added(RECOVERABLE_DEFINED)));236assertUnresolvedDependencies1(a, RECOVERABLE_DEFINED, "method g()");237assertEval("A foo() { return null; }");238assertEvalUnresolvedException("new A();", "A", 1, 0);239Snippet g = methodKey(assertEval("int g() { return 10; }",240added(VALID),241ste(a, RECOVERABLE_DEFINED, VALID, false, null)));242assertEval("new A().f();", "10");243assertEval("double g() { return 10; }",244DiagCheck.DIAG_OK,245DiagCheck.DIAG_ERROR,246ste(MAIN_SNIPPET, VALID, VALID, true, null),247ste(g, VALID, OVERWRITTEN, false, MAIN_SNIPPET),248ste(a, VALID, RECOVERABLE_DEFINED, false, MAIN_SNIPPET));249assertUnresolvedDependencies(a, 0);250assertActiveKeys();251}252253public void testForwardClassToClass1() {254Snippet a = classKey(assertEval("class A { B b = new B(); }", added(RECOVERABLE_NOT_DEFINED)));255assertDeclareFail("new A().b;", "compiler.err.cant.resolve.location");256257Snippet b = classKey(assertEval("class B { public String toString() { return \"B\"; } }",258added(VALID),259ste(a, RECOVERABLE_NOT_DEFINED, VALID, true, null)));260assertEval("new A().b;", "B");261assertEval("interface B { }",262DiagCheck.DIAG_OK,263DiagCheck.DIAG_ERROR,264ste(MAIN_SNIPPET, VALID, VALID, true, null),265ste(b, VALID, OVERWRITTEN, false, MAIN_SNIPPET),266ste(a, VALID, RECOVERABLE_DEFINED, true, MAIN_SNIPPET));267assertEvalUnresolvedException("new A().b;", "A", 0, 1);268assertActiveKeys();269}270271public void testForwardClassToClass2() {272Snippet a = classKey(assertEval("class A extends B { }", added(RECOVERABLE_NOT_DEFINED)));273assertDeclareFail("new A();", "compiler.err.cant.resolve.location");274275Snippet b = classKey(assertEval("class B { public String toString() { return \"B\"; } }",276added(VALID),277ste(a, RECOVERABLE_NOT_DEFINED, VALID, true, null)));278assertEval("new A();", "B");279assertEval("interface B { }",280DiagCheck.DIAG_OK,281DiagCheck.DIAG_ERROR,282ste(MAIN_SNIPPET, VALID, VALID, true, null),283ste(b, VALID, OVERWRITTEN, false, MAIN_SNIPPET),284ste(a, VALID, RECOVERABLE_NOT_DEFINED, true, MAIN_SNIPPET));285assertDeclareFail("new A();", "compiler.err.cant.resolve.location");286assertActiveKeys();287}288289public void testForwardClassToClass3() {290Snippet a = classKey(assertEval("interface A extends B { static int f() { return 10; } }", added(RECOVERABLE_NOT_DEFINED)));291assertDeclareFail("A.f();", "compiler.err.cant.resolve.location");292293Snippet b = classKey(assertEval("interface B { }",294added(VALID),295ste(a, RECOVERABLE_NOT_DEFINED, VALID, true, null)));296assertEval("A.f();", "10");297assertEval("class B { }",298DiagCheck.DIAG_OK,299DiagCheck.DIAG_ERROR,300ste(MAIN_SNIPPET, VALID, VALID, true, null),301ste(b, VALID, OVERWRITTEN, false, MAIN_SNIPPET),302ste(a, VALID, RECOVERABLE_NOT_DEFINED, true, MAIN_SNIPPET));303assertDeclareFail("A.f();", "compiler.err.cant.resolve.location");304assertActiveKeys();305}306307public void testForwardVariable() {308assertEval("int f() { return x; }", added(RECOVERABLE_DEFINED));309assertEvalUnresolvedException("f();", "f", 1, 0);310assertActiveKeys();311}312313public void testLocalClassInUnresolved() {314Snippet f = methodKey(assertEval("void f() { class A {} g(); }", added(RECOVERABLE_DEFINED)));315assertEval("void g() {}",316added(VALID),317ste(f, RECOVERABLE_DEFINED, VALID, true, null));318assertEval("f();", "");319}320}321322323