[RFC][icedtea-web] Test for regression of ServiceManager not setup correctly

Jiri Vanek jvanek at redhat.com
Wed Jun 13 07:28:27 PDT 2012


On 06/08/2012 11:43 PM, Danesh Dadachanji wrote:
> On 20/04/12 04:05 AM, Jiri Vanek wrote:
>>>>>> In general, am not sure how good these applet tests might be. We know
>>>>>> that applets run under javaws use different code paths from applets run
>>>>>> under a browser. Still it's better to have a few tests than none.
>>>>>
>>>> As mentioned above in-html tests will be necessary to be added when
>>>> browser-testing will be pushed.
>>>>
>>>
>>> Will do.
>>>
>>>>
>>>>
>>
>>
>> Just reminder O:)
>
> I had it on my TODO list =)
>
> What do you think of the attached patch? It adds the test, refactors CheckServices into a helper
> method and adds the @NeedsDisplay annotations.
>
> ChangeLog:
> +2012-06-08  Danesh Dadachanji <ddadacha at redhat.com>
> +
> +    Update CheckServices reproducer to handle browser testcase.
> +    * tests/jnlp_tests/simple/CheckServices/testcases/CheckServicesTests.java:
> +    Added browser test and annotation, refactored asserts into helper method.
> +    * tests/jnlp_tests/simple/CheckServices/resources/CheckPluginServices.html:
> +    New browser test file that runs applet using jnlp_href.
> +
>
> Okay for HEAD?

Looks ok. Just two minors lower, feel free to push after fix.

End ensure it compiles;)

J
>
> Cheers,
> Danesh
>
> check-services-update-01.patch
>
>
> diff --git a/tests/jnlp_tests/simple/CheckServices/resources/CheckPluginServices.html b/tests/jnlp_tests/simple/CheckServices/resources/CheckPluginServices.html
> new file mode 100644
> --- /dev/null
> +++ b/tests/jnlp_tests/simple/CheckServices/resources/CheckPluginServices.html
> @@ -0,0 +1,46 @@
> +<!--
> +
> +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.
> +
> +-->
> +<html>
> +<head></head>
> +<body>

please quotes.

> +<applet code="CheckServices" width=800 height=600>
> +<param name="jnlp_href" value="CheckServices.jnlp">
> +</applet>
> +</body>
> +</html>
> +
> diff --git a/tests/jnlp_tests/simple/CheckServices/testcases/CheckServicesTests.java b/tests/jnlp_tests/simple/CheckServices/testcases/CheckServicesTests.java
> --- a/tests/jnlp_tests/simple/CheckServices/testcases/CheckServicesTests.java
> +++ b/tests/jnlp_tests/simple/CheckServices/testcases/CheckServicesTests.java
> @@ -36,7 +36,10 @@
>    */
>
>   import net.sourceforge.jnlp.ServerAccess;
> +import net.sourceforge.jnlp.ServerAccess.ProcessResult;
>   import net.sourceforge.jnlp.annotations.Bug;
> +import net.sourceforge.jnlp.annotations.NeedsDisplay;
> +
>   import org.junit.Assert;
>   import org.junit.Test;
>
> @@ -45,9 +48,7 @@
>
>       private static ServerAccess server = new ServerAccess();
>
> -    @Test
> -    public void CheckServices() throws Exception {
> -        ServerAccess.ProcessResult pr = server.executeJavawsHeadless(null, "/CheckServices.jnlp");
> +    public void evaluateApplet(ProcessResult pr) {
>           String s0 = "Codebase for applet was found in constructor";
>           Assert.assertTrue("CheckServices stdout should contain `" + s0 + "' bud didn't.", pr.stdout.contains(s0));
>           String s1 = "Codebase for applet was found in init()";
> @@ -65,6 +66,22 @@
>           Assert.assertFalse("CheckServices stderr should not contain `" + s5 + "' bud did.", pr.stdout.contains(s5));
>           String s6 = "Applet killing itself after 2000 ms of life";
>           Assert.assertTrue("CheckServices stdout should contain `" + s6 + "' bud didn't.", pr.stdout.contains(s6));
> +    }
> +
> +    @Test
> +    @NeedsDisplay
NeedsDisplay+executeJavawsHeadless is not possible.
Applets should be launched via executeJavaws
> +    public void CheckWebstartServices() throws Exception {
> +        ProcessResult pr = server.executeJavawsHeadless(null, "/CheckServices.jnlp");
> +        evaluateApplet(pr);
> +        Assert.assertFalse(pr.wasTerminated);
>           Assert.assertEquals((Integer)0, pr.returnValue);
>       }
> +
> +    @Test
> +    @NeedsDisplay
> +    public void CheckPluginJNLPHServices() throws Exception {
> +        ProcessResult pr = server.executeBrowser(null, "/CheckPluginServices.html");
> +        evaluateApplet(pr);
> +        Assert.assertTrue(pr.wasTerminated);
> +    }
>   }
>




More information about the distro-pkg-dev mailing list