aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatteo Mara <matteo.mara@sonarsource.com>2023-12-18 17:25:34 +0100
committersonartech <sonartech@sonarsource.com>2023-12-21 20:02:33 +0000
commit43f2e06d649bd047963863637ad95bdb9fdfa04e (patch)
treee6ea2773b207f29059d5d253dd6b289a48c9edea
parentac97b614d4746f683712851488d88952e06c59fc (diff)
downloadsonarqube-43f2e06d649bd047963863637ad95bdb9fdfa04e.tar.gz
sonarqube-43f2e06d649bd047963863637ad95bdb9fdfa04e.zip
SONAR-21197 add a property to enable the download of the required plugins only
-rw-r--r--sonar-core/src/main/java/org/sonar/core/config/ScannerProperties.java9
-rw-r--r--sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerPluginRepository.java11
-rw-r--r--sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginRepositoryTest.java6
3 files changed, 18 insertions, 8 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/config/ScannerProperties.java b/sonar-core/src/main/java/org/sonar/core/config/ScannerProperties.java
index 0eccffea26c..9dd608d27af 100644
--- a/sonar-core/src/main/java/org/sonar/core/config/ScannerProperties.java
+++ b/sonar-core/src/main/java/org/sonar/core/config/ScannerProperties.java
@@ -40,6 +40,7 @@ public class ScannerProperties {
public static final String FILE_SIZE_LIMIT = "sonar.filesize.limit";
public static final String LINKS_SOURCES_DEV = "sonar.links.scm_dev";
public static final String DISABLE_PROJECT_AND_ORG_AUTODETECTION = "sonar.keys_autodetection.disabled";
+ public static final String PLUGIN_LOADING_OPTIMIZATION_KEY = "sonar.plugins.downloadOnlyRequired";
private ScannerProperties() {
// only static stuff
@@ -91,6 +92,14 @@ public class ScannerProperties {
.description(
"Allows discarding files from analysis exceeding certain sizes.")
.hidden()
+ .build(),
+ PropertyDefinition.builder(PLUGIN_LOADING_OPTIMIZATION_KEY)
+ .name("Enable scanner plugin loading optimization")
+ .description("When enabled, scanners will only download plugins required for detected languages.")
+ .category(CoreProperties.CATEGORY_GENERAL)
+ .subCategory("Performance")
+ .type(BOOLEAN)
+ .defaultValue("true")
.build());
}
}
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerPluginRepository.java b/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerPluginRepository.java
index 074079f974e..4aecad4de72 100644
--- a/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerPluginRepository.java
+++ b/sonar-scanner-engine/src/main/java/org/sonar/scanner/bootstrap/ScannerPluginRepository.java
@@ -40,6 +40,7 @@ import org.sonar.scanner.mediumtest.LocalPlugin;
import static java.util.stream.Collectors.toMap;
import static org.sonar.api.utils.Preconditions.checkState;
+import static org.sonar.core.config.ScannerProperties.PLUGIN_LOADING_OPTIMIZATION_KEY;
/**
* Orchestrates the installation and loading of plugins
@@ -56,7 +57,7 @@ public class ScannerPluginRepository implements PluginRepository, Startable {
private Map<String, Plugin> pluginInstancesByKeys;
private Map<String, ScannerPlugin> pluginsByKeys;
private Map<ClassLoader, String> keysByClassLoader;
- private boolean shouldLoadAllPluginsOnStart;
+ private boolean shouldLoadOnlyRequiredPluginsOnStart;
public ScannerPluginRepository(PluginInstaller installer, PluginJarExploder pluginJarExploder, PluginClassLoader loader, Configuration properties) {
this.installer = installer;
@@ -67,9 +68,9 @@ public class ScannerPluginRepository implements PluginRepository, Startable {
@Override
public void start() {
- shouldLoadAllPluginsOnStart = properties.getBoolean("sonar.plugins.loadAll").orElse(false);
- if (shouldLoadAllPluginsOnStart) {
- LOG.warn("sonar.plugins.loadAll is true, so ALL available plugins will be downloaded");
+ shouldLoadOnlyRequiredPluginsOnStart = properties.getBoolean(PLUGIN_LOADING_OPTIMIZATION_KEY).orElse(true);
+ if (!shouldLoadOnlyRequiredPluginsOnStart) {
+ LOG.warn("{} is false, so ALL available plugins will be downloaded", PLUGIN_LOADING_OPTIMIZATION_KEY);
pluginsByKeys = new HashMap<>(installer.installAllPlugins());
} else {
pluginsByKeys = new HashMap<>(installer.installRequiredPlugins());
@@ -96,7 +97,7 @@ public class ScannerPluginRepository implements PluginRepository, Startable {
}
public Collection<PluginInfo> installPluginsForLanguages(Set<String> languageKeys) {
- if (shouldLoadAllPluginsOnStart) {
+ if (!shouldLoadOnlyRequiredPluginsOnStart) {
return Collections.emptySet();
}
diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginRepositoryTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginRepositoryTest.java
index 5fdb95cae22..a91426dad85 100644
--- a/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginRepositoryTest.java
+++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginRepositoryTest.java
@@ -47,6 +47,7 @@ import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
+import static org.sonar.core.config.ScannerProperties.PLUGIN_LOADING_OPTIMIZATION_KEY;
public class ScannerPluginRepositoryTest {
@@ -90,9 +91,8 @@ public class ScannerPluginRepositoryTest {
}
@Test
- public void should_install_all_plugins_when_loadall_flag_is_set() {
- when(properties.getBoolean("sonar.plugins.loadAll")).thenReturn(Optional.of(true));
-
+ public void should_install_all_plugins_when_downloadOnlyRequired_flag_is_false() {
+ when(properties.getBoolean(PLUGIN_LOADING_OPTIMIZATION_KEY)).thenReturn(Optional.of(false));
underTest.start();
verify(installer).installAllPlugins();