aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-home/src
diff options
context:
space:
mode:
authorJulien HENRY <julien.henry@sonarsource.com>2014-03-24 11:30:22 +0100
committerJulien HENRY <julien.henry@sonarsource.com>2014-03-24 11:30:22 +0100
commit47ab2873f318ebc3cdf0ee44903ee6f4ea6a23f5 (patch)
treeb10218d3c65d67e1078b8dc41c9c071f3e5e4eaa /sonar-home/src
parentc95f41167a3d2e30855e4d41a2bde8154ba754be (diff)
downloadsonarqube-47ab2873f318ebc3cdf0ee44903ee6f4ea6a23f5.tar.gz
sonarqube-47ab2873f318ebc3cdf0ee44903ee6f4ea6a23f5.zip
SONAR-5062 Add test
Diffstat (limited to 'sonar-home/src')
-rw-r--r--sonar-home/src/main/java/org/sonar/home/cache/FileCache.java1
-rw-r--r--sonar-home/src/test/java/org/sonar/home/cache/FileCacheTest.java30
2 files changed, 26 insertions, 5 deletions
diff --git a/sonar-home/src/main/java/org/sonar/home/cache/FileCache.java b/sonar-home/src/main/java/org/sonar/home/cache/FileCache.java
index 4ede4d4f56a..085e83b0f4b 100644
--- a/sonar-home/src/main/java/org/sonar/home/cache/FileCache.java
+++ b/sonar-home/src/main/java/org/sonar/home/cache/FileCache.java
@@ -188,7 +188,6 @@ public class FileCache {
if (!destDir.exists()) {
File tempDir = createTempDir();
ZipUtils.unzip(cachedFile, tempDir, new LibFilter());
- // Recheck in case a concurrent process
try {
FileUtils.moveDirectory(tempDir, destDir);
} catch (FileExistsException e) {
diff --git a/sonar-home/src/test/java/org/sonar/home/cache/FileCacheTest.java b/sonar-home/src/test/java/org/sonar/home/cache/FileCacheTest.java
index c4276c38857..5a3e16f0701 100644
--- a/sonar-home/src/test/java/org/sonar/home/cache/FileCacheTest.java
+++ b/sonar-home/src/test/java/org/sonar/home/cache/FileCacheTest.java
@@ -29,6 +29,13 @@ import org.sonar.home.log.Slf4jLog;
import java.io.File;
import java.io.IOException;
import java.net.URISyntaxException;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.concurrent.Callable;
+import java.util.concurrent.ExecutionException;
+import java.util.concurrent.ExecutorService;
+import java.util.concurrent.Executors;
+import java.util.concurrent.Future;
import static org.fest.assertions.Assertions.assertThat;
import static org.mockito.Matchers.any;
@@ -121,10 +128,10 @@ public class FileCacheTest {
}
@Test
- public void unzip_from_cache() throws IOException, URISyntaxException {
+ public void unzip_from_cache() throws IOException, URISyntaxException, InterruptedException, ExecutionException {
final File samplePlugin = new File(this.getClass().getResource("/sonar-checkstyle-plugin-2.8.jar").toURI());
FileHashes hashes = mock(FileHashes.class);
- FileCache cache = new FileCache(tempFolder.newFolder(), log, hashes);
+ final FileCache cache = new FileCache(tempFolder.newFolder(), log, hashes);
when(hashes.of(any(File.class))).thenReturn("ABCDE");
FileCache.Downloader downloader = new FileCache.Downloader() {
@@ -132,11 +139,26 @@ public class FileCacheTest {
FileUtils.copyFile(samplePlugin, toFile);
}
};
- File cachedFile = cache.get("sonar-checkstyle-plugin-2.8.jar", "ABCDE", downloader);
+ final File cachedFile = cache.get("sonar-checkstyle-plugin-2.8.jar", "ABCDE", downloader);
assertThat(cachedFile).isNotNull().exists().isFile();
assertThat(cachedFile.getName()).isEqualTo("sonar-checkstyle-plugin-2.8.jar");
- File pluginDepsDir = cache.unzip(cachedFile);
+ final int nThreads = 5;
+ ExecutorService executorService = Executors.newFixedThreadPool(nThreads);
+ List<Callable<File>> tasks = new ArrayList<Callable<File>>();
+ for (int i = 0; i < nThreads; i++) {
+ tasks.add(new Callable<File>() {
+
+ public File call() throws Exception {
+ return cache.unzip(cachedFile);
+ }
+ });
+ }
+
+ File pluginDepsDir = null;
+ for (Future<File> result : executorService.invokeAll(tasks)) {
+ pluginDepsDir = result.get();
+ }
assertThat(pluginDepsDir.listFiles()).hasSize(1);
File metaDir = new File(pluginDepsDir, "META-INF");
assertThat(metaDir.listFiles()).hasSize(1);