[rfc][icedtea-web] closing listener idea

Jiri Vanek jvanek at redhat.com
Mon Sep 24 07:24:18 PDT 2012


On 09/20/2012 04:58 PM, Adam Domurad wrote:
>
>>>> inclined to agree. Overall, I'm starting to think that a standard,
>>>> magic, "**APPLET FINISHED**" string copypasted into every applet is the
...
>
>
>> diff -r d23356f8a7a6
>> tests/reproducers/signed/AppletTestSigned/testcases/AppletTestSignedTests.java
>> ---
>> a/tests/reproducers/signed/AppletTestSigned/testcases/AppletTestSignedTests.java    Thu Sep 20 10:55:16 2012 +0200
>> +++
>> b/tests/reproducers/signed/AppletTestSigned/testcases/AppletTestSignedTests.java    Thu Sep 20 12:03:40 2012 +0200
>> @@ -43,6 +43,8 @@
>>   import net.sourceforge.jnlp.browsertesting.BrowserTest;
>>   import net.sourceforge.jnlp.browsertesting.Browsers;
>>   import net.sourceforge.jnlp.annotations.TestInBrowsers;
>> +import net.sourceforge.jnlp.closinglisteners.Rule;
>> +import
>> net.sourceforge.jnlp.closinglisteners.RulesFolowingClosingListener;
>>   import org.junit.Assert;
>>
>>   import org.junit.Test;
>> @@ -50,8 +52,22 @@
>>   public class AppletTestSignedTests extends BrowserTest {
>>
>>       private final List<String> l =
>> Collections.unmodifiableList(Arrays.asList(new
>> String[]{"-Xtrustall"}));
>> +    private static final String ss = "xception";
>> +    private static final String s0 = "AppletTestSigned was started";
>> +    private static final String s1 = "value1";
>> +    private static final String s2 = "value2";
>> +    private static final String s3 = "AppletTestSigned was
>> initialised";
>> +    private static final String s7 = "AppletTestSigned killing
>> himself after 2000 ms of life";
>> +    private static final RulesFolowingClosingListener.ContainsRule
>> crss = new RulesFolowingClosingListener.ContainsRule(ss);
> Still a bit of verbosity here that is just a little off-putting (mainly
> because of Java requiring type twice to be honest - once in declaration
> and once in initialization :).

I would rather stay off renaming of old variables in this patch (not reefactoring one), although I 
agree with ...

> The part that's supposed to be the most
> meaningful (the variable name) has the least verbosity.

... ^this :)

So I have refactored ruels name.

> It would be a
> bit better I think if the line read something like:
> private static final Rule exceptionRule = new ContainsRule(ss);
>
> Note that this doesn't require you to move the ContainsRule class, but
> simply import RulesFolowingClosingListener.ContainsRule;

sure, done

