From: Martin Stockhammer Date: Thu, 27 Oct 2016 10:21:46 +0000 (+0200) Subject: Additional improvement for file locks X-Git-Tag: without_jdo~3 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=40816fc367fce33c4220fbd683dbd8db75fbb781;p=archiva.git Additional improvement for file locks --- diff --git a/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java b/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java index 2ce2f188c..258366aa9 100644 --- a/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java +++ b/archiva-modules/archiva-base/archiva-filelock/src/main/java/org/apache/archiva/common/filelock/DefaultFileLockManager.java @@ -198,28 +198,38 @@ public class DefaultFileLockManager } throw new FileLockException( e.getMessage(), e ); } - catch ( Throwable e ) + catch ( IllegalStateException e ) { + // Ignore this + log.debug( "openLock {}:{}", e.getClass(), e.getMessage() ); + } catch (Throwable t) { if (lock!=null && lock.isValid()) { try { lock.close(); } catch (IOException ex) { // Ignore - } finally { - lock = null; } } - log.debug( "openLock {}:{}", e.getClass(), e.getMessage() ); + throw t; } } Lock current = lockFiles.putIfAbsent( file, lock ); + if (lock!=null && lock != current) { + try { + lock.close(); + } catch (IOException e) { + // ignore + } + + } if ( current != null ) { lock = current; } + return lock; diff --git a/archiva-modules/archiva-base/archiva-filelock/src/test/java/org/apache/archiva/common/filelock/DefaultFileLockManagerTest.java b/archiva-modules/archiva-base/archiva-filelock/src/test/java/org/apache/archiva/common/filelock/DefaultFileLockManagerTest.java index 96186612e..19f836dbc 100644 --- a/archiva-modules/archiva-base/archiva-filelock/src/test/java/org/apache/archiva/common/filelock/DefaultFileLockManagerTest.java +++ b/archiva-modules/archiva-base/archiva-filelock/src/test/java/org/apache/archiva/common/filelock/DefaultFileLockManagerTest.java @@ -246,7 +246,7 @@ public class DefaultFileLockManagerTest public void thread9() throws FileLockException, FileLockTimeoutException, IOException { - logger.info( "thread7" ); + logger.info( "thread9" ); Lock lock = fileLockManager.writeFileLock( this.file ); try { @@ -274,7 +274,7 @@ public class DefaultFileLockManagerTest { fileLockManager.release( lock ); } - logger.info( "thread8 ok" ); + logger.info( "thread10 ok" ); success.incrementAndGet(); }