diff options
author | Matteo Mara <matteo.mara@sonarsource.com> | 2023-12-18 17:25:34 +0100 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2023-12-21 20:02:33 +0000 |
commit | 43f2e06d649bd047963863637ad95bdb9fdfa04e (patch) | |
tree | e6ea2773b207f29059d5d253dd6b289a48c9edea | |
parent | ac97b614d4746f683712851488d88952e06c59fc (diff) | |
download | sonarqube-43f2e06d649bd047963863637ad95bdb9fdfa04e.tar.gz sonarqube-43f2e06d649bd047963863637ad95bdb9fdfa04e.zip |
SONAR-21197 add a property to enable the download of the required plugins only
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(); |