[RFC][icedtea-web] PR833 - icedtea-web is failing when cache is corupted.

Deepak Bhole dbhole at redhat.com
Mon Dec 19 07:41:05 PST 2011


* Jiri Vanek <jvanek at redhat.com> [2011-12-13 11:36]:
> 2011-12-13 Jiri Vanek <jvanek at redhat.com>
> 
> 	Fix for PR844
> 	* netx/net/sourceforge/jnlp/cache/CacheLRUWrapper.java:	(getLRUSortedEntries)
> 	instead of error throwing own LRU exception. Also catches more then NumberFormatException
> 	(clearLRUSortedEntries) new method - making soft clearing of cache public
> 	(clearCache) now return true if cache was cleared, false otherwise (or exception)
> 	* netx/net/sourceforge/jnlp/cache/CacheUtil.java: (getCacheFileIfExist) does three tires to load cache.
> 	If ifrst fails, then recently_used file is emptied both in memory and on disc.
> 	When second attemmpt fails, then LRU cache is forcibly cleared. if clearing fails, then error is thrown.
> 	If it pass, then one more try to load entries is allowed. When third attempt fails, then error is  thrown.
> 	* /netx/net/sourceforge/jnlp/cache/LruCacheException.java:
> 	new file, for purpose of catching this particular exception
> 	* netx/net/sourceforge/jnlp/util/PropertiesFile.java: (store) tries to mkdirs to its path.
> 	It is better then to fail when no cache directory exists.
> 	* tests/jnlp_tests/signed/CacheReproducer: new  reproducr trying severals way of corupted cache
> 	 on several types of jnlp files. Is signed because of reflection used.
> 	* tests/jnlp_tests/signed/SimpletestSigned1: signed hello world to be used in  CacheReproducer tests.
> 	* tests/netx/jnlp_testsengine/net/sourceforge/jnlp/ServerAccess.java: timeout for processes doubled,
> 	as clear cache methods sometimes took more then original allowed.
> 
> When badly formated recently_used file is saved (or better not-save-correctly eg because of kill -9 signal) then netx is not starting, but is throwing out error.
> Solution to this is caal netx with -Xclearcache. From my point of view, it should at least warn user and suggest this option, but better can be to clear cache and (recommend) restart iself/toUser.
> I also beive, that it can simply just continue running.
> *warn user and terminate, can be done in any time
> *forcibly clear cache during runtime can be dangerous, as some jars already correctly loaded from cache can depend on this local copy (and what about another instances of netx!)and though netx will much more mysteriously fail later
>        - I was unable to reproduce this behaviour (see testAlreadyLoadedCached1,2,11 and 21 - I was trying to do this, but not sure if successfully)
>        - to try to clear cache (will not be successful in if another netx instance is running), recommend run javaws -Xclearcache and restart and terminate can be the best fix
> *to fake cache  -  is what I do now. It clear cache metadata in  memory and on disc (recently-used). Then continue loading.
>        -if this will not help, clear cache is tried, but I was unable to reproduce this possibility - "soft" clearing of cache solved all problems.
>        -it is not affecting already running javawss, but can cause problems when two javaws are trying to start simultaneously-but I was unable to reproduce this behaviour too (see startParalelInstancesUponBrokenCache test)\
> 
> 

Hi Jiri,

The indentation seems to be all messed up. Can you please repost using
the style guidelines here?

http://icedtea.classpath.org/wiki/IcedTea-Web#Code_style

Thanks!
Deepak

> Any hints welcomed!
> Best Regards
> J.

