Skip to content

Commit

Permalink
SCANMAVEN-243 The SonarScanner for Maven does not try to contact the …
Browse files Browse the repository at this point in the history
…server when the project is skipped
  • Loading branch information
alban-auzeill committed Oct 29, 2024
1 parent 993000d commit 2aa2921
Show file tree
Hide file tree
Showing 2 changed files with 130 additions and 8 deletions.
32 changes: 32 additions & 0 deletions its/projects/maven/bootstrap-small-project/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,36 @@
</dependency>
</dependencies>

<profiles>

<profile>
<id>test-sonar-skip</id>
<activation>
<activeByDefault>false</activeByDefault>
</activation>
<properties>
<sonar.skip>true</sonar.skip>
</properties>
</profile>

<profile>
<id>test-plugin-skip</id>
<activation>
<activeByDefault>false</activeByDefault>
</activation>
<build>
<plugins>
<plugin>
<groupId>org.sonarsource.scanner.maven</groupId>
<artifactId>sonar-maven-plugin</artifactId>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
</plugins>
</build>
</profile>

</profiles>

</project>
106 changes: 98 additions & 8 deletions its/src/test/java/com/sonar/maven/it/suite/BootstrapTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,86 @@ void test_unsupported_platform() {
}
}

@Test
void test_bootstrapping_with_sonar_skip_in_pom_xml() {
MavenBuild build = MavenBuild.create(ItUtils.locateProjectPom("maven/bootstrap-small-project"))
.setProperty("sonar.login", ORCHESTRATOR.getDefaultAdminToken())
.setProperty("sonar.host.url", ORCHESTRATOR.getServer().getUrl())
// activate in the pom.xml <properties><sonar.skip>true</sonar.skip></properties>
.addArguments("-Ptest-sonar-skip")
.setGoals(sonarGoal());
BuildResult result = executeBuildAndValidateWithoutCE(build);
assertThat(result.getLogs())
.contains("Skipping analysis")
.doesNotContain("JRE provisioning:", "Communicating with SonarQube Server", "Starting SonarScanner Engine");
}

@Test
void test_bootstrapping_with_sonar_skip_in_system_property() {
MavenBuild build = MavenBuild.create(ItUtils.locateProjectPom("maven/bootstrap-small-project"))
.setProperty("sonar.login", ORCHESTRATOR.getDefaultAdminToken())
.setProperty("sonar.host.url", ORCHESTRATOR.getServer().getUrl())
// analyze using: mvn sonar:sonar -Dsonar.skip=true
.setProperty("sonar.skip", "true")
.setGoals(sonarGoal());
BuildResult result = executeBuildAndValidateWithoutCE(build);
assertThat(result.getLogs())
.contains("Skipping analysis")
.doesNotContain("JRE provisioning:", "Communicating with SonarQube Server", "Starting SonarScanner Engine");
}

@Test
void test_bootstrapping_with_sonar_skip_in_plugin_configuration() {
MavenBuild build = MavenBuild.create(ItUtils.locateProjectPom("maven/bootstrap-small-project"))
.setProperty("sonar.login", ORCHESTRATOR.getDefaultAdminToken())
.setProperty("sonar.host.url", ORCHESTRATOR.getServer().getUrl())
// activate in the pom.xml <configuration><skip>true</skip></configuration>
.addArguments("-Ptest-plugin-skip")
.setGoals(sonarGoal());
BuildResult result = executeBuildAndValidateWithoutCE(build);
assertThat(result.getLogs())
.contains("Skipping analysis")
.doesNotContain("JRE provisioning:", "Communicating with SonarQube Server", "Starting SonarScanner Engine");
}

@Test
void test_bootstrapping_that_skip_the_JRE_provisioning() throws IOException {
String projectName = "maven/bootstrap-small-project";
MavenBuild build = MavenBuild.create(ItUtils.locateProjectPom(projectName))
.setProperty("sonar.login", ORCHESTRATOR.getDefaultAdminToken())
.setProperty("sonar.host.url", ORCHESTRATOR.getServer().getUrl())
.setProperty("sonar.scanner.skipJreProvisioning", "true")
.setEnvironmentVariable("DUMP_SYSTEM_PROPERTIES", "java.home")
.setGoals(sonarGoal());
BuildResult result = executeBuildAndValidateWithCE(build);
assertThat(result.getLogs())
.doesNotContain("Skipping analysis", "JRE provisioning:")
.contains("JRE provisioning is disabled", "Communicating with SonarQube Server", "Starting SonarScanner Engine");
Path propertiesFile = ItUtils.locateProjectDir(projectName).toPath().resolve("target/sonar/dumpSensor.system.properties");
Properties props = new Properties();
props.load(Files.newInputStream(propertiesFile));
assertThat(props.getProperty("java.home")).isEqualTo(guessJavaHomeSelectedByMvn());
}

