/hg/icedtea-web: Nashorn made accessible to javaws applications

jvanek at icedtea.classpath.org jvanek at icedtea.classpath.org
Fri Dec 16 11:45:05 UTC 2016


changeset 2461eeea269f in /hg/icedtea-web
details: http://icedtea.classpath.org/hg/icedtea-web?cmd=changeset;node=2461eeea269f
author: Jiri Vanek <jvanek at redhat.com>
date: Fri Dec 16 12:50:53 2016 +0100

	Nashorn made accessible to javaws applications

	* NEWS: mentioned PR3263
	* launcher/launchers.in: added nashorn to BOOT_CLASSPATH
	* tests/reproducers/signed/jsengineSigned/: reproducer of behavior
	* tests/reproducers/simple/jsengine/: for completeness, added signed reproducer of behavior


diffstat:

 ChangeLog                                                                 |   8 +
 NEWS                                                                      |   1 +
 launcher/launchers.in                                                     |   4 +
 tests/reproducers/signed/jsengineSigned/resources/jsengineSigned.jnlp     |  56 ++++++++
 tests/reproducers/signed/jsengineSigned/srcs/jsengineSigned.java          |  56 ++++++++
 tests/reproducers/signed/jsengineSigned/testcases/jsengineSignedTest.java |  61 +++++++++
 tests/reproducers/simple/jsengine/resources/jsengine.jnlp                 |  53 ++++++++
 tests/reproducers/simple/jsengine/srcs/jsengine.java                      |  56 ++++++++
 tests/reproducers/simple/jsengine/testcases/jsengineTest.java             |  63 ++++++++++
 9 files changed, 358 insertions(+), 0 deletions(-)

diffs (418 lines):

diff -r d5801f6cc5b3 -r 2461eeea269f ChangeLog
--- a/ChangeLog	Mon Nov 21 14:23:11 2016 +0100
+++ b/ChangeLog	Fri Dec 16 12:50:53 2016 +0100
@@ -1,3 +1,11 @@
+2016-12-16  Jiri Vanek <jvanek at redhat.com>
+
+	Nashorn made accessible to javaws applications
+	* NEWS: mentioned PR3263
+	* launcher/launchers.in: added nashorn to BOOT_CLASSPATH
+	* tests/reproducers/signed/jsengineSigned/: reproducer of behavior
+	* tests/reproducers/simple/jsengine/: for completeness, added signed reproducer of behavior
+
 2016-11-21  Jiri Vanek <jvanek at redhat.com>
 
 	internal browser extended for trivial charset selection
diff -r d5801f6cc5b3 -r 2461eeea269f NEWS
--- a/NEWS	Mon Nov 21 14:23:11 2016 +0100
+++ b/NEWS	Fri Dec 16 12:50:53 2016 +0100
@@ -31,6 +31,7 @@
 * RH1231441 Unable to read the text of the buttons of the security dialogue
 * Fixed RH1233697 icedtea-web: applet origin spoofing
 * Fixed RH1233667 icedtea-web: unexpected permanent authorization of unsigned applets
+* FIXED PR3263 - Cannot retrieve JavaScript Engine using ScriptEngineManager.getEngineByName 
 * fixed fatal impact of initialization error of FileLog
 * MissingALACAdialog made available also for unsigned applications (but ignoring actual manifest value) and fixed
 * more dialogs got remember me possibility
diff -r d5801f6cc5b3 -r 2461eeea269f launcher/launchers.in
--- a/launcher/launchers.in	Mon Nov 21 14:23:11 2016 +0100
+++ b/launcher/launchers.in	Fri Dec 16 12:50:53 2016 +0100
@@ -1,5 +1,6 @@
 #!/bin/bash
 
+NASHORN=lib/ext/nashorn.jar
 JAVA=@JAVA@
 LAUNCHER_BOOTCLASSPATH=@LAUNCHER_BOOTCLASSPATH@
 LAUNCHER_FLAGS=-Xms8m
@@ -28,9 +29,12 @@
   if [ -e  "$CUSTOM_JRE" -a -e "$CUSTOM_JRE/bin/java" ] ; then
     JAVA=$CUSTOM_JRE/bin/java
     CP=$CUSTOM_JRE/lib/rt.jar:$CUSTOM_JRE/lib/jfxrt.jar