> diff -r 71f338e881d2 netx/net/sourceforge/jnlp/cache/CacheLRUWrapper.java
> --- a/netx/net/sourceforge/jnlp/cache/CacheLRUWrapper.java	Tue Nov 29 17:13:03 2011 +0100
> +++ b/netx/net/sourceforge/jnlp/cache/CacheLRUWrapper.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -178,10 +178,8 @@
>  
>                      int c = t1.compareTo(t2);
>                      return c < 0 ? 1 : (c > 0 ? -1 : 0);
> -                } catch (NumberFormatException e) {
> -                    // Perhaps an error is too harsh. Maybe just somehow turn
> -                    // caching off if this is the case.
> -                    throw new InternalError("Corrupt LRU file entries");
> +                } catch (Exception e) {
> +                    throw new LruCacheException("Corrupt LRU file entries");
>                  }
>              }
>          });
> @@ -249,4 +247,8 @@
>      public String generateKey(String path) {
>          return System.currentTimeMillis() + "," + getIdForCacheFolder(path);
>      }
> +
> +    void clearLRUSortedEntries() {
> +        cacheOrder.clear();
> +    }
>  }
> diff -r 71f338e881d2 netx/net/sourceforge/jnlp/cache/CacheUtil.java
> --- a/netx/net/sourceforge/jnlp/cache/CacheUtil.java	Tue Nov 29 17:13:03 2011 +0100
> +++ b/netx/net/sourceforge/jnlp/cache/CacheUtil.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -144,16 +144,16 @@
>       * process is using them can be quite disasterous. Hence why Launcher creates lock files
>       * and we check for those by calling {@link #okToClearCache()}
>       */
> -    public static void clearCache() {
> +    public static boolean clearCache() {
>  
>          if (!okToClearCache()) {
>              System.err.println(R("CCannotClearCache"));
> -            return;
> +            return false;
>          }
>  
>          File cacheDir = new File(CacheUtil.cacheDir);
>          if (!(cacheDir.isDirectory())) {
> -            return;
> +            return false;
>          }
>  
>          if (JNLPRuntime.isDebug()) {
> @@ -165,6 +165,7 @@
>          } catch (IOException e) {
>              throw new RuntimeException(e);
>          }
> +        return true;
>      }
>  
>      /**
> @@ -322,7 +323,37 @@
>      private static File getCacheFileIfExist(File urlPath) {
>          synchronized (lruHandler) {
>              File cacheFile = null;
> -            List<Entry<String, String>> entries = lruHandler.getLRUSortedEntries();
> +            int tries=0;
> +            List<Entry<String, String>> entries=null;
> +            do{
> +            try{
> +            tries++;
> +            entries = lruHandler.getLRUSortedEntries();
> +            }catch(LruCacheException ex){
> +                if (tries==1){
> +                    ex.printStackTrace();
> +                    System.out.println("Cache is corupted, will be faked now");
> +                    lruHandler.clearLRUSortedEntries();
> +                    lruHandler.store();
> +                    System.out.println("Faked, continuing. It is strongly recomanded to run javaws -Xclearcache and rerun your application as soon as possible.");
> +                }else if (tries==2){
> +                    ex.printStackTrace();
> +                    System.out.println("Cache is still corupted, will be cleared now");
> +                    boolean clearingresult=CacheUtil.clearCache();
> +                    if (!clearingresult){
> +                        throw new InternalError("Clearing was not sucessfull, probably due to another javaws instance runnin.. Try to shut down all instances of javaws, run javaws -Xclearcache and rerun yout jnlp file");
> +                    }
> +                    System.out.println("Cleared, reloading");
> +                    lruHandler.clearLRUSortedEntries();
> +                    lruHandler.store();
> +                    System.out.println("Reload, restarting, it is strongly recomanded to run javaws -Xclearcache and rerun your application as soon as possible.");
> +
> +                }else{
> +                    throw new InternalError("LRU cache was corrupted. Was cleared, but still is corrupted. Try to shut down all instances of javaws, run javaws -Xclearcache and rerun yout jnlp file");
> +                }
> +
> +            }
> +            }while(entries==null);
>              // Start searching from the most recent to least recent.
>              for (Entry<String, String> e : entries) {
>                  final String key = e.getKey();
> diff -r 71f338e881d2 netx/net/sourceforge/jnlp/cache/LruCacheException.java
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/netx/net/sourceforge/jnlp/cache/LruCacheException.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,23 @@
> +/*
> + * To change this template, choose Tools | Templates
> + * and open the template in the editor.
> + */
> +
> +package net.sourceforge.jnlp.cache;
> +
> +/**
> + *
> + * @author jvanek
> + */
> +class LruCacheException extends RuntimeException{
> +
> +    public LruCacheException() {
> +        super();
> +    }
> +
> +
> +    public LruCacheException(String string) {
> +        super(string);
> +    }
> +
> +}
> diff -r 71f338e881d2 netx/net/sourceforge/jnlp/util/PropertiesFile.java
> --- a/netx/net/sourceforge/jnlp/util/PropertiesFile.java	Tue Nov 29 17:13:03 2011 +0100
> +++ b/netx/net/sourceforge/jnlp/util/PropertiesFile.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -134,6 +134,7 @@
>          OutputStream s = null;
>          try {
>              try {
> +                file.getParentFile().mkdirs();
>                  s = new FileOutputStream(file);
>                  store(s, header);
>              } finally {
> diff -r 71f338e881d2 tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer1.jnlp
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer1.jnlp	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,16 @@
> +<?xml version="1.0" encoding="utf-8"?> 
> +<jnlp spec="1.0"
> +      codebase="./"
> +      href="CacheReproducer1.jnlp">
> +    <information>
> +        <title>read properties using System.getenv()</title>
> +    </information>
> +    <resources>
> +        <jar href="CacheReproducer.jar" main="true"/>
> +        <jar href="SimpletestSigned1.jar" main="false" download="eager"/>  
> +    </resources>
> +    <application-desc main-class="CacheReproducer"/>
> +     <security>
> +      <all-permissions/>
> +    </security>
> +</jnlp>
> diff -r 71f338e881d2 tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer1_1.jnlp
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer1_1.jnlp	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,16 @@
> +<?xml version="1.0" encoding="utf-8"?> 
> +<jnlp spec="1.0"
> +      codebase="./"
> +      href="CacheReproducer1_1.jnlp">
> +    <information>
> +        <title>read properties using System.getenv()</title>
> +    </information>
> +    <resources>
> +        <jar href="CacheReproducer.jar" main="true"/>
> +        <jar href="SimpletestSigned1.jar" main="false" download="lazy"/>
> +    </resources>
> +    <application-desc main-class="CacheReproducer"/>
> +     <security>
> +      <all-permissions/>
> +    </security>
> +</jnlp>
> diff -r 71f338e881d2 tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer2.jnlp
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer2.jnlp	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,16 @@
> +<?xml version="1.0" encoding="utf-8"?> 
> +<jnlp spec="1.0"
> +      codebase="./"
> +      href="CacheReproducer2.jnlp">
> +    <information>
> +        <title>read properties using System.getenv()</title>
> +    </information>
> +    <resources>
> +        <jar href="SimpletestSigned1.jar" main="false" download="eager"/>
> +        <jar href="CacheReproducer.jar" main="true"/>
> +    </resources>
> +    <application-desc main-class="CacheReproducer"/>
> +     <security>
> +      <all-permissions/>
> +    </security>
> +</jnlp>
> diff -r 71f338e881d2 tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer2_1.jnlp
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/CacheReproducer/resources/CacheReproducer2_1.jnlp	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,16 @@
> +<?xml version="1.0" encoding="utf-8"?> 
> +<jnlp spec="1.0"
> +      codebase="./"
> +      href="CacheReproducer2_1.jnlp">
> +    <information>
> +        <title>read properties using System.getenv()</title>
> +    </information>
> +    <resources>
> +        <jar href="SimpletestSigned1.jar" main="false" download="lazy"/>
> +        <jar href="CacheReproducer.jar" main="true"/>
> +    </resources>
> +    <application-desc main-class="CacheReproducer"/>
> +     <security>
> +      <all-permissions/>
> +    </security>
> +</jnlp>
> diff -r 71f338e881d2 tests/jnlp_tests/signed/CacheReproducer/srcs/CacheReproducer.java
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/CacheReproducer/srcs/CacheReproducer.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,47 @@
> +/* CacheReproducer.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 java.lang.reflect.*;
> +
> +public class CacheReproducer{
> +
> +    public static void main(String[] args) throws Exception{
> +        Class c1= Class.forName("SimpletestSigned1");
> +        Method m1=c1.getDeclaredMethod("main",args.getClass());
> +        m1.invoke((Object) null, (Object)args);
> +    }
> +}
> diff -r 71f338e881d2 tests/jnlp_tests/signed/CacheReproducer/testcases/CacheReproducerTest.java
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/CacheReproducer/testcases/CacheReproducerTest.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,438 @@
> +/* CacheReproducerTest.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 java.io.BufferedReader;
> +import java.io.File;
> +import java.io.FileInputStream;
> +import java.io.FileNotFoundException;
> +import java.io.IOException;
> +import java.io.InputStreamReader;
> +import java.io.UnsupportedEncodingException;
> +import java.util.Arrays;
> +import java.util.List;
> +import java.util.regex.Matcher;
> +import java.util.regex.Pattern;
> +import net.sourceforge.jnlp.ServerAccess;
> +import net.sourceforge.jnlp.ServerAccess.ProcessResult;
> +import org.junit.AfterClass;
> +import org.junit.Assert;
> +
> +import org.junit.Test;
> +
> +public class CacheReproducerTest {
> +
> +    private static final ServerAccess server = new ServerAccess();
> +    private static final List<String> clear = Arrays.asList(new String[]{server.getJavawsLocation(), "-Xclearcache"});
> +    private static final List<String> trusted = Arrays.asList(new String[]{"-Xtrustall", ServerAccess.HEADLES_OPTION});
> +    private static final String home = System.getProperty("user.home");
> +    private static final String name = System.getProperty("user.name");
> +    private static final String tmp = System.getProperty("java.io.tmpdir");
> +    private static final File icedteaDir = new File(home + "/" + ".icedtea");
> +    private static final File icedteaCache = new File(icedteaDir, "cache");
> +    private static final File icedteaCacheFile = new File(icedteaCache, "recently_used");
> +    private static final File netxLock = new File(tmp + "/" + name + "/netx/locks/netx_running");
> +    private static final String lre = "LruCacheException";
> +    private static final String corruptRegex = "\\d{13}";
> +    private static final Pattern corruptPatern = Pattern.compile(corruptRegex);
> +    private static final String corruptString = "156dsf1562kd5";
> +
> +    @Test
> +    public void cacheIsWorkingTest() throws Exception {
> +        clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +
> +    }
> +
> +    @Test
> +    public void cacheIsWorkingTestSigned() throws Exception {
> +        clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1Signed());
> +        assertCacheIsNotEmpty();
> +
> +    }
> +     private class ParalelSimpleTestRunner extends   Thread {
> +           public boolean b=false;
> +            @Override
> +            public void run() {
> +                try {
> +
> +                    ServerAccess.ProcessResult pr = runSimpleTest1();
> +                    evaluateSimpleTest1OkCache(pr);
> +                    b=true;
> +                } catch (Exception ex) {
> +                    throw new RuntimeException(ex);
> +                }
> +            }
> +        };
> +    @Test
> +    public void startParalelInstancesUponBrokenCache() throws Exception {
> +
> +        clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +        breakCache1();
> +        ParalelSimpleTestRunner t1=new ParalelSimpleTestRunner();
> +        ParalelSimpleTestRunner t2=new ParalelSimpleTestRunner();
> +        ParalelSimpleTestRunner t3=new ParalelSimpleTestRunner();
> +        t1.start();
> +        t2.start();
> +        t3.start();
> +        int c=0;
> +        while(true){
> +            c++;
> +            Thread.sleep(100);
> +            if (c>600) throw new Error("threads have not died in time");
> +            if (!t1.isAlive() && !t2.isAlive() && !t3.isAlive()) break;
> +        }
> +        Thread.sleep(1000);
> +        Assert.assertTrue(t1.b);
> +        Assert.assertTrue(t2.b);
> +        Assert.assertTrue(t3.b);
> +
> +    }
> +
> +
> +    private void assertCacheIsNotEmpty() {
> +        Assert.assertTrue("icedtea cache " + icedteaCache.getAbsolutePath() + " should exists some any run", icedteaCache.exists());
> +        Assert.assertTrue("icedtea cache file " + icedteaCacheFile.getAbsolutePath() + " should exists some any run", icedteaCacheFile.exists());
> +        Assert.assertTrue("icedtea cache file " + icedteaCacheFile.getAbsolutePath() + " should not be empty", icedteaCacheFile.length() > 0);
> +    }
> +
> +    @Test
> +    public void coruptAndRunCache1() throws Exception {
> +        clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +        breakCache1();
> +        ProcessResult pr = runSimpleTest1();
> +        assertLruExceptionAppeared(pr);
> +        evaluateSimpleTest1OkCache(pr);
> +        clearAndEvaluateCache();
> +        ProcessResult pr2 = runSimpleTest1();
> +        evaluateSimpleTest1OkCache(pr2);
> +        assertLruExceptionNOTappeared(pr2);
> +
> +    }
> +
> +    @Test
> +    public void coruptAndRunCache2() throws Exception {
> +         clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +        breakCache1();
> +        ProcessResult pr = runSimpleTest1();
> +        assertLruExceptionAppeared(pr);
> +        evaluateSimpleTest1OkCache(pr);
> +        ProcessResult pr3 = runSimpleTest1();
> +        evaluateSimpleTest1OkCache(pr3);
> +        assertLruExceptionNOTappeared(pr3);
> +        clearAndEvaluateCache();
> +        ProcessResult pr2 = runSimpleTest1();
> +        evaluateSimpleTest1OkCache(pr2);
> +        assertLruExceptionNOTappeared(pr2);
> +
> +    }
> +
> +    private void assertLruExceptionNOTappeared(ProcessResult pr2) {
> +        Assert.assertFalse("serr should NOT contains " + lre, pr2.stderr.contains(lre));
> +    }
> +
> +    private void assertLruExceptionAppeared(ProcessResult pr) {
> +        Assert.assertTrue("serr should contains " + lre, pr.stderr.contains(lre));
> +    }
> +
> +    @Test
> +    public void coruptAndRunCache1Signed() throws Exception {
> +         clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +        breakCache1();
> +        ProcessResult pr = runSimpleTest1Signed();
> +        assertLruExceptionAppeared(pr);
> +        evaluateSimpleTest1OkCache(pr);
> +        clearAndEvaluateCache();
> +        ProcessResult pr2 = runSimpleTest1Signed();
> +        evaluateSimpleTest1OkCache(pr2);
> +        assertLruExceptionNOTappeared(pr2);
> +
> +    }
> +
> +    @Test
> +    public void coruptAndRunCache2Signed() throws Exception {
> +         clearAndEvaluateCache();
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +        breakCache1();
> +        ProcessResult pr = runSimpleTest1Signed();
> +        assertLruExceptionAppeared(pr);
> +        evaluateSimpleTest1OkCache(pr);
> +        ProcessResult pr3 = runSimpleTest1Signed();
> +        evaluateSimpleTest1OkCache(pr3);
> +        assertLruExceptionNOTappeared(pr3);
> +        clearAndEvaluateCache();
> +        ProcessResult pr2 = runSimpleTest1Signed();
> +        evaluateSimpleTest1OkCache(pr2);
> +        assertLruExceptionNOTappeared(pr2);
> +
> +    }
> +
> +    @Test
> +    public void clearCacheUnsucessfully() throws Exception {
> +        evaluateSimpleTest1OkCache(runSimpleTest1());
> +        assertCacheIsNotEmpty();
> +        ProcessResult pr;
> +        Thread t = new Thread(new Runnable() {
> +
> +            @Override
> +            public void run() {
> +                try {
> +                    System.out.println("connecting deadlocktest request");
> +                    System.err.println("connecting deadlocktest request");
> +                    ServerAccess.ProcessResult pr = server.executeJavawsHeadless(null, "/deadlocktest.jnlp");
> +                    System.out.println(pr.stdout);
> +                    System.err.println(pr.stderr);
> +                } catch (Exception ex) {
> +                    throw new RuntimeException(ex);
> +                }
> +            }
> +        });
> +        t.start();
> +        Thread.sleep(1000);
> +        pr = tryToClearcache();
> +        System.out.println(pr.stdout);
> +        System.err.println(pr.stderr);
> +        String q = "Can not clear cache at this time";
> +        Assert.assertTrue("Stderr should contains " + q + ", but did not.", pr.stderr.contains(q));
> +        assertCacheIsNotEmpty();
> +
> +    }
> +
> +     
> +    //next four tests are designed to ensure, that corupted cache wil not break already loaded cached files
> +    public static final String CR1 = "CacheReproducer1";
> +    public static final String CR2 = "CacheReproducer2";
> +    public static final String CR11 = "CacheReproducer1_1";
> +    public static final String CR21 = "CacheReproducer2_1";
> +
> +    public void testsBody(String id, int breaker) throws Exception {
> +        clearAndEvaluateCache();
> +        ProcessResult pr1 = runSimpleTestSigned(id);
> +        assertLruExceptionNOTappeared(pr1);
> +        evaluateSimpleTest1OkCache(pr1);
> +        if (breaker < 0) {
> +            breakCache1();
> +        } else {
> +            breakCache2(breaker);
> +        }
> +        ProcessResult pr2 = runSimpleTestSigned(id);
> +        assertLruExceptionAppeared(pr2);
> +        evaluateSimpleTest1OkCache(pr2);
> +    }
> +
> +    @Test
> +    public void testAlreadyLoadedCached1() throws Exception {
> +        testsBody(CR1, 1);
> +        testsBody(CR1, 2);
> +        testsBody(CR1, -1);
> +    }
> +
> +    @Test
> +    public void testAlreadyLoadedCached2() throws Exception {
> +        testsBody(CR2, 1);
> +        testsBody(CR2, 2);
> +        testsBody(CR2, -1);
> +    }
> +
> +    @Test
> +    public void testAlreadyLoadedCached11() throws Exception {
> +        testsBody(CR11, 1);
> +        testsBody(CR11, 2);
> +        testsBody(CR11, -1);
> +    }
> +
> +    @Test
> +    public void testAlreadyLoadedCached21() throws Exception {
> +        testsBody(CR21, 1);
> +        testsBody(CR21, 2);
> +        testsBody(CR21, -1);
> +    }
> +
> +    @AfterClass
> +    public static void clearCache() throws Exception {
> +        clearAndEvaluateCache();
> +    }
> +
> +    private static void clearAndEvaluateCache() throws Exception {
> +        clearAndEvaluateCache(true);
> +    }
> +
> +    private static void clearAndEvaluateCache(boolean force) throws Exception {
> +        System.out.println("clearing cache");
> +        System.err.println("clearing cache");
> +        if (force) {
> +            if (netxLock.isFile()) {
> +                boolean b = netxLock.delete();
> +                junit.framework.Assert.assertTrue(b);
> +            }
> +
> +        }
> +        tryToClearcache();
> +        Assert.assertFalse("icedtea cache " + icedteaCache.getAbsolutePath() + " should not exists after clearing", icedteaCache.exists());
> +    }
> +
> +    private static String loadFile(File f) throws FileNotFoundException, UnsupportedEncodingException, IOException {
> +        BufferedReader r = new BufferedReader(new InputStreamReader(new FileInputStream(icedteaCacheFile), "UTF-8"));
> +        StringBuilder sb = new StringBuilder();
> +        while (true) {
> +            String s = r.readLine();
> +            if (s == null) {
> +                break;
> +            }
> +            sb.append(s).append("\n");
> +
> +        }
> +        return sb.toString();
> +    }
> +
> +    private static String loadCacheFile() throws IOException {
> +        return loadFile(icedteaCacheFile);
> +    }
> +
> +    @Test
> +    public void assertBreakersAreWorking() {
> +        String s = "#netx file\n"
> +                + "#Mon Dec 12 16:20:46 CET 2011\n"
> +                + "1323703236508,0=/home/jvanek/.icedtea/cache/0/http/localhost/ReadPropertiesBySignedHack.jnlp\n"
> +                + "1323703243086,2=/home/jvanek/.icedtea/cache/2/http/localhost/ReadProperties.jar\n"
> +                + "1323703243082,1=/home/jvanek/.icedtea/cache/1/http/localhost/ReadPropertiesBySignedHack.jar";
> +        String sp[] = s.split("\n");
> +
> +        String ss[] = breakAll(s).split("\n");
> +        for (int i = 0; i < 2; i++) {
> +            Assert.assertEquals(sp[i], ss[i]);
> +
> +        }
> +        for (int i = 2; i < ss.length; i++) {
> +            Assert.assertNotSame(sp[i], ss[i]);
> +
> +        }
> +        String sb = breakOne(s, 0);
> +        junit.framework.Assert.assertEquals(s, sb);
> +        for (int x = 1; x <= 3; x++) {
> +            String[] sx = breakOne(s, x).split("\n");
> +            for (int i = 0; i < sx.length; i++) {
> +                if (i == x + 1) {
> +                    Assert.assertNotSame(sp[i], sx[i]);
> +                } else {
> +                    Assert.assertEquals(sp[i], sx[i]);
> +                }
> +
> +            }
> +        }
> +        String sbb = breakOne(s, 4);
> +        junit.framework.Assert.assertEquals(s, sbb);
> +
> +
> +    }
> +
> +    private static String breakAll(String s) {
> +        return s.replaceAll(corruptRegex, corruptString);
> +    }
> +
> +    private static String breakOne(String s, int i) {
> +        Matcher m1 = corruptPatern.matcher(s);
> +        int x = 0;
> +        while (m1.find()) {
> +            x++;
> +            String r = (m1.group(0));
> +            if (x == i) {
> +                return s.replace(r, corruptString);
> +            }
> +        }
> +        return s;
> +    }
> +
> +    private static void breakCache1() throws IOException {
> +        String s = loadCacheFile();
> +        s = breakAll(s);
> +        ServerAccess.saveFile(s, icedteaCacheFile);
> +    }
> +
> +    private static void breakCache2(int i) throws FileNotFoundException, UnsupportedEncodingException, IOException {
> +        String s = loadCacheFile();
> +        s = breakOne(s, i);
> +        ServerAccess.saveFile(s, icedteaCacheFile);
> +
> +
> +    }
> +
> +    private static ServerAccess.ProcessResult runSimpleTest1() throws Exception {
> +        return runSimpleTest1(null, "simpletest1");
> +    }
> +
> +    private static ServerAccess.ProcessResult runSimpleTest1(List<String> args, String s) throws Exception {
> +        System.out.println("connecting " + s + " request");
> +        System.err.println("connecting " + s + " request");
> +        ServerAccess.ProcessResult pr2 = server.executeJavawsHeadless(args, "/" + s + ".jnlp");
> +        System.out.println(pr2.stdout);
> +        System.err.println(pr2.stderr);
> +        return pr2;
> +    }
> +
> +    private static ServerAccess.ProcessResult runSimpleTest1Signed() throws Exception {
> +        return runSimpleTestSigned("SimpletestSigned1");
> +    }
> +
> +    private static ServerAccess.ProcessResult runSimpleTestSigned(String id) throws Exception {
> +        return runSimpleTest1(trusted, id);
> +    }
> +
> +    private static void evaluateSimpleTest1OkCache(ServerAccess.ProcessResult pr2) throws Exception {
> +        String s = "Good simple javaws exapmle";
> +        Assert.assertTrue("test stdout should contains " + s + " bud didn't", pr2.stdout.contains(s));
> +        Assert.assertFalse(pr2.wasTerminated);
> +        Assert.assertEquals((Integer) 0, pr2.returnValue);
> +    }
> +
> +    private static ProcessResult tryToClearcache() throws Exception {
> +        ServerAccess.ProcessResult pr1 = ServerAccess.executeProcess(clear);
> +        System.out.println(pr1.stdout);
> +        System.err.println(pr1.stderr);
> +        return pr1;
> +    }
> +}
> diff -r 71f338e881d2 tests/jnlp_tests/signed/SimpletestSigned1/resources/SimpletestSigned1.jnlp
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/SimpletestSigned1/resources/SimpletestSigned1.jnlp	Tue Dec 13 17:35:08 2011 +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="SimpletestSigned1.jnlp" codebase=".">
> +  <information>
> +    <title>simpletest1</title>
> +    <vendor>NetX</vendor>
> +    <homepage href="http://jnlp.sourceforge.net/netx/"/>
> +    <description>simpletest1</description>
> +    <offline/>
> +  </information>
> +  <resources>
> +    <j2se version="1.4+"/>
> +    <jar href="SimpletestSigned1.jar"/>
> +  </resources>
> +  <application-desc main-class="SimpletestSigned1">
> +  </application-desc>
> +</jnlp>
> diff -r 71f338e881d2 tests/jnlp_tests/signed/SimpletestSigned1/srcs/SimpletestSigned1.java
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/tests/jnlp_tests/signed/SimpletestSigned1/srcs/SimpletestSigned1.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -0,0 +1,43 @@
> +/* SimpletestSigned1.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.
> + */
> +
> +public class SimpletestSigned1{
> +
> +    public static void main(String[] args){
> +        System.out.println("Good simple javaws exapmle");
> +    }
> +}
> diff -r 71f338e881d2 tests/netx/jnlp_testsengine/net/sourceforge/jnlp/ServerAccess.java
> --- a/tests/netx/jnlp_testsengine/net/sourceforge/jnlp/ServerAccess.java	Tue Nov 29 17:13:03 2011 +0100
> +++ b/tests/netx/jnlp_testsengine/net/sourceforge/jnlp/ServerAccess.java	Tue Dec 13 17:35:08 2011 +0100
> @@ -108,7 +108,7 @@
>       * timeout in ms to let process to finish, before assasin wil kill it.
>       * This can be changed in runtime, but will affect all following tasks
>       */
> -    public static long PROCESS_TIMEOUT = 10 * 1000;//ms
> +    public static long PROCESS_TIMEOUT = 20 * 1000;//ms
>      /**
>       * all terminated processes are stored here. As wee need to 'wait' to termination to be finished.
>       */




More information about the distro-pkg-dev mailing list