8068524: NashornScriptEngineFactory.getParameter() throws IAE for an unknown key, doesn't conform to the general spec
Reviewed-by: hannesw, attila
This commit is contained in:
parent
8ae9081136
commit
dc2d8b7e11
94
nashorn/samples/jd.js
Normal file
94
nashorn/samples/jd.js
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
#// Usage: jjs -cp <asmtools.jar> jd.js -- <classname> [jdis|jdec]
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* - Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
*
|
||||||
|
* - Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* - Neither the name of Oracle nor the names of its
|
||||||
|
* contributors may be used to endorse or promote products derived
|
||||||
|
* from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
|
||||||
|
* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||||
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||||
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// javap-like disassembler/decoder tool that disassembles/decodes
|
||||||
|
// java classes but with OpenJDK AsmTools disassembler/decoder syntax.
|
||||||
|
// You need to build asmtool.jar from OpenJDK codetools project
|
||||||
|
// specify it with -cp option.
|
||||||
|
|
||||||
|
// See also https://wiki.openjdk.java.net/display/CodeTools/AsmTools
|
||||||
|
|
||||||
|
function usage() {
|
||||||
|
print("Usage: jjs -cp <asmtools.jar> jd.js -- <classname> [jdis|jdec]");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (arguments.length == 0) {
|
||||||
|
usage();
|
||||||
|
}
|
||||||
|
|
||||||
|
// argument handling
|
||||||
|
// convert to internal class name
|
||||||
|
var className = arguments[0].replaceAll('\\.', '/');
|
||||||
|
var tool;
|
||||||
|
if (arguments.length > 1) {
|
||||||
|
tool = arguments[1];
|
||||||
|
switch (tool) {
|
||||||
|
case 'jdis':
|
||||||
|
case 'jdec':
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
usage();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
tool = "jdis"; // default tool
|
||||||
|
}
|
||||||
|
|
||||||
|
// Java classes used
|
||||||
|
var AsmTools = Java.type("org.openjdk.asmtools.Main");
|
||||||
|
var Files = Java.type("java.nio.file.Files");
|
||||||
|
var StandardCopyOption = Java.type("java.nio.file.StandardCopyOption");
|
||||||
|
|
||||||
|
// retrive input stream for .class bytes
|
||||||
|
var cl = AsmTools.class.classLoader;
|
||||||
|
var res = cl.getResource(className + ".class");
|
||||||
|
|
||||||
|
if (res) {
|
||||||
|
var is = res.openStream();
|
||||||
|
var tmpPath;
|
||||||
|
try {
|
||||||
|
// copy the content of the .class to a temp file
|
||||||
|
tmpPath = Files.createTempFile("asmtools-", ".class");
|
||||||
|
// mark as delete-on-exit
|
||||||
|
tmpPath.toFile().deleteOnExit();
|
||||||
|
Files.copy(is, tmpPath, [ StandardCopyOption.REPLACE_EXISTING ]);
|
||||||
|
} finally {
|
||||||
|
is.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
// invoke asmtools Main
|
||||||
|
AsmTools.main([ tool, tmpPath.toString() ]);
|
||||||
|
} else {
|
||||||
|
print("no such class: " + arguments[0]);
|
||||||
|
exit(1);
|
||||||
|
}
|
@ -123,7 +123,7 @@ public final class NashornScriptEngineFactory implements ScriptEngineFactory {
|
|||||||
// used to execute scripts concurrently on multiple threads.
|
// used to execute scripts concurrently on multiple threads.
|
||||||
return null;
|
return null;
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("Invalid key");
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ package jdk.nashorn.api.scripting;
|
|||||||
|
|
||||||
import static org.testng.Assert.assertEquals;
|
import static org.testng.Assert.assertEquals;
|
||||||
import static org.testng.Assert.assertNotNull;
|
import static org.testng.Assert.assertNotNull;
|
||||||
|
import static org.testng.Assert.assertNull;
|
||||||
import static org.testng.Assert.assertTrue;
|
import static org.testng.Assert.assertTrue;
|
||||||
import static org.testng.Assert.fail;
|
import static org.testng.Assert.fail;
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
@ -668,6 +669,17 @@ public class ScriptEngineTest {
|
|||||||
assertEquals("helloworld", inv.invokeMethod(ctx.get(), "join", ""));
|
assertEquals("helloworld", inv.invokeMethod(ctx.get(), "join", ""));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// @bug 8068524: NashornScriptEngineFactory.getParameter() throws IAE
|
||||||
|
// for an unknown key, doesn't conform to the general spec
|
||||||
|
@Test
|
||||||
|
public void getParameterInvalidKeyTest() throws Exception {
|
||||||
|
final ScriptEngineManager manager = new ScriptEngineManager();
|
||||||
|
final ScriptEngine e = manager.getEngineByName("nashorn");
|
||||||
|
// no exception expected here!
|
||||||
|
Object value = e.getFactory().getParameter("no value assigned to this key");
|
||||||
|
assertNull(value);
|
||||||
|
}
|
||||||
|
|
||||||
private static void checkProperty(final ScriptEngine e, final String name)
|
private static void checkProperty(final ScriptEngine e, final String name)
|
||||||
throws ScriptException {
|
throws ScriptException {
|
||||||
final String value = System.getProperty(name);
|
final String value = System.getProperty(name);
|
||||||
|
Loading…
Reference in New Issue
Block a user