aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-scanner-engine/src
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@sonarsource.com>2019-05-12 17:24:18 +0200
committerSonarTech <sonartech@sonarsource.com>2019-05-22 20:21:18 +0200
commit8e51dfd985545cb0b686dcee0a8a225e6cbeb15c (patch)
tree4e3c7bd86f592ec92d68be28552cb367d33cae6e /sonar-scanner-engine/src
parent4237a3a071c080bfdb739849a6ad6517b3b51fcd (diff)
downloadsonarqube-8e51dfd985545cb0b686dcee0a8a225e6cbeb15c.tar.gz
sonarqube-8e51dfd985545cb0b686dcee0a8a225e6cbeb15c.zip
SONAR-11950 autoconfig of SCM revision on AppVeyor
Diffstat (limited to 'sonar-scanner-engine/src')
-rw-r--r--sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AppVeyor.java55
-rw-r--r--sonar-scanner-engine/src/main/java/org/sonar/scanner/scan/ProjectScanContainer.java2
-rw-r--r--sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AppVeyorTest.java74
3 files changed, 131 insertions, 0 deletions
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AppVeyor.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AppVeyor.java
new file mode 100644
index 00000000000..6cf32448f40
--- /dev/null
+++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/ci/vendors/AppVeyor.java
@@ -0,0 +1,55 @@
+/*
+ * 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;
+
+/**
+ * Support of https://www.appveyor.com
+ *
+ * Environment variables: https://www.appveyor.com/docs/environment-variables/
+ */
+public class AppVeyor implements CiVendor {
+
+ private final System2 system;
+
+ public AppVeyor(System2 system) {
+ this.system = system;
+ }
+
+ @Override
+ public String getName() {
+ return "AppVeyor";
+ }
+
+ @Override
+ public boolean isDetected() {
+ return "true".equalsIgnoreCase(system.envVariable("CI")) && "true".equalsIgnoreCase(system.envVariable("APPVEYOR"));
+ }
+
+ @Override
+ public CiConfiguration loadConfiguration() {
+ String revision = system.envVariable("APPVEYOR_REPO_COMMIT");
+ 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 d6a502a90b7..cbffd780c3b 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
@@ -47,6 +47,7 @@ import org.sonar.scanner.bootstrap.MetricProvider;
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.BitbucketPipelines;
import org.sonar.scanner.ci.vendors.Buildkite;
import org.sonar.scanner.ci.vendors.CircleCi;
@@ -272,6 +273,7 @@ public class ProjectScanContainer extends ComponentContainer {
// CI
new CiConfigurationProvider(),
+ AppVeyor.class,
BitbucketPipelines.class,
Buildkite.class,
CircleCi.class,
diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AppVeyorTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AppVeyorTest.java
new file mode 100644
index 00000000000..7595bdc5d45
--- /dev/null
+++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/ci/vendors/AppVeyorTest.java
@@ -0,0 +1,74 @@
+/*
+ * 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 AppVeyorTest {
+
+ private System2 system = mock(System2.class);
+ private CiVendor underTest = new AppVeyor(system);
+
+ @Test
+ public void getName() {
+ assertThat(underTest.getName()).isEqualTo("AppVeyor");
+ }
+
+ @Test
+ public void isDetected() {
+ setEnvVariable("CI", "true");
+ setEnvVariable("APPVEYOR", "true");
+ assertThat(underTest.isDetected()).isTrue();
+
+ // on Windows
+ setEnvVariable("CI", "True");
+ setEnvVariable("APPVEYOR", "True");
+ assertThat(underTest.isDetected()).isTrue();
+
+ setEnvVariable("CI", "true");
+ setEnvVariable("SEMAPHORE", "true");
+ setEnvVariable("APPVEYOR", null);
+ assertThat(underTest.isDetected()).isFalse();
+
+ setEnvVariable("CI", "false");
+ setEnvVariable("APPVEYOR", "true");
+ assertThat(underTest.isDetected()).isFalse();
+ }
+
+ @Test
+ public void loadConfiguration() {
+ setEnvVariable("CI", "true");
+ setEnvVariable("APPVEYOR", "true");
+ setEnvVariable("APPVEYOR_REPO_COMMIT", "abd12fc");
+
+ assertThat(underTest.loadConfiguration().getScmRevision()).hasValue("abd12fc");
+ }
+
+ private void setEnvVariable(String key, @Nullable String value) {
+ when(system.envVariable(key)).thenReturn(value);
+ }
+}