aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-home/src
diff options
context:
space:
mode:
authorDuarte Meneses <duarte.meneses@sonarsource.com>2017-09-14 14:05:32 +0200
committerDuarte Meneses <duarte.meneses@sonarsource.com>2017-09-14 15:40:11 +0200
commitd37a06d8bb263713e3e2c99b977806a41dec15a6 (patch)
treeb42c27ab89a4965d9f68c61dcf707eb7686bc797 /sonar-home/src
parentc9975c3520d55d9f79cb04468fa5a64da8ed5dfa (diff)
downloadsonarqube-d37a06d8bb263713e3e2c99b977806a41dec15a6.tar.gz
sonarqube-d37a06d8bb263713e3e2c99b977806a41dec15a6.zip
Improve quality
Diffstat (limited to 'sonar-home/src')
-rw-r--r--sonar-home/src/main/java/org/sonar/home/cache/FileCache.java2
-rw-r--r--sonar-home/src/test/java/org/sonar/home/cache/FileCacheTest.java59
2 files changed, 48 insertions, 13 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 01d9e0a5430..febb4ef460d 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
@@ -42,7 +42,7 @@ public class FileCache {
FileCache(File dir, FileHashes fileHashes, Logger logger) {
this.hashes = fileHashes;
this.logger = logger;
- this.dir = createDir(dir, "user cache");
+ this.dir = createDir(dir, "user cache: ");
logger.info(String.format("User cache: %s", dir.getAbsolutePath()));
this.tmpDir = createDir(new File(dir, "_tmp"), "temp dir");
}
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 64815767e7f..2a7381c866a 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
@@ -22,6 +22,8 @@ package org.sonar.home.cache;
import java.io.File;
import java.io.IOException;
import org.apache.commons.io.FileUtils;
+import org.assertj.core.util.Files;
+import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
@@ -33,6 +35,15 @@ import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
public class FileCacheTest {
+ private FileHashes fileHashes;
+ private FileCache cache;
+
+ @Before
+ public void setUp() throws IOException {
+ fileHashes = mock(FileHashes.class);
+ cache = new FileCache(tempFolder.getRoot(), fileHashes, mock(Logger.class));
+ }
+
@Rule
public TemporaryFolder tempFolder = new TemporaryFolder();
@@ -41,14 +52,11 @@ public class FileCacheTest {
@Test
public void not_in_cache() throws IOException {
- FileCache cache = FileCache.create(tempFolder.newFolder(), mock(Logger.class));
assertThat(cache.get("sonar-foo-plugin-1.5.jar", "ABCDE")).isNull();
}
@Test
public void found_in_cache() throws IOException {
- FileCache cache = FileCache.create(tempFolder.newFolder(), mock(Logger.class));
-
// populate the cache. Assume that hash is correct.
File cachedFile = new File(new File(cache.getDir(), "ABCDE"), "sonar-foo-plugin-1.5.jar");
FileUtils.write(cachedFile, "body");
@@ -57,10 +65,41 @@ public class FileCacheTest {
}
@Test
+ public void fail_to_download() {
+ when(fileHashes.of(any(File.class))).thenReturn("ABCDE");
+
+ FileCache.Downloader downloader = new FileCache.Downloader() {
+ public void download(String filename, File toFile) throws IOException {
+ throw new IOException("fail");
+ }
+ };
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("Fail to download");
+ cache.get("sonar-foo-plugin-1.5.jar", "ABCDE", downloader);
+ }
+
+ @Test
+ public void fail_create_hash_dir() throws IOException {
+ File file = tempFolder.newFile();
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("Unable to create user cache");
+ cache = new FileCache(file, fileHashes, mock(Logger.class));
+ }
+
+ @Test
+ public void fail_to_create_hash_dir() throws IOException {
+ when(fileHashes.of(any(File.class))).thenReturn("ABCDE");
+
+ File hashDir = new File(cache.getDir(), "ABCDE");
+ hashDir.createNewFile();
+ thrown.expect(IllegalStateException.class);
+ thrown.expectMessage("Fail to create cache directory");
+ cache.get("sonar-foo-plugin-1.5.jar", "ABCDE", mock(FileCache.Downloader.class));
+ }
+
+ @Test
public void download_and_add_to_cache() throws IOException {
- FileHashes hashes = mock(FileHashes.class);
- FileCache cache = new FileCache(tempFolder.newFolder(), hashes, mock(Logger.class));
- when(hashes.of(any(File.class))).thenReturn("ABCDE");
+ when(fileHashes.of(any(File.class))).thenReturn("ABCDE");
FileCache.Downloader downloader = new FileCache.Downloader() {
public void download(String filename, File toFile) throws IOException {
@@ -79,9 +118,7 @@ public class FileCacheTest {
thrown.expect(IllegalStateException.class);
thrown.expectMessage("INVALID HASH");
- FileHashes hashes = mock(FileHashes.class);
- FileCache cache = new FileCache(tempFolder.newFolder(), hashes, mock(Logger.class));
- when(hashes.of(any(File.class))).thenReturn("VWXYZ");
+ when(fileHashes.of(any(File.class))).thenReturn("VWXYZ");
FileCache.Downloader downloader = new FileCache.Downloader() {
public void download(String filename, File toFile) throws IOException {
@@ -93,9 +130,7 @@ public class FileCacheTest {
@Test
public void concurrent_download() throws IOException {
- FileHashes hashes = mock(FileHashes.class);
- when(hashes.of(any(File.class))).thenReturn("ABCDE");
- final FileCache cache = new FileCache(tempFolder.newFolder(), hashes, mock(Logger.class));
+ when(fileHashes.of(any(File.class))).thenReturn("ABCDE");
FileCache.Downloader downloader = new FileCache.Downloader() {
public void download(String filename, File toFile) throws IOException {