]> source.dussan.org Git - archiva.git/blob
cd2cba209c511133a16f63fddc7767a1eafd24ca
[archiva.git] /
1 package org.apache.archiva.common.filelock;
2
3 /*
4  * Licensed to the Apache Software Foundation (ASF) under one
5  * or more contributor license agreements.  See the NOTICE file
6  * distributed with this work for additional information
7  * regarding copyright ownership.  The ASF licenses this file
8  * to you under the Apache License, Version 2.0 (the
9  * "License"); you may not use this file except in compliance
10  * with the License.  You may obtain a copy of the License at
11  *
12  *  http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing,
15  * software distributed under the License is distributed on an
16  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17  * KIND, either express or implied.  See the License for the
18  * specific language governing permissions and limitations
19  * under the License.
20  */
21
22 import org.junit.Before;
23 import org.junit.Test;
24 import org.junit.runner.RunWith;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
27 import org.springframework.test.context.ContextConfiguration;
28 import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
29
30 import javax.inject.Inject;
31 import javax.inject.Named;
32 import java.io.File;
33 import java.nio.file.FileSystemException;
34 import java.nio.file.Files;
35 import java.nio.file.StandardCopyOption;
36
37 /**
38  * @author Olivier Lamy
39  */
40 @RunWith(SpringJUnit4ClassRunner.class)
41 @ContextConfiguration(locations = { "classpath*:/META-INF/spring-context.xml" })
42 public class DefaultFileLockManagerTimeoutTest
43 {
44
45     final Logger logger = LoggerFactory.getLogger( getClass() );
46
47     @Inject
48     @Named(value = "fileLockManager#default")
49     FileLockManager fileLockManager;
50
51     @Before
52     public void initialize()
53     {
54         fileLockManager.setSkipLocking( false );
55
56         fileLockManager.setTimeout( 5000 );
57
58         fileLockManager.clearLockFiles();
59     }
60
61     @Test(expected = FileLockTimeoutException.class)
62     public void testTimeout()
63         throws Throwable
64     {
65
66             try {
67                 File file = new File(System.getProperty("buildDirectory"), "foo.txt");
68
69                 Files.deleteIfExists(file.toPath());
70
71                 File largeJar = new File(System.getProperty("basedir"), "src/test/cassandra-all-2.0.3.jar");
72
73                 Lock lock = fileLockManager.writeFileLock(file);
74
75                 Files.copy(largeJar.toPath(), lock.getFile().toPath(), StandardCopyOption.REPLACE_EXISTING);
76
77                 lock = fileLockManager.writeFileLock(file);
78             } catch (FileSystemException ex) {
79                 logger.error("Exception from filesystem "+ex.getMessage());
80                 ex.printStackTrace();
81                 throw ex;
82             }
83
84     }
85
86 }