@Test
void test_bootstrapping_that_use_the_provided_JRE_instead_of_downloading_a_JRE() throws IOException {
String projectName = "maven/bootstrap-small-project";
MavenBuild build = MavenBuild.create(ItUtils.locateProjectPom(projectName))
.setProperty("sonar.login", ORCHESTRATOR.getDefaultAdminToken())
.setProperty("sonar.host.url", ORCHESTRATOR.getServer().getUrl())
.setProperty("sonar.scanner.javaExePath", System.getProperty("java.home") + File.separator + "bin" + File.separator + "java")
.setEnvironmentVariable("DUMP_SYSTEM_PROPERTIES", "java.home")
.setGoals(sonarGoal());
BuildResult result = executeBuildAndValidateWithCE(build);
assertThat(result.getLogs())
.doesNotContain("Skipping analysis", "JRE provisioning:", "JRE provisioning is disabled")
.contains("Using the configured java executable", "Communicating with SonarQube Server", "Starting SonarScanner Engine");
Path propertiesFile = ItUtils.locateProjectDir(projectName).toPath().resolve("target/sonar/dumpSensor.system.properties");
Properties props = new Properties();
props.load(Files.newInputStream(propertiesFile));
assertThat(props.getProperty("java.home")).isEqualTo(System.getProperty("java.home"));
}

@Test
void test_supported_arch_to_assert_jre_used() throws IOException {
BuildRunner runner = new BuildRunner(ORCHESTRATOR.getConfiguration());
Expand Down Expand Up @@ -100,6 +180,10 @@ void test_supported_arch_to_assert_jre_used() throws IOException {

BuildResult result = validateBuildWithCE(runner.runQuietly(null, build));
assertThat(result.isSuccess()).isTrue();
assertThat(result.getLogs())
.doesNotContain("Skipping analysis")
.contains("JRE provisioning:", "Communicating with SonarQube Server", "Starting SonarScanner Engine");

Path propertiesFile = ItUtils.locateProjectDir(projectName).toPath().resolve("target/sonar/dumpSensor.system.properties");
Properties props = new Properties();
props.load(Files.newInputStream(propertiesFile));
Expand Down Expand Up @@ -131,30 +215,27 @@ void test_supported_arch_to_assert_jre_used() throws IOException {
softly.assertThat(props.getProperty("sonar.java.source")).isEqualTo( "11");
softly.assertThat(props.getProperty("sonar.java.target")).isEqualTo( "11");
softly.assertThat(props.getProperty("sonar.java.test.libraries")).contains("jsr305-3.0.2.jar");
// sonar.java.jdkHome should be the one used by "mvn sonar:sonar", by default maven uses JAVA_HOME
String javaHome = System.getenv("JAVA_HOME");
if (javaHome == null) {
javaHome = System.getProperty("java.home");
}
softly.assertThat(props.getProperty("sonar.java.jdkHome")).isEqualTo( new File(javaHome).getCanonicalPath());
// sonar.java.jdkHome should be the one used by "mvn sonar:sonar"
softly.assertThat(props.getProperty("sonar.java.jdkHome")).isEqualTo(guessJavaHomeSelectedByMvn());

StringAssert javaHomeAssertion = softly.assertThat(props.getProperty("java.home")).isNotEmpty();
if (ORCHESTRATOR.getServer().version().isGreaterThanOrEquals(10, 6)) {
//we test that we are actually using the JRE downloaded from SQ
javaHomeAssertion
.isNotEqualTo(System.getProperty("java.home"))
.isNotEqualTo(guessJavaHomeSelectedByMvn())
.contains(".sonar" + File.separator + "cache");

// System properties of the initial JRE are intentionally not set on the provisioned JRE
softly.assertThat(props.getProperty("http.nonProxyHosts"))
.isEmpty();
.isNotEqualTo("localhost|my-custom-non-proxy.server.com");

// System properties defined in "sonar.scanner.javaOpts" are set on the provisioned JRE
softly.assertThat(props.getProperty("http.proxyUser")).isEqualTo("my-custom-user-from-system-properties");
} else {
//we test that we are using the system JRE
javaHomeAssertion
.isEqualTo(System.getProperty("java.home"))
.isEqualTo(guessJavaHomeSelectedByMvn())
.doesNotContain(".sonar" + File.separator + "cache");

softly.assertThat(props.getProperty("http.nonProxyHosts"))
Expand All @@ -166,4 +247,13 @@ void test_supported_arch_to_assert_jre_used() throws IOException {
softly.assertAll();
}

private static String guessJavaHomeSelectedByMvn() throws IOException {
// By default maven uses JAVA_HOME if it exists, otherwise we don't know, we hope it uses the one that is currently running
String javaHome = System.getenv("JAVA_HOME");
if (javaHome == null) {
javaHome = System.getProperty("java.home");
}
return new File(javaHome).getCanonicalPath();
}

}

0 comments on commit 2aa2921

Please sign in to comment.