aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-core
diff options
context:
space:
mode:
authorSteve Marion <steve.marion@sonarsource.com>2024-11-21 10:36:22 +0100
committersonartech <sonartech@sonarsource.com>2024-11-28 20:02:59 +0000
commit84398329f3989d32830e7fd4f623c8b8fc47e5d5 (patch)
treebddb3ef6821fe5ca77f50728d0475b43a5e0fb45 /sonar-core
parent49e3469392c8a5d5d17a72a19b60583445993cee (diff)
downloadsonarqube-84398329f3989d32830e7fd4f623c8b8fc47e5d5.tar.gz
sonarqube-84398329f3989d32830e7fd4f623c8b8fc47e5d5.zip
SONAR-23755 Add core extension common to allow SQS specific behavior to happen. Add to DefaultLinkGenerator extension point to modify the default documentation base URL.
Diffstat (limited to 'sonar-core')
-rw-r--r--sonar-core/src/main/java/org/sonar/core/config/CorePropertyDefinitions.java4
-rw-r--r--sonar-core/src/main/java/org/sonar/core/documentation/DefaultDocumentationLinkGenerator.java26
-rw-r--r--sonar-core/src/main/java/org/sonar/core/documentation/DocumentationBaseLinkProvider.java33
-rw-r--r--sonar-core/src/main/java/org/sonar/core/documentation/DocumentationLinkGenerator.java2
-rw-r--r--sonar-core/src/main/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProvider.java50
-rw-r--r--sonar-core/src/test/java/org/sonar/core/documentation/DefaultDocumentationLinkGeneratorTest.java41
-rw-r--r--sonar-core/src/test/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProviderTest.java50
7 files changed, 157 insertions, 49 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/config/CorePropertyDefinitions.java b/sonar-core/src/main/java/org/sonar/core/config/CorePropertyDefinitions.java
index 440c6d09ff4..c8c4b139611 100644
--- a/sonar-core/src/main/java/org/sonar/core/config/CorePropertyDefinitions.java
+++ b/sonar-core/src/main/java/org/sonar/core/config/CorePropertyDefinitions.java
@@ -27,7 +27,6 @@ import org.sonar.api.PropertyType;
import org.sonar.api.config.EmailSettings;
import org.sonar.api.config.PropertyDefinition;
import org.sonar.api.config.PropertyDefinition.ConfigScope;
-import org.sonar.core.documentation.DefaultDocumentationLinkGenerator;
import org.sonar.core.extension.PluginRiskConsent;
import static java.util.Arrays.asList;
@@ -136,8 +135,7 @@ public class CorePropertyDefinitions {
.build(),
PropertyDefinition.builder(DOCUMENTATION_BASE_URL)
.name("Base URL of the documentation")
- .description("Base URL to be used in SonarQube documentation links, such as <i>https://docs.sonarsource.com/sonarqube/</i>")
- .defaultValue(DefaultDocumentationLinkGenerator.DOCUMENTATION_PUBLIC_URL)
+ .description("Override the base URL to be used in SonarQube documentation links.")
.hidden()
.type(STRING)
.build(),
diff --git a/sonar-core/src/main/java/org/sonar/core/documentation/DefaultDocumentationLinkGenerator.java b/sonar-core/src/main/java/org/sonar/core/documentation/DefaultDocumentationLinkGenerator.java
index 92c530ae8e1..b499c6406f4 100644
--- a/sonar-core/src/main/java/org/sonar/core/documentation/DefaultDocumentationLinkGenerator.java
+++ b/sonar-core/src/main/java/org/sonar/core/documentation/DefaultDocumentationLinkGenerator.java
@@ -22,31 +22,19 @@ package org.sonar.core.documentation;
import java.util.Optional;
import javax.annotation.Nullable;
import org.sonar.api.config.Configuration;
-import org.sonar.api.utils.Version;
import org.sonar.core.config.CorePropertyDefinitions;
-import org.sonar.core.platform.SonarQubeVersion;
public class DefaultDocumentationLinkGenerator implements DocumentationLinkGenerator {
- public static final String DOCUMENTATION_PUBLIC_URL = "https://docs.sonarsource.com/sonarqube/";
+ public static final String DOCUMENTATION_PUBLIC_URL = "https://docs.sonarsource.com/sonarqube-community-build";
private final String documentationBaseUrl;
- public DefaultDocumentationLinkGenerator(SonarQubeVersion sonarQubeVersion, Configuration configuration) {
- this.documentationBaseUrl = completeUrl(configuration.get(CorePropertyDefinitions.DOCUMENTATION_BASE_URL)
- .orElse(DOCUMENTATION_PUBLIC_URL), sonarQubeVersion.get());
- }
-
- private static String completeUrl(String baseUrl, Version version) {
- String url = baseUrl;
- if (!url.endsWith("/")) {
- url += "/";
- }
- if (version.qualifier().equals("SNAPSHOT")) {
- url += "latest";
- } else {
- url += version.major() + "." + version.minor();
- }
- return url;
+ public DefaultDocumentationLinkGenerator(Configuration configuration, @Nullable DocumentationBaseLinkProvider documentationBaseLinkProvider) {
+ this.documentationBaseUrl =
+ configuration.get(CorePropertyDefinitions.DOCUMENTATION_BASE_URL)
+ .or(() -> Optional.ofNullable(documentationBaseLinkProvider).map(DocumentationBaseLinkProvider::getDocumentationBaseUrl))
+ .map(url -> url.endsWith("/") ? url.substring(0, url.lastIndexOf("/")) : url)
+ .orElse(DOCUMENTATION_PUBLIC_URL);
}
@Override
diff --git a/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationBaseLinkProvider.java b/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationBaseLinkProvider.java
new file mode 100644
index 00000000000..e1f18289f84
--- /dev/null
+++ b/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationBaseLinkProvider.java
@@ -0,0 +1,33 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2024 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.core.documentation;
+
+import org.sonar.api.ce.ComputeEngineSide;
+import org.sonar.api.scanner.ScannerSide;
+import org.sonar.api.server.ServerSide;
+import org.sonar.core.extension.PlatformLevel;
+
+@ServerSide
+@ComputeEngineSide
+@ScannerSide
+@PlatformLevel(1)
+public interface DocumentationBaseLinkProvider {
+ String getDocumentationBaseUrl();
+}
diff --git a/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationLinkGenerator.java b/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationLinkGenerator.java
index 2ccbf5dbd89..aad1593af15 100644
--- a/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationLinkGenerator.java
+++ b/sonar-core/src/main/java/org/sonar/core/documentation/DocumentationLinkGenerator.java
@@ -23,10 +23,12 @@ import javax.annotation.Nullable;
import org.sonar.api.ce.ComputeEngineSide;
import org.sonar.api.scanner.ScannerSide;
import org.sonar.api.server.ServerSide;
+import org.sonar.core.extension.PlatformLevel;
@ServerSide
@ComputeEngineSide
@ScannerSide
+@PlatformLevel(1)
public interface DocumentationLinkGenerator {
String getDocumentationLink(@Nullable String suffix);
diff --git a/sonar-core/src/main/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProvider.java b/sonar-core/src/main/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProvider.java
new file mode 100644
index 00000000000..4b6b3271c86
--- /dev/null
+++ b/sonar-core/src/main/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProvider.java
@@ -0,0 +1,50 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2024 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.core.documentation;
+
+import org.sonar.api.utils.Version;
+import org.sonar.core.platform.SonarQubeVersion;
+
+public class VersionedDocumentationBaseLinkProvider implements DocumentationBaseLinkProvider {
+
+ private final String documentationBaseUrl;
+
+ public VersionedDocumentationBaseLinkProvider(String baseUrl, SonarQubeVersion sonarQubeVersion) {
+ documentationBaseUrl = completeUrl(baseUrl, sonarQubeVersion.get());
+ }
+
+ @Override
+ public String getDocumentationBaseUrl() {
+ return documentationBaseUrl;
+ }
+
+ private static String completeUrl(String baseUrl, Version version) {
+ String url = baseUrl;
+ if (!url.endsWith("/")) {
+ url += "/";
+ }
+ if ("SNAPSHOT".equals(version.qualifier())) {
+ url += "latest";
+ } else {
+ url += version.major() + "." + version.minor();
+ }
+ return url;
+ }
+}
diff --git a/sonar-core/src/test/java/org/sonar/core/documentation/DefaultDocumentationLinkGeneratorTest.java b/sonar-core/src/test/java/org/sonar/core/documentation/DefaultDocumentationLinkGeneratorTest.java
index 58f4f5b646c..852e4ac0cd2 100644
--- a/sonar-core/src/test/java/org/sonar/core/documentation/DefaultDocumentationLinkGeneratorTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/documentation/DefaultDocumentationLinkGeneratorTest.java
@@ -23,91 +23,78 @@ import java.util.Optional;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
-import org.mockito.Answers;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnitRunner;
import org.sonar.api.config.Configuration;
-import org.sonar.core.platform.SonarQubeVersion;
import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.when;
import static org.sonar.core.config.CorePropertyDefinitions.DOCUMENTATION_BASE_URL;
-import static org.sonar.core.documentation.DefaultDocumentationLinkGenerator.DOCUMENTATION_PUBLIC_URL;
@RunWith(MockitoJUnitRunner.class)
public class DefaultDocumentationLinkGeneratorTest {
private static final String TEST_SUFFIX = "/documentation/analyzing-source-code/scm-integration/";
+ public static final String BASE_URL = "http://base";
- @Mock(answer = Answers.RETURNS_DEEP_STUBS)
- private SonarQubeVersion sonarQubeVersion;
@Mock
private Configuration configuration;
+ @Mock
+ private DocumentationBaseLinkProvider documentationBaseLinkProvider;
private DefaultDocumentationLinkGenerator documentationLinkGenerator;
@Before
public void setUp() {
- when(sonarQubeVersion.get().major()).thenReturn(100);
- when(sonarQubeVersion.get().minor()).thenReturn(1000);
- when(sonarQubeVersion.get().qualifier()).thenReturn("");
when(configuration.get(DOCUMENTATION_BASE_URL)).thenReturn(Optional.empty());
- documentationLinkGenerator = new DefaultDocumentationLinkGenerator(sonarQubeVersion, configuration);
- }
-
- @Test
- public void getDocumentationLink_whenSuffixProvided_concatenatesIt() {
- String generatedLink = documentationLinkGenerator.getDocumentationLink(TEST_SUFFIX);
+ when(documentationBaseLinkProvider.getDocumentationBaseUrl()).thenReturn(BASE_URL);
- assertThat(generatedLink).isEqualTo(DOCUMENTATION_PUBLIC_URL + "100.1000/documentation/analyzing-source-code/scm-integration/");
+ documentationLinkGenerator = new DefaultDocumentationLinkGenerator(configuration, documentationBaseLinkProvider);
}
@Test
- public void getDocumentationLink_whenSnapshot_returnLatest() {
- when(sonarQubeVersion.get().qualifier()).thenReturn("SNAPSHOT");
- documentationLinkGenerator = new DefaultDocumentationLinkGenerator(sonarQubeVersion, configuration);
-
+ public void getDocumentationLink_whenSuffixProvided_concatenatesIt() {
String generatedLink = documentationLinkGenerator.getDocumentationLink(TEST_SUFFIX);
- assertThat(generatedLink).isEqualTo(DOCUMENTATION_PUBLIC_URL + "latest/documentation/analyzing-source-code/scm-integration/");
+ assertThat(generatedLink).isEqualTo(BASE_URL + "/documentation/analyzing-source-code/scm-integration/");
}
@Test
public void getDocumentationLink_whenSuffixNotProvided_returnsBaseUrl() {
String generatedLink = documentationLinkGenerator.getDocumentationLink(null);
- assertThat(generatedLink).isEqualTo(DOCUMENTATION_PUBLIC_URL + "100.1000");
+ assertThat(generatedLink).isEqualTo(BASE_URL);
}
@Test
public void getDocumentationLink_suffixProvided_withPropertyOverride() {
String propertyValue = "https://new-url.sonarqube.org/";
when(configuration.get(DOCUMENTATION_BASE_URL)).thenReturn(Optional.of(propertyValue));
- documentationLinkGenerator = new DefaultDocumentationLinkGenerator(sonarQubeVersion, configuration);
+ documentationLinkGenerator = new DefaultDocumentationLinkGenerator(configuration, documentationBaseLinkProvider);
String generatedLink = documentationLinkGenerator.getDocumentationLink(TEST_SUFFIX);
- assertThat(generatedLink).isEqualTo(propertyValue + "100.1000/documentation/analyzing-source-code/scm-integration/");
+ assertThat(generatedLink).isEqualTo(propertyValue + "documentation/analyzing-source-code/scm-integration/");
}
@Test
public void getDocumentationLink_suffixNotProvided_withPropertyOverride() {
String propertyValue = "https://new-url.sonarqube.org/";
when(configuration.get(DOCUMENTATION_BASE_URL)).thenReturn(Optional.of(propertyValue));
- documentationLinkGenerator = new DefaultDocumentationLinkGenerator(sonarQubeVersion, configuration);
+ documentationLinkGenerator = new DefaultDocumentationLinkGenerator(configuration, documentationBaseLinkProvider);
String generatedLink = documentationLinkGenerator.getDocumentationLink(null);
- assertThat(generatedLink).isEqualTo(propertyValue + "100.1000");
+ assertThat(generatedLink).isEqualTo("https://new-url.sonarqube.org");
}
@Test
public void getDocumentationLink_suffixNotProvided_withPropertyOverride_missingSlash() {
String propertyValue = "https://new-url.sonarqube.org";
when(configuration.get(DOCUMENTATION_BASE_URL)).thenReturn(Optional.of(propertyValue));
- documentationLinkGenerator = new DefaultDocumentationLinkGenerator(sonarQubeVersion, configuration);
+ documentationLinkGenerator = new DefaultDocumentationLinkGenerator(configuration, documentationBaseLinkProvider);
String generatedLink = documentationLinkGenerator.getDocumentationLink(null);
- assertThat(generatedLink).isEqualTo(propertyValue + "/100.1000");
+ assertThat(generatedLink).isEqualTo(propertyValue);
}
}
diff --git a/sonar-core/src/test/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProviderTest.java b/sonar-core/src/test/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProviderTest.java
new file mode 100644
index 00000000000..3de4c9e38d5
--- /dev/null
+++ b/sonar-core/src/test/java/org/sonar/core/documentation/VersionedDocumentationBaseLinkProviderTest.java
@@ -0,0 +1,50 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2024 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.core.documentation;
+
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.CsvSource;
+import org.sonar.api.utils.Version;
+import org.sonar.core.platform.SonarQubeVersion;
+
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+
+class VersionedDocumentationBaseLinkProviderTest {
+
+ @CsvSource({
+ "http://base/, 1.2, http://base/1.2",
+ "http://base, 1.2, http://base/1.2",
+ "http://base/, 1.2-SNAPSHOT, http://base/latest",
+ "http://base, 1.2-SNAPSHOT, http://base/latest",
+ })
+ @ParameterizedTest
+ void runTest(String baseUrl, String version, String expected) {
+ SonarQubeVersion sonarQubeVersion = mock();
+
+ when(sonarQubeVersion.get()).thenReturn(Version.parse(version));
+
+ VersionedDocumentationBaseLinkProvider versionedDocumentationBaseLinkProvider = new VersionedDocumentationBaseLinkProvider(baseUrl, sonarQubeVersion);
+
+ assertThat(versionedDocumentationBaseLinkProvider.getDocumentationBaseUrl())
+ .isEqualTo(expected);
+ }
+}