]> source.dussan.org Git - sonarqube.git/commitdiff
SONAR-11950 add support of Azure DevOps
authorSimon Brandhof <simon.brandhof@sonarsource.com>
Tue, 21 May 2019 19:06:31 +0000 (21:06 +0200)
committerSonarTech <sonartech@sonarsource.com>
Wed, 22 May 2019 18:21:20 +0000 (20:21 +0200)
sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AzureDevops.java [new file with mode: 0644]
sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/ProjectScanContainer.java
sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AzureDevopsTest.java [new file with mode: 0644]

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 (file)
index 0000000..0eaad86
--- /dev/null
@@ -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);
+  }
+}
index 0bfdd5ca386f29c500130190e61450cad0241398..c9f85f3111d039a318eef29ac47f5519fc6fdeea 100644 (file)
@@ -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 (file)
index 0000000..ad70fe1
--- /dev/null
@@ -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);
+  }
+
+}