[rfc][icedtea-web] refactored logging
Jiri Vanek
jvanek at redhat.com
Tue Oct 22 07:05:02 PDT 2013
On 10/22/2013 03:42 PM, Omair Majid wrote:
> * Jiri Vanek<jvanek at redhat.com> [2013-10-22 03:40]:
>> > On 10/22/2013 12:42 AM, Omair Majid wrote:
>>> > >It's a bad test. It modifies the global logging configuration and does
>>> > >not restore the original. The modified logging configuration is not
>>> > >visible on all machines because the order in which junit runs the test
>>> > >is not guaranteed; sometimes a later tests modifies the configuration to
>>> > >something which happens to be the default configuration.
>>> > >
>>> > >Does the attached patch look okay?
>> >
>> > I would vote for backuping whole LogConfig instead of individual
>> > fields, but do as you wish. Thanx for catching it.
> Okay, how about the following?
>
> Thanks,
> Omair
>
>
> fix-log-configuration-unit-tests-02.patch
>
>
> diff --git a/netx/net/sourceforge/jnlp/util/logging/LogConfig.java b/netx/net/sourceforge/jnlp/util/logging/LogConfig.java
> --- a/netx/net/sourceforge/jnlp/util/logging/LogConfig.java
> +++ b/netx/net/sourceforge/jnlp/util/logging/LogConfig.java
> @@ -98,6 +98,13 @@
> return logConfig;
> }
>
Well, much better :) But, isn't set/get much more common?
Again, do as you wish :) I'm ok with all three variants.
> + /** For testing only: throw away the previous config */
> + static void resetLogConfig() {
> + if (logConfig != null) {
> + logConfig = new LogConfig();
> + }
> + }
> +
> public String getIcedteaLogDir() {
> return icedteaLogDir;
> }
> diff --git a/tests/netx/unit/net/sourceforge/jnlp/util/logging/OutputControllerTest.java b/tests/netx/unit/net/sourceforge/jnlp/util/logging/OutputControllerTest.java
> --- a/tests/netx/unit/net/sourceforge/jnlp/util/logging/OutputControllerTest.java
> +++ b/tests/netx/unit/net/sourceforge/jnlp/util/logging/OutputControllerTest.java
> @@ -43,6 +43,8 @@
> import net.sourceforge.jnlp.closinglisteners.RulesFolowingClosingListener;
> import net.sourceforge.jnlp.util.StreamUtils;
> import org.junit.Assert;
> +import org.junit.After;
> +import org.junit.Before;
> import org.junit.Test;
>
> public class OutputControllerTest {
> @@ -71,6 +73,16 @@
> }
> }
>
> + @Before
> + public void setUp() {
> + LogConfig.resetLogConfig();
> + }
> +
> + @After
> + public void tearDown() {
> + LogConfig.resetLogConfig();
> + }
> +
> @Test
> public void isLoggingStdStreams() throws Exception {
> ByteArrayOutputStream os1 = new ByteArrayOutputStream();
More information about the distro-pkg-dev
mailing list