+    LAUNCHER_BOOTCLASSPATH=$LAUNCHER_BOOTCLASSPATH:$CUSTOM_JRE/$NASHORN
   else
     echo "Your custom JRE $CUSTOM_JRE read from deployment.properties under key $PROPERTY_NAME as $CUSTOM_JRE is not valid. Using default ($JAVA, $CP) in attempt to start. Please fix this."
   fi
+else
+  LAUNCHER_BOOTCLASSPATH="$LAUNCHER_BOOTCLASSPATH:@JRE@/$NASHORN"
 fi;
 
 JDK9="NO"
diff -r d5801f6cc5b3 -r 2461eeea269f tests/reproducers/signed/jsengineSigned/resources/jsengineSigned.jnlp
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/reproducers/signed/jsengineSigned/resources/jsengineSigned.jnlp	Fri Dec 16 12:50:53 2016 +0100
@@ -0,0 +1,56 @@
+<!--
+
+This file is part of IcedTea.
+
+IcedTea is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+IcedTea 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 for more details.
+
+You should have received a copy of the GNU General Public License
+along with IcedTea; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+02110-1301 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version.
+
+ -->
+<?xml version="1.0" encoding="utf-8"?>
+<jnlp spec="1.0" href="jsengineSigned.jnlp" codebase=".">
+  <information>
+    <title>jsengineSigned</title>
+    <vendor>IcedTea</vendor>
+    <homepage href="http://icedtea.classpath.org/wiki/IcedTea-Web#Testing_IcedTea-Web"/>
+    <description>jsengineSigned</description>
+    <offline/>
+  </information>
+  <security>
+      <all-permissions/>
+  </security>
+  <resources>
+    <j2se version="1.4+"/>
+    <jar href="jsengineSigned.jar"/>
+  </resources>
+  <application-desc main-class="jsengineSigned">
+  </application-desc>
+</jnlp>
diff -r d5801f6cc5b3 -r 2461eeea269f tests/reproducers/signed/jsengineSigned/srcs/jsengineSigned.java
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/reproducers/signed/jsengineSigned/srcs/jsengineSigned.java	Fri Dec 16 12:50:53 2016 +0100
@@ -0,0 +1,56 @@
+/* jsengineSigned.java
+Copyright (C) 2011 Red Hat, Inc.
+
+This file is part of IcedTea.
+
+IcedTea is free software; you can redistribute it and/or
+modify it under the terms of the GNU General Public License as published by
+the Free Software Foundation, version 2.
+
+IcedTea 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 for more details.
+
+You should have received a copy of the GNU General Public License
+along with IcedTea; see the file COPYING.  If not, write to
+the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+02110-1301 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version.
+ */
+
+
+import javax.script.ScriptEngine;
+import javax.script.ScriptEngineManager;
+
+public class jsengineSigned{
+    
+    private  static final ScriptEngine engine1 = new ScriptEngineManager().getEngineByName("JavaScript");
+    private  static final ScriptEngine engine2 = new ScriptEngineManager(jsengineSigned.class.getClassLoader()).getEngineByName("JavaScript");
+    private  static final ScriptEngine engine3 = new ScriptEngineManager(null).getEngineByName("JavaScript");
+
+    public static void main(String[] args){
+        System.out.println("starting");
+        System.out.println("A-"+engine1+"-Z");
+        System.out.println("B-"+engine2+"-Y");
+        System.out.println("C-"+engine3+"-X");
+        System.out.println("finished");
+
+    }
+}
diff -r d5801f6cc5b3 -r 2461eeea269f tests/reproducers/signed/jsengineSigned/testcases/jsengineSignedTest.java
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/reproducers/signed/jsengineSigned/testcases/jsengineSignedTest.java	Fri Dec 16 12:50:53 2016 +0100
@@ -0,0 +1,61 @@
+/* jsengineSignedTest.java
+ Copyright (C) 2011 Red Hat, Inc.
+
+ This file is part of IcedTea.
+
+ IcedTea is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, version 2.
+
+ IcedTea 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 for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with IcedTea; see the file COPYING.  If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ 02110-1301 USA.
+
+ Linking this library statically or dynamically with other modules is
+ making a combined work based on this library.  Thus, the terms and
+ conditions of the GNU General Public License cover the whole
+ combination.
+
+ As a special exception, the copyright holders of this library give you
+ permission to link this library with independent modules to produce an
+ executable, regardless of the license terms of these independent
+ modules, and to copy and distribute the resulting executable under
+ terms of your choice, provided that you also meet, for each linked
+ independent module, the terms and conditions of the license of that
+ module.  An independent module is a module which is not derived from
+ or based on this library.  If you modify this library, you may extend
+ this exception to your version of the library, but you are not
+ obligated to do so.  If you do not wish to do so, delete this
+ exception statement from your version.
+ */
+
+import net.sourceforge.jnlp.ProcessResult;
+import net.sourceforge.jnlp.ServerAccess;
+import org.junit.Assert;
+
+import org.junit.Test;
+
+public class jsengineSignedTest {
+
+    private static final ServerAccess server = new ServerAccess();
+    
+    @Test
+    public void jsengineSignedTestcase1() throws Exception {
+        String originalResourceName = "jsengineSigned.jnlp";
+        ProcessResult pr = server.executeJavawsHeadless(null, "/" + originalResourceName);
+        //ServerAccess.logOutputReprint(pr.stderr);
+        //ServerAccess.logOutputReprint(pr.stdout);
+        Assert.assertTrue(pr.stdout.matches("(?s).*starting.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s)(?i).*A-.*nashorn.*-Z.*") || pr.stdout.matches("(?s)(?i).*A-.*rhino.*-Z.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s)(?i).*B-.*nashorn.*-Y.*") || pr.stdout.matches("(?s)(?i).*B-.*rhino.*-Y.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s)(?i).*C-.*nashorn.*-X.*") || pr.stdout.matches("(?s)(?i).*C-.*rhino.*-X.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s).*finished.*"));
+    }
+}
+
diff -r d5801f6cc5b3 -r 2461eeea269f tests/reproducers/simple/jsengine/resources/jsengine.jnlp
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/reproducers/simple/jsengine/resources/jsengine.jnlp	Fri Dec 16 12:50:53 2016 +0100
@@ -0,0 +1,53 @@
+<!--
+
+This file is part of IcedTea.
+
+IcedTea is free software; you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation; either version 2, or (at your option)
+any later version.
+
+IcedTea 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 for more details.
+
+You should have received a copy of the GNU General Public License
+along with IcedTea; see the file COPYING.  If not, write to the
+Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+02110-1301 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version.
+
+ -->
+<?xml version="1.0" encoding="utf-8"?>
+<jnlp spec="1.0" href="jsengine.jnlp" codebase=".">
+  <information>
+    <title>jsengine</title>
+    <vendor>IcedTea</vendor>
+    <homepage href="http://icedtea.classpath.org/wiki/IcedTea-Web#Testing_IcedTea-Web"/>
+    <description>jsengine</description>
+    <offline/>
+  </information>
+  <resources>
+    <j2se version="1.4+"/>
+    <jar href="jsengine.jar"/>
+  </resources>
+  <application-desc main-class="jsengine">
+  </application-desc>
+</jnlp>
diff -r d5801f6cc5b3 -r 2461eeea269f tests/reproducers/simple/jsengine/srcs/jsengine.java
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/reproducers/simple/jsengine/srcs/jsengine.java	Fri Dec 16 12:50:53 2016 +0100
@@ -0,0 +1,56 @@
+/* jsengine.java
+Copyright (C) 2011 Red Hat, Inc.
+
+This file is part of IcedTea.
+
+IcedTea is free software; you can redistribute it and/or
+modify it under the terms of the GNU General Public License as published by
+the Free Software Foundation, version 2.
+
+IcedTea 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 for more details.
+
+You should have received a copy of the GNU General Public License
+along with IcedTea; see the file COPYING.  If not, write to
+the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+02110-1301 USA.
+
+Linking this library statically or dynamically with other modules is
+making a combined work based on this library.  Thus, the terms and
+conditions of the GNU General Public License cover the whole
+combination.
+
+As a special exception, the copyright holders of this library give you
+permission to link this library with independent modules to produce an
+executable, regardless of the license terms of these independent
+modules, and to copy and distribute the resulting executable under
+terms of your choice, provided that you also meet, for each linked
+independent module, the terms and conditions of the license of that
+module.  An independent module is a module which is not derived from
+or based on this library.  If you modify this library, you may extend
+this exception to your version of the library, but you are not
+obligated to do so.  If you do not wish to do so, delete this
+exception statement from your version.
+ */
+
+
+import javax.script.ScriptEngine;
+import javax.script.ScriptEngineManager;
+
+public class jsengine{
+    
+    private  static final ScriptEngine engine1 = new ScriptEngineManager().getEngineByName("JavaScript");
+    private  static final ScriptEngine engine2 = new ScriptEngineManager(jsengine.class.getClassLoader()).getEngineByName("JavaScript");
+    private  static final ScriptEngine engine3 = new ScriptEngineManager(null).getEngineByName("JavaScript");
+
+    public static void main(String[] args){
+        System.out.println("starting");
+        System.out.println("A-"+engine1+"-Z");
+        System.out.println("B-"+engine2+"-Y");
+        System.out.println("C-"+engine3+"-X");
+        System.out.println("finished");
+
+    }
+}
diff -r d5801f6cc5b3 -r 2461eeea269f tests/reproducers/simple/jsengine/testcases/jsengineTest.java
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/reproducers/simple/jsengine/testcases/jsengineTest.java	Fri Dec 16 12:50:53 2016 +0100
@@ -0,0 +1,63 @@
+/* jsengineTest.java
+ Copyright (C) 2011 Red Hat, Inc.
+
+ This file is part of IcedTea.
+
+ IcedTea is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, version 2.
+
+ IcedTea 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 for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with IcedTea; see the file COPYING.  If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ 02110-1301 USA.
+
+ Linking this library statically or dynamically with other modules is
+ making a combined work based on this library.  Thus, the terms and
+ conditions of the GNU General Public License cover the whole
+ combination.
+
+ As a special exception, the copyright holders of this library give you
+ permission to link this library with independent modules to produce an
+ executable, regardless of the license terms of these independent
+ modules, and to copy and distribute the resulting executable under
+ terms of your choice, provided that you also meet, for each linked
+ independent module, the terms and conditions of the license of that
+ module.  An independent module is a module which is not derived from
+ or based on this library.  If you modify this library, you may extend
+ this exception to your version of the library, but you are not
+ obligated to do so.  If you do not wish to do so, delete this
+ exception statement from your version.
+ */
+
+import net.sourceforge.jnlp.ProcessResult;
+import net.sourceforge.jnlp.ServerAccess;
+import net.sourceforge.jnlp.annotations.Bug;
+import org.junit.Assert;
+
+import org.junit.Test;
+
+public class jsengineTest {
+
+    private static final ServerAccess server = new ServerAccess();
+    
+    @Test
+    @Bug(id="PR3263")
+    public void jsengineTestcase1() throws Exception {
+        String originalResourceName = "jsengine.jnlp";
+        ProcessResult pr = server.executeJavawsHeadless(null, "/" + originalResourceName);
+        //ServerAccess.logOutputReprint(pr.stderr);
+        //ServerAccess.logOutputReprint(pr.stdout);
+        Assert.assertTrue(pr.stdout.matches("(?s).*starting.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s)(?i).*A-.*nashorn.*-Z.*") || pr.stdout.matches("(?s)(?i).*A-.*rhino.*-Z.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s)(?i).*B-.*nashorn.*-Y.*") || pr.stdout.matches("(?s)(?i).*B-.*rhino.*-Y.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s)(?i).*C-.*nashorn.*-X.*") || pr.stdout.matches("(?s)(?i).*C-.*rhino.*-X.*"));
+        Assert.assertTrue(pr.stdout.matches("(?s).*finished.*"));
+    }
+}
+


More information about the distro-pkg-dev mailing list