/*
* 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" );
}
}
Messung V0.5 in Prozent C=97 H=87 G=91
¤ Dauer der Verarbeitung: 0.4 Sekunden
¤
*© Formatika GbR, Deutschland