>
>> +    private static final RulesFolowingClosingListener.ContainsRule
>> s0ss = new RulesFolowingClosingListener.ContainsRule(s0);
>> +    private static final RulesFolowingClosingListener.ContainsRule
>> s1ss = new RulesFolowingClosingListener.ContainsRule(s1);
>> +    private static final RulesFolowingClosingListener.ContainsRule
>> s2ss = new RulesFolowingClosingListener.ContainsRule(s2);
>> +    private static final RulesFolowingClosingListener.ContainsRule
>> s3ss = new RulesFolowingClosingListener.ContainsRule(s3);
>> +    private static final RulesFolowingClosingListener.ContainsRule
>> s7ss = new RulesFolowingClosingListener.ContainsRule(s7);
>> +    private static final Rule[] okRules = new Rule[]{s0ss, s1ss,
>> s2ss, s3ss, s7ss};
>> +    private static final Rule[] errorRrules = new Rule[]{crss};
> Rrules -> Rules
>>
>> -    @Test
>> +   // @Test
>>       public void AppletTestSignedTest() throws Exception {
>>           ProcessResult pr = server.executeJavawsHeadless(l,
>> "/AppletTestSigned.jnlp");
>>           evaluateSignedApplet(pr, true);
>> @@ -60,18 +76,12 @@
>>       }
>>
>>       private void evaluateSignedApplet(ProcessResult pr, boolean
>> javawsApplet) {
>> -        String s3 = "AppletTestSigned was initialised";
>> -        Assert.assertTrue("AppletTestSigned stdout should contain " +
>> s3 + " but didn't", pr.stdout.contains(s3));
>> -        String s0 = "AppletTestSigned was started";
>> -        Assert.assertTrue("AppletTestSigned stdout should contain " +
>> s0 + " but didn't", pr.stdout.contains(s0));
>> -        String s1 = "value1";
>> -        Assert.assertTrue("AppletTestSigned stdout should contain " +
>> s1 + " but didn't", pr.stdout.contains(s1));
>> -        String s2 = "value2";
>> -        Assert.assertTrue("AppletTestSigned stdout should contain " +
>> s2 + " but didn't", pr.stdout.contains(s2));
>> -        String ss = "xception";
>> -        Assert.assertFalse("AppletTestSigned stderr should not
>> contain " + ss + " but did", pr.stderr.contains(ss));
>> -        String s7 = "AppletTestSigned killing himself after 2000 ms
>> of life";
>> -        Assert.assertTrue("AppletTestSigned stdout should contain " +
>> s7 + " but didn't", pr.stdout.contains(s7));
>> +        Assert.assertTrue("AppletTestSigned stdout " +
>> s3ss.toString() + " but didn't", s3ss.evaluate(pr.stdout));
>> +        Assert.assertTrue("AppletTestSigned stdout " +
>> s0ss.toString() + " but didn't", s0ss.evaluate(pr.stdout));
>> +        Assert.assertTrue("AppletTestSigned stdout " +
>> s1ss.toString() + " but didn't", s1ss.evaluate(pr.stdout));
>> +        Assert.assertTrue("AppletTestSigned stdout " +
>> s2ss.toString() + " but didn't", s2ss.evaluate(pr.stdout));
>> +        Assert.assertFalse("AppletTestSigned stderr " +
>> crss.toNotString() + " but did", crss.evaluate(pr.stderr));
>> +        Assert.assertTrue("AppletTestSigned stdout " +
>> s7ss.toString() + " but didn't", s7ss.evaluate(pr.stdout));
>>           if (!javawsApplet) {
>>               /*this is working correctly in most browser, but not in
>> all. temporarily disabling
>>               String s4 = "AppletTestSigned was stopped";
>> @@ -87,7 +97,7 @@
>>       public void AppletTestSignedFirefoxTestXslowX() throws Exception
>> {
>>           ServerAccess.PROCESS_TIMEOUT = 30 * 1000;
>>           try {
>> -            ProcessResult pr =
>> server.executeBrowser("/AppletTestSigned2.html");
>> +            ProcessResult pr =
>> server.executeBrowser("/AppletTestSigned2.html",new
>> RulesFolowingClosingListener(okRules),new
>> RulesFolowingClosingListener(errorRrules));
>>               evaluateSignedApplet(pr, false);
>>               //Assert.assertTrue(pr.wasTerminated);
>>               //Assert.assertEquals((Integer) 0, pr.returnValue); due
>> to destroy is null
>> diff -r d23356f8a7a6
>> tests/reproducers/simple/AppletTest/testcases/AppletTestTests.java
>> ---
>> a/tests/reproducers/simple/AppletTest/testcases/AppletTestTests.java        Thu Sep 20 10:55:16 2012 +0200
>> +++
>> b/tests/reproducers/simple/AppletTest/testcases/AppletTestTests.java        Thu Sep 20 12:03:40 2012 +0200
>> @@ -35,6 +35,7 @@
>>   exception statement from your version.
>>    */
>>
>> +import net.sourceforge.jnlp.closinglisteners.CountingClosingListener;
>>   import net.sourceforge.jnlp.ProcessResult;
>>   import net.sourceforge.jnlp.ServerAccess;
>>   import net.sourceforge.jnlp.browsertesting.BrowserTest;
>> @@ -47,6 +48,24 @@
>>
>>   public class AppletTestTests extends BrowserTest {
>>
>> +    private final String s7 = "Aplet killing himself after 2000 ms of
>> life";
> Aplet -> Applet (Is there another occurence of this typo ?)

I let it be intentionally, it is also in src and more tests depend on it.

>> +    private final String ss = "xception";
> I'm wondering what case this covers as opposed to "Exception" ? It's
> fine though, as there are no other english words that end in xception :)
>> +    private final String s2 = "value2";
>> +    private final String s1 = "value1";
>> +    private final String s0 = "applet was started";
>> +    private final String s3 = "applet was initialised";
>> +
>> +    private class CountingClosingListenerImpl extends
>> CountingClosingListener {
>> +
>> +        @Override
>> +        protected boolean isAlowedToFinish(String s) {
>> +            if (s.contains(ss)) {
>> +                return true;
>> +            }
>> +            return (s.contains(s0) && s.contains(s1) &&
>> s.contains(s2) && s.contains(s3) && s.contains(s7));
>> +        }
>> +    }
>> +
>>       @Test
>>       @TestInBrowsers(testIn = {Browsers.googleChrome})
>>       @NeedsDisplay
>> @@ -55,7 +74,7 @@
>>           try {
>>               //System.out.println("connecting AppletInFirefoxTest
>> request in " + getBrowser().toString());
>>               //just verify loging is recording browser
>> -            ProcessResult pr1 =
>> server.executeBrowser("/appletAutoTests.html");
>> +            ProcessResult pr1 =
>> server.executeBrowser("/appletAutoTests2.html", new
>> CountingClosingListenerImpl(), new CountingClosingListenerImpl());
>>               if (pr1.process == null) {
>>                   Assert.assertTrue("If proces was null here, then
>> google-chrome had to not exist, and so "
>>                           + ServerAccess.UNSET_BROWSER
>> @@ -64,12 +83,12 @@
>>
>> pr1.deadlyException.getMessage().contains(ServerAccess.UNSET_BROWSER));
>>                   return;
>>               }
>> -            evaluateApplet(pr1,false);
>> +            evaluateApplet(pr1, false);
>>               Assert.assertTrue(pr1.wasTerminated);
>>               //System.out.println("connecting AppletInFirefoxTest
>> request in " + getBrowser().toString());
>>               // just verify loging is recording browser
>> -            ServerAccess.ProcessResult pr =
>> server.executeBrowser("/appletAutoTests.html");
>> -            evaluateApplet(pr,false);
>> +            ServerAccess.ProcessResult pr =
>> server.executeBrowser("/appletAutoTests2.html", new
>> CountingClosingListenerImpl(), new CountingClosingListenerImpl());
>> +            evaluateApplet(pr, false);
>>               Assert.assertTrue(pr.wasTerminated);
>>           } finally {
>>               ServerAccess.PROCESS_TIMEOUT = 20 * 1000; //back to
>> normal
>> @@ -80,30 +99,24 @@
>>       @NeedsDisplay
>>       public void AppletTest() throws Exception {
>>           ProcessResult pr = server.executeJavawsHeadless(null,
>> "/AppletTest.jnlp");
>> -        evaluateApplet(pr,true);
>> +        evaluateApplet(pr, true);
>>           Assert.assertFalse(pr.wasTerminated);
>>           Assert.assertEquals((Integer) 0, pr.returnValue);
>>       }
>>
>>       private void evaluateApplet(ProcessResult pr, boolean
>> javawsApplet) {
>> -        String s3 = "applet was initialised";
>>           Assert.assertTrue("AppletTest stdout should contains " + s3 +
>> " bud didn't", pr.stdout.contains(s3));
>> -        String s0 = "applet was started";
>>           Assert.assertTrue("AppletTest stdout should contains " + s0 +
>> " bud didn't", pr.stdout.contains(s0));
>> -        String s1 = "value1";
>>           Assert.assertTrue("AppletTest stdout should contains " + s1 +
>> " bud didn't", pr.stdout.contains(s1));
>> -        String s2 = "value2";
>>           Assert.assertTrue("AppletTest stdout should contains " + s2 +
>> " bud didn't", pr.stdout.contains(s2));
>> -        String ss = "xception";
>>           Assert.assertFalse("AppletTest stderr should not contains " +
>> ss + " but did", pr.stderr.contains(ss));
>> -        String s7 = "Aplet killing himself after 2000 ms of life";
>>           Assert.assertTrue("AppletTest stdout should contains " + s7 +
>> " bud didn't", pr.stdout.contains(s7));
>>           if (!javawsApplet) {
>>               /*this is working correctly in most browser, but not in
>> all. temporarily disabling
>> -        String s4 = "applet was stopped";
>> -        Assert.assertTrue("AppletTest stdout should contains " + s4 +
>> " bud did't", pr.stdout.contains(s4));
>> -        String s5 = "applet will be destroyed";
>> -        Assert.assertTrue("AppletTest stdout should contains " + s5 +
>> " bud did't", pr.stdout.contains(s5));
>> +            String s4 = "applet was stopped";
>> +            Assert.assertTrue("AppletTest stdout should contains " +
>> s4 + " bud did't", pr.stdout.contains(s4));
>> +            String s5 = "applet will be destroyed";
>> +            Assert.assertTrue("AppletTest stdout should contains " +
>> s5 + " bud did't", pr.stdout.contains(s5));
>>                */
>>           }
>>       }
>> @@ -116,8 +129,8 @@
>>           //just verify loging is recordingb rowser
>>           ServerAccess.PROCESS_TIMEOUT = 30 * 1000;
>>           try {
>> -            ProcessResult pr =
>> server.executeBrowser("/appletAutoTests2.html");
>> -            evaluateApplet(pr,false);
>> +            ProcessResult pr =
>> server.executeBrowser("/appletAutoTests2.html", new
>> CountingClosingListenerImpl(), new CountingClosingListenerImpl());
>> +            evaluateApplet(pr, false);
>>               Assert.assertTrue(pr.wasTerminated);
>>               //Assert.assertEquals((Integer) 0, pr.returnValue); due
>> to destroy is null
>>           } finally {
>> @@ -132,9 +145,9 @@
>>           //just verify loging is recording browser
>>           ServerAccess.PROCESS_TIMEOUT = 30 * 1000;
>>           try {
>> -            ProcessResult pr =
>> server.executeBrowser("/appletAutoTests.html");
>> +            ProcessResult pr =
>> server.executeBrowser("/appletAutoTests.html", new
>> CountingClosingListenerImpl(), new CountingClosingListenerImpl());
>>               pr.process.destroy();
>> -            evaluateApplet(pr,false);
>> +            evaluateApplet(pr, false);
>>               Assert.assertTrue(pr.wasTerminated);
>>               //Assert.assertEquals((Integer) 0, pr.returnValue); due
>> to destroy is null
>>           } finally {
>> diff -r d23356f8a7a6
>> tests/test-extensions/net/sourceforge/jnlp/closinglisteners/CountingClosingListener.java
>> --- /dev/null   Thu Jan 01 00:00:00 1970 +0000
>> +++
>> b/tests/test-extensions/net/sourceforge/jnlp/closinglisteners/CountingClosingListener.java  Thu Sep 20 12:03:40 2012 +0200
>> @@ -0,0 +1,60 @@
>> +/* CountingClosingListener.java
>> +Copyright (C) 2012 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.
>> + */
>> +package net.sourceforge.jnlp.closinglisteners;
>> +
>> +import net.sourceforge.jnlp.ClosingListener;
>> +
>> +public abstract class CountingClosingListener extends ClosingListener
>> {
>> +
>> +    protected StringBuilder sb = new StringBuilder();
>> +
>> +    @Override
>> +    public void charReaded(char ch) {
>> +        sb.append(ch);
>> +        if (isAlowedToFinish(sb.toString())) {
>> +            terminate();
>> +        }
>> +
>> +    }
>> +
>> +    @Override
>> +    public void lineReaded(String s) {
>> +        //nothing to do
>> +    }
>> +
>> +    protected abstract boolean isAlowedToFinish(String content);
>> +}
>> diff -r d23356f8a7a6
>> tests/test-extensions/net/sourceforge/jnlp/closinglisteners/Rule.java
>> --- /dev/null   Thu Jan 01 00:00:00 1970 +0000
>> +++
>> b/tests/test-extensions/net/sourceforge/jnlp/closinglisteners/Rule.java     Thu Sep 20 12:03:40 2012 +0200
>> @@ -0,0 +1,47 @@
>> +/* Rule.java
>> +Copyright (C) 2012 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.
>> +*/
>> +package net.sourceforge.jnlp.closinglisteners;
>> +
>> +public interface Rule<S,T> {
> Oh boy this is so generic it reminds me of the Boost C++ library :). (If
> you're unfamiliar, almost all their types take <type> parameters.)

Yap, I'm familiar, and I don like it :)

However here it seemed to me useful - kept.

>> +
>> +    public void setRule(S rule);
>> +    public boolean evaluate(T upon);
>> +    @Override
>> +    public String toString();
>> +    public String toNotString();
>> +
>> +}
>> diff -r d23356f8a7a6
>> tests/test-extensions/net/sourceforge/jnlp/closinglisteners/RulesFolowingClosingListener.java
>> --- /dev/null   Thu Jan 01 00:00:00 1970 +0000
>> +++
>> b/tests/test-extensions/net/sourceforge/jnlp/closinglisteners/RulesFolowingClosingListener.java     Thu Sep 20 12:03:40 2012 +0200
>> @@ -0,0 +1,238 @@
>> +/* RulesFolowingClosingListener.java
>> +Copyright (C) 2012 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.
>> + */
>> +package net.sourceforge.jnlp.closinglisteners;
>> +
>> +import java.util.ArrayList;
>> +import java.util.Arrays;
>> +import java.util.List;
>> +
>> +public class RulesFolowingClosingListener extends
>> CountingClosingListener {
>> +
>> +    private List<Rule> rules = new ArrayList<Rule>();
>> +
>> +    public static class ContainsRule extends StringRule<String,
>> String> {
>> +
>> +        public ContainsRule(String s) {
>> +            super(s);
>> +        }
> There's considerable overlap between Contains and NotContains, what do
> you think about an inversion flag ?
>> +
>> +        @Override
>> +        public boolean evaluate(String upon) {
>> +            return (upon.contains(rule));
>> +        }
>> +
>> +        @Override
>> +        public String toString() {
>> +            return "should contains `" + rule + "`";
>> +        }
> 'should contains' -> 'should contain'
fixed in all new code

> Although its a tough call, I'm inclined to say this is a bit of an abuse
> of toString(). It's a built-in that doesn't have a natural 'opposite'
> like you're giving it. toPassingString() and to toFailingString() might
> be better, but feel free to leave it if it feels more natural to you.

I compeltely agree. Refactored as sugested
>> +
>> +        @Override
>> +        public String toNotString() {
>> +            return "should NOT contains `" + rule + "`";
> 'should NOT contains' -> 'should NOT contain', similar cases below
fixed in all new code
>> +        }
>> +    }
>> +
>> +    public static class NotContainsRule extends StringRule<String,
>> String> {
>> +
>> +        public NotContainsRule(String s) {
>> +            super(s);
>> +        }
>> +
>> +        @Override
>> +        public boolean evaluate(String upon) {
>> +            return !(upon.contains(rule));
>> +        }
>> +
>> +        @Override
>> +        public String toString() {
>> +            return "should NOT contains `" + rule + "`";
>> +        }
>> +
>> +        @Override
>> +        public String toNotString() {
>> +            return "should contains `" + rule + "`";
>> +        }
>> +    }
>> +
>> +    public static class MatchesRule extends StringRule<String,
>> String> {
>> +
>> +        public MatchesRule(String s) {
>> +            super(s);
>> +        }
>> +
>> +        @Override
>> +        public boolean evaluate(String upon) {
>> +            return (upon.matches(rule));
>> +        }
>> +
>> +        @Override
>> +        public String toString() {
>> +            return "should match `" + rule + "`";
>> +        }
>> +
>> +        @Override
>> +        public String toNotString() {
>> +            return "should NOT match `" + rule + "`";
>> +        }
>> +    }
>> +
>> +    public static class NotMatchesRule extends StringRule<String,
>> String> {
>> +
>> +        public NotMatchesRule(String s) {
>> +            super(s);
>> +        }
>> +
>> +        @Override
>> +        public boolean evaluate(String upon) {
>> +            return !(upon.matches(rule));
>> +        }
>> +
>> +        @Override
>> +        public String toString() {
>> +            return "should NOT match`" + rule + "`";
>> +        }
>> +
>> +        @Override
>> +        public String toNotString() {
>> +            return "should match`" + rule + "`";
>> +        }
>> +    }
>> +
>> +    /**
>> +     *
>> +     * @param rule
>> +     * @return self, to alow chaing add(...).add(..)...
>> +     */
>> +    public RulesFolowingClosingListener addRule(Rule rule) {
>> +        this.rules.add(rule);
>> +        return this;
>> +    }
>> +
>> +    /**
>> +     *
>> +     * @param rule
>> +     * @return self, to alow chaing add(...).add(..)...
>> +     */
>> +    public RulesFolowingClosingListener addMatchingRule(String rule)
>> {
>> +        this.rules.add(new MatchesRule(rule));
>> +        return this;
>> +    }
>> +
>> +    /**
>> +     *
>> +     * @param rule
>> +     * @return self, to alow chaing add(...).add(..)...
>> +     */
>> +    public RulesFolowingClosingListener addNotMatchingRule(String
>> rule) {
>> +        this.rules.add(new NotMatchesRule(rule));
>> +        return this;
>> +    }
>> +
>> +    /**
>> +     *
>> +     * @param rule
>> +     * @return self, to alow chaing add(...).add(..)...
>> +     */
>> +    public RulesFolowingClosingListener addContainsRule(String rule)
>> {
>> +        this.rules.add(new ContainsRule(rule));
>> +        return this;
>> +    }
>> +
>> +    /**
>> +     *
>> +     * @param rule
>> +     * @return self, to alow chaing add(...).add(..)...
>> +     */
>> +    public RulesFolowingClosingListener addNotContainsRule(String
>> rule) {
>> +        this.rules.add(new NotContainsRule(rule));
>> +        return this;
>> +    }
>> +
>> +    public RulesFolowingClosingListener() {
>> +    }
>> +
>> +    public RulesFolowingClosingListener(List<Rule> l) {
>> +        addRules(l);
>> +    }
>> +
>> +    public RulesFolowingClosingListener(Rule[] l) {
>> +        addRules(l);
>> +    }
>> +
>> +    public void setRules(List<Rule> rules) {
>> +        if (rules == null) {
>> +            throw new NullPointerException("rules cant be null");
>> +        }
>> +        this.rules = rules;
>> +    }
>> +
>> +    public void setRules(Rule[] rules) {
>> +        if (rules == null) {
>> +            throw new NullPointerException("rules cant be null");
>> +        }
>> +        this.rules = Arrays.asList(rules);
>> +    }
>> +
>> +     public void addRules(List<Rule> rules) {
>> +        if (rules == null) {
>> +            throw new NullPointerException("rules cant be null");
>> +        }
>> +        this.rules.addAll(rules);
>> +    }
>> +
>> +    public void addRules(Rule[] rules) {
> Is there a reason you wouldn't want this as Rule... ? This would still
> allow for passing an array, but allow more convenience than creating an
> array explicitly.
>> +        if (rules == null) {
>> +            throw new NullPointerException("rules cant be null");
>> +        }
>> +        this.rules.addAll(Arrays.asList(rules));
>> +    }
>> +
>> +    @Override
>> +    protected boolean isAlowedToFinish(String content) {
>> +        if (rules == null || rules.size() < 1) {
>> +            throw new IllegalStateException("No rules specified");
>> +        }
>> +        for (Rule rule : rules) {
>> +            if (!rule.evaluate(content)) {
> So all rules have to match for it to close ?

Yes!  And Imho it is the only correct thing to do (and reason why I'm not 100% for Auto*ClsoingListener)
In case of multithread applet this will become absolutely necessary. (or to make some additional 
sync in applet, which is unnecessary overhead)

>> +                return false;
>> +            }
>> +        }
>> +        return true;
>> +
>> +
>> +    }
>> +}
>> diff -r d23356f8a7a6
>> tests/test-extensions/net/sourceforge/jnlp/closinglisteners/StringRule.java
>> --- /dev/null   Thu Jan 01 00:00:00 1970 +0000
>> +++
>> b/tests/test-extensions/net/sourceforge/jnlp/closinglisteners/StringRule.java       Thu Sep 20 12:03:40 2012 +0200
>> @@ -0,0 +1,57 @@
>> +/* StringRule.java
>> +Copyright (C) 2012 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.
>> +*/
>> +package net.sourceforge.jnlp.closinglisteners;
>> +
>> +public abstract class StringRule<String,T>  implements Rule<String,
>> T>{
> I'm confused, why isn't this type simply StringRule<T> ? (Isn't String
> here being parsed as a generic type ?? I must admit I've never seen
> concrete types in this location.)

Sure. Fixed
>> +    protected String rule;
>> +
>> +    public StringRule(String rule) {
>> +        setRule(rule);
>> +    }
>> +
>> +    public StringRule() {
>> +    }
>> +
>> +
>> +    @Override
>> +    public void setRule(String rule){
>> +        this.rule=rule;
>> +    }
>> +    @Override
>> +    public abstract boolean evaluate(T upon);
>> +
>> +}
>>

> Thanks for the patch!

Tahnk yo for review :)

> - Adam
>

-------------- next part --------------
A non-text attachment was scrubbed...
Name: closingListener_5_2.diff
Type: text/x-patch
Size: 25446 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120924/a137ab6a/closingListener_5_2.diff 


More information about the distro-pkg-dev mailing list