aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-core
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-core')
-rw-r--r--sonar-core/src/main/java/org/sonar/core/plugins/DefaultPluginMetadata.java7
-rw-r--r--sonar-core/src/main/java/org/sonar/core/plugins/PluginFileExtractor.java16
-rw-r--r--sonar-core/src/main/java/org/sonar/core/plugins/RemotePlugin.java106
-rw-r--r--sonar-core/src/test/java/org/sonar/core/plugins/PluginFileExtractorTest.java4
-rw-r--r--sonar-core/src/test/java/org/sonar/core/plugins/RemotePluginTest.java75
5 files changed, 197 insertions, 11 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/plugins/DefaultPluginMetadata.java b/sonar-core/src/main/java/org/sonar/core/plugins/DefaultPluginMetadata.java
index 798cd20bf2b..56cb45aa239 100644
--- a/sonar-core/src/main/java/org/sonar/core/plugins/DefaultPluginMetadata.java
+++ b/sonar-core/src/main/java/org/sonar/core/plugins/DefaultPluginMetadata.java
@@ -20,14 +20,12 @@
package org.sonar.core.plugins;
import com.google.common.collect.Lists;
-import org.apache.commons.collections.ComparatorUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.commons.lang.builder.ToStringBuilder;
import org.apache.commons.lang.builder.ToStringStyle;
import org.sonar.api.platform.PluginMetadata;
import java.io.File;
-import java.util.ArrayList;
import java.util.List;
public final class DefaultPluginMetadata implements PluginMetadata, Comparable<PluginMetadata> {
@@ -82,6 +80,11 @@ public final class DefaultPluginMetadata implements PluginMetadata, Comparable<P
return this;
}
+ public DefaultPluginMetadata setDeprecatedExtensions(List<File> files) {
+ this.deprecatedExtensions = (files==null ? Lists.<File>newArrayList() : files);
+ return this;
+ }
+
public String[] getPathsToInternalDeps() {
return pathsToInternalDeps;
}
diff --git a/sonar-core/src/main/java/org/sonar/core/plugins/PluginFileExtractor.java b/sonar-core/src/main/java/org/sonar/core/plugins/PluginFileExtractor.java
index e248ffd078e..da200c937be 100644
--- a/sonar-core/src/main/java/org/sonar/core/plugins/PluginFileExtractor.java
+++ b/sonar-core/src/main/java/org/sonar/core/plugins/PluginFileExtractor.java
@@ -20,28 +20,28 @@
package org.sonar.core.plugins;
import org.apache.commons.io.FileUtils;
-import org.apache.commons.lang.StringUtils;
import org.sonar.api.Plugin;
import org.sonar.api.utils.SonarException;
import org.sonar.api.utils.ZipUtils;
import org.sonar.updatecenter.common.PluginKeyUtils;
import org.sonar.updatecenter.common.PluginManifest;
-import javax.swing.plaf.metal.MetalTabbedPaneUI;
import java.io.File;
import java.io.IOException;
import java.net.URL;
import java.net.URLClassLoader;
+import java.util.List;
import java.util.zip.ZipEntry;
public class PluginFileExtractor {
- public DefaultPluginMetadata installInSameLocation(File pluginFile, boolean isCore) {
- return install(pluginFile, isCore, null);
+ public DefaultPluginMetadata installInSameLocation(File pluginFile, boolean isCore, List<File> deprecatedExtensions) {
+ return install(pluginFile, isCore, deprecatedExtensions, null);
}
- public DefaultPluginMetadata install(File pluginFile, boolean isCore, File toDir) {
+ public DefaultPluginMetadata install(File pluginFile, boolean isCore, List<File> deprecatedExtensions, File toDir) {
DefaultPluginMetadata metadata = extractMetadata(pluginFile, isCore);
+ metadata.setDeprecatedExtensions(deprecatedExtensions);
return install(metadata, toDir);
}
@@ -78,7 +78,9 @@ public class PluginFileExtractor {
for (File extension : metadata.getDeprecatedExtensions()) {
File toFile = new File(pluginBasedir, extension.getName());
- FileUtils.copyFile(extension, toFile);
+ if (!toFile.equals(extension)) {
+ FileUtils.copyFile(extension, toFile);
+ }
metadata.addDeployedFile(toFile);
}
@@ -123,7 +125,7 @@ public class PluginFileExtractor {
// copy file in a temp directory because Windows+Oracle JVM Classloader lock the JAR file
File tempFile = File.createTempFile(pluginFile.getName(), null);
FileUtils.copyFile(pluginFile, tempFile);
-
+
URLClassLoader pluginClassLoader = URLClassLoader.newInstance(new URL[]{tempFile.toURI().toURL()}, getClass().getClassLoader());
Plugin pluginInstance = (Plugin) pluginClassLoader.loadClass(mainClass).newInstance();
metadata.setKey(PluginKeyUtils.sanitize(pluginInstance.getKey()));
diff --git a/sonar-core/src/main/java/org/sonar/core/plugins/RemotePlugin.java b/sonar-core/src/main/java/org/sonar/core/plugins/RemotePlugin.java
new file mode 100644
index 00000000000..bf3477f2663
--- /dev/null
+++ b/sonar-core/src/main/java/org/sonar/core/plugins/RemotePlugin.java
@@ -0,0 +1,106 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2008-2011 SonarSource
+ * 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.core.plugins;
+
+import com.google.common.collect.Lists;
+import org.apache.commons.lang.StringUtils;
+
+import java.io.File;
+import java.util.List;
+
+public class RemotePlugin {
+ private String pluginKey;
+ private List<String> filenames = Lists.newArrayList();
+ private boolean core;
+
+ public RemotePlugin(String pluginKey, boolean core) {
+ this.pluginKey = pluginKey;
+ this.core = core;
+ }
+
+ public static RemotePlugin create(DefaultPluginMetadata metadata) {
+ RemotePlugin result = new RemotePlugin(metadata.getKey(), metadata.isCore());
+ result.addFilename(metadata.getFile().getName());
+ for (File file : metadata.getDeprecatedExtensions()) {
+ result.addFilename(file.getName());
+ }
+ return result;
+ }
+
+ public static RemotePlugin unmarshal(String row) {
+ String[] fields = StringUtils.split(row, ",");
+ RemotePlugin result = new RemotePlugin(fields[0], Boolean.parseBoolean(fields[1]));
+ if (fields.length > 2) {
+ for (int index = 2; index < fields.length; index++) {
+ result.addFilename(fields[index]);
+ }
+ }
+ return result;
+ }
+
+ public String marshal() {
+ StringBuilder sb = new StringBuilder();
+ sb.append(pluginKey).append(",");
+ sb.append(String.valueOf(core));
+ for (String filename : filenames) {
+ sb.append(",").append(filename);
+ }
+ return sb.toString();
+ }
+
+ public String getKey() {
+ return pluginKey;
+ }
+
+
+ public boolean isCore() {
+ return core;
+ }
+
+ public RemotePlugin addFilename(String s) {
+ filenames.add(s);
+ return this;
+ }
+
+ public List<String> getFilenames() {
+ return filenames;
+ }
+
+ public String getPluginFilename() {
+ return (filenames.size()>0 ? filenames.get(0) : null);
+ }
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) {
+ return true;
+ }
+ if (o == null || getClass() != o.getClass()) {
+ return false;
+ }
+ RemotePlugin that = (RemotePlugin) o;
+ return pluginKey.equals(that.pluginKey);
+ }
+
+ @Override
+ public int hashCode() {
+ return pluginKey.hashCode();
+ }
+}
diff --git a/sonar-core/src/test/java/org/sonar/core/plugins/PluginFileExtractorTest.java b/sonar-core/src/test/java/org/sonar/core/plugins/PluginFileExtractorTest.java
index 4923a470ab9..1dff51b0119 100644
--- a/sonar-core/src/test/java/org/sonar/core/plugins/PluginFileExtractorTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/plugins/PluginFileExtractorTest.java
@@ -64,7 +64,7 @@ public class PluginFileExtractorTest {
FileUtils.forceMkdir(toDir);
FileUtils.cleanDirectory(toDir);
- DefaultPluginMetadata metadata = extractor.install(getFile("sonar-checkstyle-plugin-2.8.jar"), true, toDir);
+ DefaultPluginMetadata metadata = extractor.install(getFile("sonar-checkstyle-plugin-2.8.jar"), true, null, toDir);
assertThat(metadata.getKey(), is("checkstyle"));
assertThat(new File(toDir, "sonar-checkstyle-plugin-2.8.jar").exists(), is(true));
@@ -77,7 +77,7 @@ public class PluginFileExtractorTest {
FileUtils.forceMkdir(toDir);
FileUtils.cleanDirectory(toDir);
- extractor.install(getFile("sonar-checkstyle-plugin-2.8.jar"), true, toDir);
+ extractor.install(getFile("sonar-checkstyle-plugin-2.8.jar"), true, null, toDir);
assertThat(new File(toDir, "sonar-checkstyle-plugin-2.8.jar").exists(), is(true));
assertThat(new File(toDir, "META-INF/MANIFEST.MF").exists(), is(false));
diff --git a/sonar-core/src/test/java/org/sonar/core/plugins/RemotePluginTest.java b/sonar-core/src/test/java/org/sonar/core/plugins/RemotePluginTest.java
new file mode 100644
index 00000000000..941c9301791
--- /dev/null
+++ b/sonar-core/src/test/java/org/sonar/core/plugins/RemotePluginTest.java
@@ -0,0 +1,75 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2008-2011 SonarSource
+ * 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.core.plugins;
+
+import org.junit.Test;
+
+import static org.hamcrest.core.Is.is;
+import static org.junit.Assert.assertThat;
+import static org.junit.matchers.JUnitMatchers.hasItems;
+
+public class RemotePluginTest {
+ @Test
+ public void shouldEqual() {
+ RemotePlugin clirr1 = new RemotePlugin("clirr", false);
+ RemotePlugin clirr2 = new RemotePlugin("clirr", false);
+ RemotePlugin checkstyle = new RemotePlugin("checkstyle", true);
+ assertThat(clirr1.equals(clirr2), is(true));
+ assertThat(clirr1.equals(clirr1), is(true));
+ assertThat(clirr1.equals(checkstyle), is(false));
+ }
+
+ @Test
+ public void shouldMarshal() {
+ RemotePlugin clirr = new RemotePlugin("clirr", false).addFilename("clirr-1.1.jar");
+ String text = clirr.marshal();
+ assertThat(text, is("clirr,false,clirr-1.1.jar"));
+ }
+
+ @Test
+ public void shouldMarshalDeprecatedExtensions() {
+ RemotePlugin checkstyle = new RemotePlugin("checkstyle", true);
+ checkstyle.addFilename("checkstyle-2.8.jar");
+ checkstyle.addFilename("ext.xml");
+ checkstyle.addFilename("ext.jar");
+
+ String text = checkstyle.marshal();
+ assertThat(text, is("checkstyle,true,checkstyle-2.8.jar,ext.xml,ext.jar"));
+ }
+
+ @Test
+ public void shouldUnmarshal() {
+ RemotePlugin clirr = RemotePlugin.unmarshal("clirr,false,clirr-1.1.jar");
+ assertThat(clirr.getKey(), is("clirr"));
+ assertThat(clirr.isCore(), is(false));
+ assertThat(clirr.getFilenames().size(), is(1));
+ assertThat(clirr.getFilenames().get(0), is("clirr-1.1.jar"));
+
+ }
+
+ @Test
+ public void shouldUnmarshalDeprecatedExtensions() {
+ RemotePlugin checkstyle = RemotePlugin.unmarshal("checkstyle,true,checkstyle-2.8.jar,ext.xml,ext.jar");
+ assertThat(checkstyle.getKey(), is("checkstyle"));
+ assertThat(checkstyle.isCore(), is(true));
+ assertThat(checkstyle.getFilenames().size(), is(3));
+ assertThat(checkstyle.getFilenames(), hasItems("checkstyle-2.8.jar", "ext.xml", "ext.jar"));
+ }
+}