aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/sonar-findbugs-plugin
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/sonar-findbugs-plugin')
-rw-r--r--plugins/sonar-findbugs-plugin/src/main/java/org/sonar/plugins/findbugs/FindbugsDownloader.java33
-rw-r--r--plugins/sonar-findbugs-plugin/src/test/java/org/sonar/plugins/findbugs/FindbugsDownloaderTest.java59
2 files changed, 88 insertions, 4 deletions
diff --git a/plugins/sonar-findbugs-plugin/src/main/java/org/sonar/plugins/findbugs/FindbugsDownloader.java b/plugins/sonar-findbugs-plugin/src/main/java/org/sonar/plugins/findbugs/FindbugsDownloader.java
index 30d8ad238d5..03c53ef65c1 100644
--- a/plugins/sonar-findbugs-plugin/src/main/java/org/sonar/plugins/findbugs/FindbugsDownloader.java
+++ b/plugins/sonar-findbugs-plugin/src/main/java/org/sonar/plugins/findbugs/FindbugsDownloader.java
@@ -1,3 +1,22 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2009 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * Sonar is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * Sonar 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with Sonar; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
+ */
package org.sonar.plugins.findbugs;
import java.io.File;
@@ -16,7 +35,7 @@ import org.sonar.api.utils.SonarException;
public class FindbugsDownloader implements BatchExtension {
- private static final String FINDBUGS_URL = "/deploy/plugins/findbugs/";
+ private static final String FINDBUGS_URL = "/deploy/plugins/findbugs";
private static List<File> libs;
@@ -35,15 +54,21 @@ public class FindbugsDownloader implements BatchExtension {
return libs;
}
- private String getUrlForAnnotationsJar() {
+ /**
+ * Visibility has been relaxed to make the code testable.
+ */
+ protected String getUrlForAnnotationsJar() {
return host + FINDBUGS_URL + "/annotations-" + FindbugsVersion.getVersion() + ".jar";
}
- private String getUrlForJsrJar() {
+ /**
+ * Visibility has been relaxed to make the code testable.
+ */
+ protected String getUrlForJsrJar() {
return host + FINDBUGS_URL + "/jsr305-" + FindbugsVersion.getVersion() + ".jar";
}
- private File downloadLib(String url) {
+ protected File downloadLib(String url) {
try {
URI uri = new URI(url);
File temp = File.createTempFile("findbugs", ".jar");
diff --git a/plugins/sonar-findbugs-plugin/src/test/java/org/sonar/plugins/findbugs/FindbugsDownloaderTest.java b/plugins/sonar-findbugs-plugin/src/test/java/org/sonar/plugins/findbugs/FindbugsDownloaderTest.java
new file mode 100644
index 00000000000..cfa1f085c76
--- /dev/null
+++ b/plugins/sonar-findbugs-plugin/src/test/java/org/sonar/plugins/findbugs/FindbugsDownloaderTest.java
@@ -0,0 +1,59 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2009 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * Sonar is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * Sonar 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with Sonar; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
+ */
+package org.sonar.plugins.findbugs;
+
+import static org.hamcrest.Matchers.is;
+import static org.hamcrest.Matchers.startsWith;
+import static org.junit.Assert.assertThat;
+import static org.mockito.Mockito.mock;
+
+import java.io.File;
+
+import org.apache.commons.configuration.BaseConfiguration;
+import org.apache.commons.configuration.Configuration;
+import org.junit.Before;
+import org.junit.Test;
+import org.sonar.api.utils.HttpDownloader;
+
+public class FindbugsDownloaderTest {
+
+ private FindbugsDownloader downloader;
+
+ @Before
+ public void setUp() {
+ Configuration configuration = new BaseConfiguration();
+ configuration.setProperty("sonar.host.url", "http://sonar/");
+
+ HttpDownloader httpDownloader = mock(HttpDownloader.class);
+ downloader = new FindbugsDownloader(configuration, httpDownloader);
+ }
+
+ @Test
+ public void testUrls() {
+ assertThat(downloader.getUrlForAnnotationsJar(), startsWith("http://sonar/deploy/plugins/findbugs/annotations-"));
+ assertThat(downloader.getUrlForJsrJar(), startsWith("http://sonar/deploy/plugins/findbugs/jsr305-"));
+ }
+
+ @Test
+ public void shouldCreateTempFile() {
+ File file = downloader.downloadLib("http://sonar/test.jar");
+ assertThat(file.exists(), is(true));
+ }
+}