aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--it/pom.xml68
-rw-r--r--it/src/test/java/com/sonar/runner/it/ScannerTestCase.java25
2 files changed, 81 insertions, 12 deletions
diff --git a/it/pom.xml b/it/pom.xml
index eb96c00..2b8d9b2 100644
--- a/it/pom.xml
+++ b/it/pom.xml
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
+ xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
@@ -52,10 +52,10 @@
<scope>test</scope>
</dependency>
<dependency>
- <groupId>org.assertj</groupId>
- <artifactId>assertj-core</artifactId>
- <version>2.1.0</version>
- </dependency>
+ <groupId>org.assertj</groupId>
+ <artifactId>assertj-core</artifactId>
+ <version>2.1.0</version>
+ </dependency>
</dependencies>
<build>
@@ -65,6 +65,9 @@
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
+ <systemProperties>
+ <scannerVersion>${scanner.version}</scannerVersion>
+ </systemProperties>
<includes>
<include>**/SonarScannerTestSuite.java</include>
</includes>
@@ -74,4 +77,59 @@
</pluginManagement>
</build>
+ <profiles>
+ <profile>
+ <id>download-qa-artifacts</id>
+ <activation>
+ <property>
+ <name>env.CI_BUILD_NUMBER</name>
+ </property>
+ </activation>
+ <build>
+ <plugins>
+ <plugin>
+ <groupId>org.codehaus.gmaven</groupId>
+ <artifactId>groovy-maven-plugin</artifactId>
+ <version>2.0</version>
+ <executions>
+ <execution>
+ <id>compute-qa-version</id>
+ <phase>initialize</phase>
+ <goals>
+ <goal>execute</goal>
+ </goals>
+ <configuration>
+ <source><![CDATA[
+ String pom = new File(project.basedir, '../pom.xml').getText('UTF-8')
+ def matcher = pom =~ /(?s).*<version>(.*?)-SNAPSHOT<\/version>.*/
+ assert matcher.matches()
+ project.properties['scanner.version'] = matcher[0][1] + '-build' + System.getenv()['CI_BUILD_NUMBER']
+ ]]>
+ </source>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-dependency-plugin</artifactId>
+ <version>2.10</version>
+ <executions>
+ <execution>
+ <id>download-qa-scanner</id>
+ <phase>initialize</phase>
+ <goals>
+ <goal>get</goal>
+ </goals>
+ <configuration>
+ <artifact>org.sonarsource.scanner.cli:sonar-scanner-cli:${scanner.version}:zip</artifact>
+ </configuration>
+ </execution>
+ </executions>
+ </plugin>
+ </plugins>
+ </build>
+ </profile>
+ </profiles>
+
</project>
diff --git a/it/src/test/java/com/sonar/runner/it/ScannerTestCase.java b/it/src/test/java/com/sonar/runner/it/ScannerTestCase.java
index 0f8d7fa..4562a42 100644
--- a/it/src/test/java/com/sonar/runner/it/ScannerTestCase.java
+++ b/it/src/test/java/com/sonar/runner/it/ScannerTestCase.java
@@ -26,12 +26,17 @@ import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.Properties;
+import org.apache.commons.lang.StringUtils;
import org.junit.ClassRule;
import org.junit.Rule;
import org.junit.rules.ExpectedException;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
public abstract class ScannerTestCase {
+ private static final Logger LOG = LoggerFactory.getLogger(ScannerTestCase.class);
+
@Rule
public ExpectedException thrown = ExpectedException.none();
@@ -42,13 +47,19 @@ public abstract class ScannerTestCase {
private static Version artifactVersion() {
if (artifactVersion == null) {
- try (FileInputStream fis = new FileInputStream(new File("../target/maven-archiver/pom.properties"))) {
- Properties props = new Properties();
- props.load(fis);
- artifactVersion = Version.create(props.getProperty("version"));
- return artifactVersion;
- } catch (IOException e) {
- throw new IllegalStateException(e);
+ String scannerVersion = System.getProperty("scanner.version");
+ if (StringUtils.isNotBlank(scannerVersion)) {
+ LOG.info("Use provided Scanner version: " + scannerVersion);
+ artifactVersion = Version.create(scannerVersion);
+ } else {
+ try (FileInputStream fis = new FileInputStream(new File("../target/maven-archiver/pom.properties"))) {
+ Properties props = new Properties();
+ props.load(fis);
+ artifactVersion = Version.create(props.getProperty("version"));
+ return artifactVersion;
+ } catch (IOException e) {
+ throw new IllegalStateException(e);
+ }
}
}
return artifactVersion;