diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2019-05-21 21:06:31 +0200 |
---|---|---|
committer | SonarTech <sonartech@sonarsource.com> | 2019-05-22 20:21:20 +0200 |
commit | 2325a36db4b74b097bbe6b1f822641671d34a4c3 (patch) | |
tree | 9049ff417a8018937076c84ca88ccf4bbf0c851d /sonar-scanner-engine | |
parent | a1b53bb85e808ff3b9a7e090c74728011b428f34 (diff) | |
download | sonarqube-2325a36db4b74b097bbe6b1f822641671d34a4c3.tar.gz sonarqube-2325a36db4b74b097bbe6b1f822641671d34a4c3.zip |
SONAR-11950 add support of Azure DevOps
Diffstat (limited to 'sonar-scanner-engine')
3 files changed, 139 insertions, 0 deletions
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AzureDevops.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AzureDevops.java new file mode 100644 index 00000000000..0eaad861bee --- /dev/null +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AzureDevops.java @@ -0,0 +1,60 @@ +/* + * SonarQube + * Copyright (C) 2009-2019 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program 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. + * + * This program 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 this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.scanner.ci.vendors; + +import org.sonar.api.utils.System2; +import org.sonar.scanner.ci.CiConfiguration; +import org.sonar.scanner.ci.CiConfigurationImpl; +import org.sonar.scanner.ci.CiVendor; + +import static org.apache.commons.lang.StringUtils.isBlank; + +/** + * Support of https://azure.microsoft.com/en-us/services/devops/ + * + * Environment variables: https://docs.microsoft.com/en-us/azure/devops/pipelines/build/variables + */ +public class AzureDevops implements CiVendor { + + private final System2 system; + + public AzureDevops(System2 system) { + this.system = system; + } + + @Override + public String getName() { + return "Azure DevOps"; + } + + @Override + public boolean isDetected() { + return "true".equalsIgnoreCase(system.envVariable("TF_BUILD")); + } + + @Override + public CiConfiguration loadConfiguration() { + String revision = system.envVariable("SYSTEM_PULLREQUEST_SOURCECOMMITID"); + if (isBlank(revision)) { + revision = system.envVariable("BUILD_SOURCEVERSION"); + } + return new CiConfigurationImpl(revision); + } +} diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/ProjectScanContainer.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/ProjectScanContainer.java index 0bfdd5ca386..c9f85f3111d 100644 --- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/ProjectScanContainer.java +++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/ProjectScanContainer.java @@ -48,6 +48,7 @@ import org.sonar.scanner.bootstrap.PostJobExtensionDictionnary; import org.sonar.scanner.bootstrap.ProcessedScannerProperties; import org.sonar.scanner.ci.CiConfigurationProvider; import org.sonar.scanner.ci.vendors.AppVeyor; +import org.sonar.scanner.ci.vendors.AzureDevops; import org.sonar.scanner.ci.vendors.BitbucketPipelines; import org.sonar.scanner.ci.vendors.Buildkite; import org.sonar.scanner.ci.vendors.CircleCi; @@ -277,6 +278,7 @@ public class ProjectScanContainer extends ComponentContainer { // CI new CiConfigurationProvider(), AppVeyor.class, + AzureDevops.class, BitbucketPipelines.class, Buildkite.class, CircleCi.class, diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AzureDevopsTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AzureDevopsTest.java new file mode 100644 index 00000000000..ad70fe1e257 --- /dev/null +++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AzureDevopsTest.java @@ -0,0 +1,77 @@ +/* + * SonarQube + * Copyright (C) 2009-2019 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program 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. + * + * This program 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 this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.scanner.ci.vendors; + +import javax.annotation.Nullable; +import org.junit.Test; +import org.sonar.api.utils.System2; +import org.sonar.scanner.ci.CiVendor; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.when; + +public class AzureDevopsTest { + + private System2 system = mock(System2.class); + private CiVendor underTest = new AzureDevops(system); + + @Test + public void getName() { + assertThat(underTest.getName()).isEqualTo("Azure DevOps"); + } + + @Test + public void isDetected() { + setEnvVariable("TF_BUILD", "True"); + assertThat(underTest.isDetected()).isTrue(); + + setEnvVariable("TF_BUILD", "true"); + assertThat(underTest.isDetected()).isTrue(); + + setEnvVariable("CI", "true"); + setEnvVariable("APPVEYOR", null); + setEnvVariable("TF_BUILD", null); + assertThat(underTest.isDetected()).isFalse(); + } + + @Test + public void loadConfiguration_on_branch() { + setEnvVariable("BUILD_SOURCEVERSION", "abd12fc"); + + assertThat(underTest.loadConfiguration().getScmRevision()).hasValue("abd12fc"); + } + + @Test + public void loadConfiguration_on_pull_request() { + setEnvVariable("BUILD_SOURCEVERSION", "0e648ea"); + setEnvVariable("SYSTEM_PULLREQUEST_PULLREQUESTID", "12"); + setEnvVariable("SYSTEM_PULLREQUEST_PULLREQUESTITERATION", "5"); + setEnvVariable("SYSTEM_PULLREQUEST_SOURCEBRANCH", "refs/heads/azure-pipelines"); + setEnvVariable("SYSTEM_PULLREQUEST_SOURCECOMMITID", "a0e1e4c"); + + assertThat(underTest.loadConfiguration().getScmRevision()).hasValue("a0e1e4c"); + } + + private void setEnvVariable(String key, @Nullable String value) { + when(system.envVariable(key)).thenReturn(value); + } + +} |