[rfc][icedtea-web] Reproducer for: Ignore invalid .jar files in applets
Adam Domurad
adomurad at redhat.com
Thu Jun 14 12:26:13 PDT 2012
Updated reproducer. Hopefully this one is good for HEAD ?
On Mon, 2012-06-04 at 10:42 +0200, Jiri Vanek wrote:
> On 06/01/2012 04:45 PM, Adam Domurad wrote:
> > Here's is a reproducer for the previous patch (which still needs a
> > reviewer btw).
> Thanx a lot for test! Few hint inline.
>
> >
> > ChangeLog:
> > 2012-06-01 Adam Domurad<adomurad at redhat.com>
> >
> > *
> > tests/jnlp_tests/simple/AppletReadsInvalidJar/resources/AppletReadsInvalidJar.html:
> > *
> > tests/jnlp_tests/simple/AppletReadsInvalidJar/resources/AppletReadsInvalidJar.jnlp:
> > * tests/jnlp_tests/simple/AppletReadsInvalidJar/srcs/Valid.java:
> > *
> > tests/jnlp_tests/simple/AppletReadsInvalidJar/testcases/AppletReadsInvalidJarTests.java:
> > Reproducer for checking behaviour of existing but invalid (corrupt,
> > etc) jar files in .jnlp files (should fail) and applet tags (should be
> > ignored)
>
> It is not clear whether the test should fail, or the test should pass with failure of application. See below for more comments on this topic.
> >
> > On Mon, 2012-05-28 at 16:23 -0400, Adam Domurad wrote:
>
> ...snip...
>
> > +exception statement from your version.
> > + */
> > +public class Valid extends Applet {
> > + @Override
> > + public void init() {
> > + System.out.println("Program Executed Correctly.");
> > + }
> > +}
>
> You do not need to create such a simple application each time, but you can reuse one of the existing. But for this case we can probably live with new one (depends on you)
>
> > diff --git a/tests/jnlp_tests/simple/AppletReadsInvalidJar/testcases/AppletReadsInvalidJarTests.java b/tests/jnlp_tests/simple/AppletReadsInvalidJar/testcases/AppletReadsInvalidJarTests.java
> > new file mode 100644
>
> ...snip...
>
> > +
> > + /*This SHOULD NOT execute the applet!*/
> > + @Test
> > + public void AppletJNLPTest() throws Exception {
> > + long previous_timeout = ServerAccess.PROCESS_TIMEOUT;
> > + /*This test should be short, so set to 2 seconds*/
> > + ServerAccess.PROCESS_TIMEOUT = 2 * 1000;
> > +
> > + ServerAccess.ProcessResult pr = server.executeJavawsHeadless("/AppletReadsInvalidJar.jnlp");
> > +
> > + String s0 = "Program Executed Correctly.";
> > + Assert.assertTrue("AppletTakesLastParam stdout should NOT contain " + s0 + ", but did (applet should not have ran!).", !pr.stdout.contains(s0));
> > +
> > + ServerAccess.PROCESS_TIMEOUT = previous_timeout;
> > + }
>
> In this case you are launching applet in javaws. It will not launch application. Is this time outing necessary? If the applet in javaws is not laoded at all, then
> javaws should be terminated or not?
> Also there is small complex - applets should be launched _without_ hedaless, but if exception is launched in not-headless mode, then dialog-window keeps hanging n the air.
>
> If timeout is really necessary (killer thread is not enough I guess) then the restore of original one must be in finally block.
> Although to check the type of exception can be very handy.
>
> Last comment here - the issue is never going to be fixed (applet by jnlp) correct? In case that it should be fixed n some future, then this test should be failing (@KnownToFail)
>
>
>
> > +
> > + /*This SHOULD execute the applet!*/
> > + @Test
> > + public void AppletInFirefoxTest() throws Exception {
> > + ServerAccess.ProcessResult pr = server.executeBrowser("/AppletReadsInvalidJar.html");
> > +
> > + String s0 = "Program Executed Correctly.";
> > + Assert.assertTrue("AppletTakesLastParam stdout should contain " + s0 + " but did not.", pr.stdout.contains(s0));
> > + }
> > +}
>
> Tahnx for test again!
>
> J.
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: ignore-invalid-jar-files-reproducers-updated.patch
Type: text/x-patch
Size: 13611 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120614/c9899318/ignore-invalid-jar-files-reproducers-updated.patch
More information about the distro-pkg-dev
mailing list