| /* |
| * Copyright (c) 2015, 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 8166744 |
| * @summary Test Completion |
| * @modules jdk.internal.le/jdk.internal.org.jline.reader |
| * jdk.jshell/jdk.internal.jshell.tool:+open |
| * @build HistoryTest |
| * @run testng HistoryTest |
| */ |
| |
| import java.lang.reflect.Field; |
| import java.lang.reflect.Method; |
| import java.util.Locale; |
| import java.util.logging.Level; |
| import java.util.logging.Logger; |
| |
| import org.testng.annotations.Test; |
| import jdk.internal.jshell.tool.JShellTool; |
| import jdk.internal.jshell.tool.JShellToolBuilder; |
| import jdk.internal.org.jline.reader.History; |
| import static org.testng.Assert.*; |
| import org.testng.annotations.BeforeMethod; |
| |
| public class HistoryTest extends ReplToolTesting { |
| |
| private JShellTool repl; |
| |
| @Override |
| protected void testRawRun(Locale locale, String[] args) { |
| // turn on logging of launch failures |
| Logger.getLogger("jdk.jshell.execution").setLevel(Level.ALL); |
| repl = ((JShellToolBuilder) builder(locale)) |
| .rawTool(); |
| try { |
| repl.start(args); |
| } catch (Exception ex) { |
| fail("Repl tool died with exception", ex); |
| } |
| } |
| |
| @Test |
| public void testHistory() { |
| test( |
| a -> {if (!a) setCommandInput("void test() {\n");}, |
| a -> {if (!a) setCommandInput(" System.err.println(1);\n");}, |
| a -> {if (!a) setCommandInput(" System.err.println(1);\n");}, |
| a -> {assertCommand(a, "} //test", "| created method test()");}, |
| a -> { |
| if (!a) { |
| try { |
| previousAndAssert(getHistory(), "void test() {\n" + |
| " System.err.println(1);\n" + |
| " System.err.println(1);\n" + |
| "} //test"); |
| } catch (Exception ex) { |
| throw new IllegalStateException(ex); |
| } |
| } |
| assertCommand(a, "int dummy;", "dummy ==> 0"); |
| }); |
| test( |
| a -> {if (!a) setCommandInput("void test2() {\n");}, |
| a -> {assertCommand(a, "} //test2", "| created method test2()");}, |
| a -> { |
| if (!a) { |
| try { |
| previousAndAssert(getHistory(), "void test2() {\n" + |
| "} //test2"); |
| previousAndAssert(getHistory(), "/debug 0"); //added by test framework |
| previousAndAssert(getHistory(), "/exit"); |
| previousAndAssert(getHistory(), "int dummy;"); |
| previousAndAssert(getHistory(), "void test() {\n" + |
| " System.err.println(1);\n" + |
| " System.err.println(1);\n" + |
| "} //test"); |
| } catch (Exception ex) { |
| throw new IllegalStateException(ex); |
| } |
| } |
| assertCommand(a, "int dummy;", "dummy ==> 0"); |
| }); |
| } |
| |
| @Test |
| public void test8166744() { |
| test( |
| a -> {if (!a) setCommandInput("class C {\n");}, |
| a -> {if (!a) setCommandInput("void f() {\n");}, |
| a -> {if (!a) setCommandInput("}\n");}, |
| a -> {assertCommand(a, "}", "| created class C");}, |
| a -> { |
| if (!a) { |
| try { |
| previousAndAssert(getHistory(), "class C {\n" + |
| "void f() {\n" + |
| "}\n" + |
| "}"); |
| getHistory().add("class C {\n" + |
| "void f() {\n" + |
| "}\n" + |
| "}"); |
| } catch (Exception ex) { |
| throw new IllegalStateException(ex); |
| } |
| } |
| assertCommand(a, "int dummy;", "dummy ==> 0"); |
| }); |
| test( |
| a -> {if (!a) setCommandInput("class C {\n");}, |
| a -> {if (!a) setCommandInput("void f() {\n");}, |
| a -> {if (!a) setCommandInput("}\n");}, |
| a -> {assertCommand(a, "}", "| created class C");}, |
| a -> { |
| if (!a) { |
| try { |
| previousAndAssert(getHistory(), "class C {\n" + |
| "void f() {\n" + |
| "}\n" + |
| "}"); |
| getHistory().add("class C {\n" + |
| "void f() {\n" + |
| "}\n" + |
| "}"); |
| } catch (Exception ex) { |
| throw new IllegalStateException(ex); |
| } |
| } |
| assertCommand(a, "int dummy;", "dummy ==> 0"); |
| }); |
| } |
| |
| @Test |
| public void testReadExistingHistory() { |
| prefsMap.put("HISTORY_LINE_0", "/debug 0"); |
| prefsMap.put("HISTORY_LINE_1", "void test() {\\"); |
| prefsMap.put("HISTORY_LINE_2", " System.err.println(1);\\"); |
| prefsMap.put("HISTORY_LINE_3", " System.err.println(`\\\\\\\\\\"); |
| prefsMap.put("HISTORY_LINE_4", " \\\\\\"); |
| prefsMap.put("HISTORY_LINE_5", "`);\\"); |
| prefsMap.put("HISTORY_LINE_6", "} //test"); |
| test( |
| a -> {assertCommand(a, "int i", "i ==> 0");}, |
| a -> { |
| if (!a) { |
| try { |
| previousAndAssert(getHistory(), "int i"); |
| previousAndAssert(getHistory(), "/debug 0"); //added by test framework |
| previousAndAssert(getHistory(), "void test() {\n" + |
| " System.err.println(1);\n" + |
| " System.err.println(`\\\\\n" + |
| " \\\n" + |
| "`);\n" + |
| "} //test"); |
| } catch (Exception ex) { |
| throw new IllegalStateException(ex); |
| } |
| } |
| assertCommand(a, "/exit", ""); |
| }); |
| assertEquals(prefsMap.get("HISTORY_LINE_00"), "/debug 0"); |
| assertEquals(prefsMap.get("HISTORY_LINE_01"), "void test() {\\"); |
| assertEquals(prefsMap.get("HISTORY_LINE_02"), " System.err.println(1);\\"); |
| assertEquals(prefsMap.get("HISTORY_LINE_03"), " System.err.println(`\\\\\\\\\\"); |
| assertEquals(prefsMap.get("HISTORY_LINE_04"), " \\\\\\"); |
| assertEquals(prefsMap.get("HISTORY_LINE_05"), "`);\\"); |
| assertEquals(prefsMap.get("HISTORY_LINE_06"), "} //test"); |
| assertEquals(prefsMap.get("HISTORY_LINE_07"), "/debug 0"); |
| assertEquals(prefsMap.get("HISTORY_LINE_08"), "int i"); |
| assertEquals(prefsMap.get("HISTORY_LINE_09"), "/exit"); |
| System.err.println("prefsMap: " + prefsMap); |
| } |
| |
| private History getHistory() throws Exception { |
| Field input = repl.getClass().getDeclaredField("input"); |
| input.setAccessible(true); |
| Object console = input.get(repl); |
| Method getHistory = console.getClass().getDeclaredMethod("getHistory"); |
| getHistory.setAccessible(true); |
| return (History) getHistory.invoke(console); |
| } |
| |
| private void previousAndAssert(History history, String expected) { |
| assertTrue(history.previous()); |
| assertEquals(history.current().toString(), expected); |
| } |
| |
| @BeforeMethod |
| public void setUp() { |
| super.setUp(); |
| System.setProperty("jshell.test.allow.incomplete.inputs", "false"); |
| } |
| |
| } |