diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2016-12-09 12:41:13 +0100 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@sonarsource.com> | 2016-12-11 21:30:02 +0100 |
commit | 0ae9b2c4cd8023b8d61911a15769445e91a50aff (patch) | |
tree | 6ae679afaa5d3cc81e3872a5645d912b047ecabd | |
parent | 11f26c6dff0725434fadc3281c6038b41d78d5a1 (diff) | |
download | sonarqube-0ae9b2c4cd8023b8d61911a15769445e91a50aff.tar.gz sonarqube-0ae9b2c4cd8023b8d61911a15769445e91a50aff.zip |
Use local SonarQube ZIP in PluginsTest
As this integration test installs the zip found in Maven build,
the version of SonarQube is unknown at runtime (this is a
current limitation of Orchestrator). As a consequence the
list of plugins to be installed is hardcoded and no more
downloaded from Development Update Center.
-rw-r--r-- | it/it-tests/pom.xml | 23 | ||||
-rw-r--r-- | it/it-tests/src/test/java/it/plugins/PluginsTest.java | 137 |
2 files changed, 107 insertions, 53 deletions
diff --git a/it/it-tests/pom.xml b/it/it-tests/pom.xml index 9ef229df246..48bb8cb4cd4 100644 --- a/it/it-tests/pom.xml +++ b/it/it-tests/pom.xml @@ -174,6 +174,27 @@ <artifactId>maven-dependency-plugin</artifactId> <executions> <execution> + <id>copy-sonarqube-zip</id> + <phase>generate-test-resources</phase> + <goals> + <goal>copy</goal> + </goals> + <configuration> + <artifactItems> + <artifactItem> + <groupId>${project.groupId}</groupId> + <artifactId>sonar-application</artifactId> + <version>${project.version}</version> + <type>zip</type> + <overWrite>true</overWrite> + </artifactItem> + </artifactItems> + <outputDirectory>${project.basedir}/../../sonar-application/target</outputDirectory> + <overWriteReleases>true</overWriteReleases> + <overWriteSnapshots>true</overWriteSnapshots> + </configuration> + </execution> + <execution> <id>copy-xoo-plugin</id> <phase>generate-test-resources</phase> <goals> @@ -189,7 +210,7 @@ <overWrite>true</overWrite> </artifactItem> </artifactItems> - <outputDirectory>../../plugins/sonar-xoo-plugin/target</outputDirectory> + <outputDirectory>${project.basedir}/../../plugins/sonar-xoo-plugin/target</outputDirectory> <overWriteReleases>true</overWriteReleases> <overWriteSnapshots>true</overWriteSnapshots> </configuration> diff --git a/it/it-tests/src/test/java/it/plugins/PluginsTest.java b/it/it-tests/src/test/java/it/plugins/PluginsTest.java index f0fdbb1f244..a8727b827bf 100644 --- a/it/it-tests/src/test/java/it/plugins/PluginsTest.java +++ b/it/it-tests/src/test/java/it/plugins/PluginsTest.java @@ -41,6 +41,7 @@ import it.plugins.checks.SwiftCheck; import it.plugins.checks.Validation; import it.plugins.checks.VbCheck; import it.plugins.checks.WebCheck; +import java.io.File; import java.util.Arrays; import java.util.List; import java.util.Set; @@ -48,46 +49,26 @@ import org.junit.BeforeClass; import org.junit.Rule; import org.junit.Test; import org.junit.rules.ErrorCollector; -import org.sonar.updatecenter.common.Plugin; -import org.sonar.updatecenter.common.Release; -import org.sonar.updatecenter.common.Version; +import static com.sonar.orchestrator.locator.FileLocation.byWildcardMavenFilename; import static org.assertj.core.api.Assertions.fail; /** - * Verify that the plugins available in update center + * Verify that latest releases of the plugins available in update center * are correctly supported. */ public class PluginsTest { - /** - * Temporarily disabled plugins. To be re-enabled. - */ - static final Set<String> DISABLED_PLUGINS = Sets.newHashSet( - // FIXME css plugin is temporary disabled as for the moment incompatible with the web plugin - "css", - - // internal plugin used for integration tests of language plugins - "lits", - - "citymodel", - - // Waiting for new release of C# and VB.NET plugins, since fxcop was previously part of those plugins => fail with duplicate props - "fxcop", - - // SONAR-7770 Realm plugins cannot be installed as no external configuration is used - "crowd", "ldap", "pam"); - - static final Set<String> LICENSED_PLUGINS = Sets.newHashSet( - "abap", "cobol", "cpp", "devcockpit", "governance", "objc", "pli", "plsql", "rpg", + private static final Set<String> LICENSED_PLUGINS = Sets.newHashSet( + "abap", "cobol", "cpp", "objc", "pli", "plsql", "rpg", "swift", "vb", "vbnet"); - static final List<Check> CHECKS = Arrays.<Check>asList( + private static final List<Check> CHECKS = Arrays.asList( new AbapCheck(), new CCheck(), new CppCheck(), new CobolCheck(), // FIXME css plugin is temporary disabled as for the moment incompatible with the web plugin -// new CssCheck(), + // new CssCheck(), new FlexCheck(), new GroovyCheck(), new JavaCheck(), @@ -100,28 +81,79 @@ public class PluginsTest { new VbCheck(), new WebCheck()); - static Orchestrator orchestrator; + private static Orchestrator ORCHESTRATOR; @BeforeClass public static void startServer() { - OrchestratorBuilder builder = Orchestrator.builderEnv(); - - // install latest compatible releases of plugins - org.sonar.updatecenter.common.Version sonarVersion = org.sonar.updatecenter.common.Version.create(builder.getSonarVersion()); - Version sonarVersionWithoutPatch = Version.create(sonarVersion.getMajor() + "." + sonarVersion.getMinor()); - builder.getUpdateCenter().setInstalledSonarVersion(sonarVersionWithoutPatch); - for (Plugin plugin : builder.getUpdateCenter().findAllCompatiblePlugins()) { - if (!DISABLED_PLUGINS.contains(plugin.getKey())) { - Release release = plugin.getLastCompatibleRelease(sonarVersionWithoutPatch); - if (release != null) { - builder.setOrchestratorProperty(plugin.getKey() + "Version", release.getVersion().toString()); - builder.addPlugin(plugin.getKey()); - } - } - } + OrchestratorBuilder builder = Orchestrator.builderEnv() + .setZipFile(byWildcardMavenFilename(new File("../../sonar-application/target"), "sonar*.zip").getFile()); + + installPlugin(builder, "JSON"); + installPlugin(builder, "Sonargraph"); + installPlugin(builder, "abap"); + installPlugin(builder, "aemrules"); + installPlugin(builder, "android"); + installPlugin(builder, "authbitbucket"); + installPlugin(builder, "authgithub"); + installPlugin(builder, "checkstyle"); + installPlugin(builder, "clover"); + installPlugin(builder, "cobol"); + installPlugin(builder, "codecrackercsharp"); + installPlugin(builder, "cpp"); + installPlugin(builder, "csharp"); + // FIXME css plugin is temporary disabled as for the moment incompatible with the web plugin installPlugin(builder, "css"); + installPlugin(builder, "erlang"); + installPlugin(builder, "findbugs"); + installPlugin(builder, "flex"); + installPlugin(builder, "github"); + installPlugin(builder, "googleanalytics"); + installPlugin(builder, "groovy"); + installPlugin(builder, "java"); + installPlugin(builder, "javaProperties"); + installPlugin(builder, "javascript"); + installPlugin(builder, "jdepend"); + installPlugin(builder, "l10nde"); + installPlugin(builder, "l10nel"); + installPlugin(builder, "l10nes"); + installPlugin(builder, "l10nfr"); + installPlugin(builder, "l10nit"); + installPlugin(builder, "l10nja"); + installPlugin(builder, "l10nko"); + installPlugin(builder, "l10npt"); + installPlugin(builder, "l10nru"); + installPlugin(builder, "l10nzh"); + installPlugin(builder, "ldap"); + installPlugin(builder, "lua"); + installPlugin(builder, "php"); + installPlugin(builder, "pitest"); + installPlugin(builder, "pli"); + installPlugin(builder, "plsql"); + installPlugin(builder, "pmd"); + installPlugin(builder, "puppet"); + installPlugin(builder, "python"); + installPlugin(builder, "rci"); + installPlugin(builder, "rpg"); + installPlugin(builder, "scmclearcase"); + installPlugin(builder, "scmcvs"); + installPlugin(builder, "scmgit"); + installPlugin(builder, "scmjazzrtc"); + installPlugin(builder, "scmmercurial"); + installPlugin(builder, "scmperforce"); + installPlugin(builder, "scmsvn"); + installPlugin(builder, "scmtfvc"); + installPlugin(builder, "softvis3d"); + installPlugin(builder, "sonargraphintegration"); + installPlugin(builder, "status"); + installPlugin(builder, "swift"); + installPlugin(builder, "vb"); + installPlugin(builder, "vbnet"); + installPlugin(builder, "web"); + installPlugin(builder, "xanitizer"); + installPlugin(builder, "xml"); + activateLicenses(builder); - orchestrator = builder.build(); - orchestrator.start(); + ORCHESTRATOR = builder.build(); + ORCHESTRATOR.start(); } @Rule @@ -130,13 +162,13 @@ public class PluginsTest { @Test public void analysis_of_project_with_all_supported_languages() { SonarScanner analysis = newAnalysis(); - BuildResult result = orchestrator.executeBuildQuietly(analysis); + BuildResult result = ORCHESTRATOR.executeBuildQuietly(analysis); if (result.getLastStatus() != 0) { fail(result.getLogs()); } for (Check check : CHECKS) { System.out.println(check.getClass().getSimpleName() + "..."); - check.validate(new Validation(orchestrator, errorCollector)); + check.validate(new Validation(ORCHESTRATOR, errorCollector)); } } @@ -144,7 +176,7 @@ public class PluginsTest { public void preview_analysis_of_project_with_all_supported_languages() { SonarScanner analysis = newAnalysis(); analysis.setProperty("sonar.analysis.mode", "issues"); - BuildResult result = orchestrator.executeBuildQuietly(analysis); + BuildResult result = ORCHESTRATOR.executeBuildQuietly(analysis); if (result.getLastStatus() != 0) { fail(result.getLogs()); } @@ -159,11 +191,12 @@ public class PluginsTest { } private static void activateLicenses(OrchestratorBuilder builder) { - for (String licensedPlugin : LICENSED_PLUGINS) { - if (!DISABLED_PLUGINS.contains(licensedPlugin)) { - builder.activateLicense(licensedPlugin); - } - } + LICENSED_PLUGINS.forEach(builder::activateLicense); + } + + private static void installPlugin(OrchestratorBuilder builder, String pluginKey) { + builder.setOrchestratorProperty(pluginKey + "Version", "LATEST_RELEASE"); + builder.addPlugin(pluginKey); } } |