aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap
diff options
context:
space:
mode:
authorMatteo Mara <matteo.mara@sonarsource.com>2023-12-06 16:58:03 +0100
committersonartech <sonartech@sonarsource.com>2023-12-21 20:02:33 +0000
commit0f4fe6e6fb7d11f768c084bbe2ddb7ffd42d7c56 (patch)
tree456c4b2191c11e11f998428384007fb458d70fab /sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap
parentb0af995a136c1ec1b233337f6ee4a15fcd4e0c95 (diff)
downloadsonarqube-0f4fe6e6fb7d11f768c084bbe2ddb7ffd42d7c56.tar.gz
sonarqube-0f4fe6e6fb7d11f768c084bbe2ddb7ffd42d7c56.zip
SONAR-21195 Enhance scanner engine to download only required plugins
Diffstat (limited to 'sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap')
-rw-r--r--sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginInstallerTest.java37
-rw-r--r--sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginRepositoryTest.java63
2 files changed, 82 insertions, 18 deletions
diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginInstallerTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginInstallerTest.java
index 4e51f4d1b2f..60e8acbdbf8 100644
--- a/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginInstallerTest.java
+++ b/sonar-scanner-engine/src/test/java/org/sonar/scanner/bootstrap/ScannerPluginInstallerTest.java
@@ -23,6 +23,8 @@ import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.StringReader;
+import java.util.HashSet;
+import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.jar.Attributes;
@@ -51,11 +53,36 @@ public class ScannerPluginInstallerTest {
@Test
public void download_installed_plugins() throws IOException {
- WsTestUtil.mockReader(wsClient, "api/plugins/installed", new InputStreamReader(getClass().getResourceAsStream("ScannerPluginInstallerTest/installed-plugins-ws.json")));
+ WsTestUtil.mockReader(wsClient, "api/plugins/installed",
+ new InputStreamReader(getClass().getResourceAsStream("ScannerPluginInstallerTest/installed-plugins-ws.json")));
+ enqueueDownload("scmgit", "abc");
+ enqueueDownload("java", "def");
+
+ Map<String, ScannerPlugin> result = underTest.installRequiredPlugins();
+
+ assertThat(result.keySet()).containsExactlyInAnyOrder("scmgit");
+ ScannerPlugin gitPlugin = result.get("scmgit");
+ assertThat(gitPlugin.getKey()).isEqualTo("scmgit");
+ assertThat(gitPlugin.getInfo().getNonNullJarFile()).exists().isFile();
+ assertThat(gitPlugin.getUpdatedAt()).isEqualTo(100L);
+
+ Map<String, ScannerPlugin> result2 = underTest.installPluginsForLanguages(new HashSet<>(List.of("java")));
+
+ assertThat(result2.keySet()).containsExactlyInAnyOrder("java");
+ ScannerPlugin javaPlugin = result2.get("java");
+ assertThat(javaPlugin.getKey()).isEqualTo("java");
+ assertThat(javaPlugin.getInfo().getNonNullJarFile()).exists().isFile();
+ assertThat(javaPlugin.getUpdatedAt()).isEqualTo(200L);
+ }
+
+ @Test
+ public void download_all_plugins() throws IOException {
+ WsTestUtil.mockReader(wsClient, "api/plugins/installed",
+ new InputStreamReader(getClass().getResourceAsStream("ScannerPluginInstallerTest/installed-plugins-ws.json")));
enqueueDownload("scmgit", "abc");
enqueueDownload("java", "def");
- Map<String, ScannerPlugin> result = underTest.installRemotes();
+ Map<String, ScannerPlugin> result = underTest.installAllPlugins();
assertThat(result.keySet()).containsExactlyInAnyOrder("scmgit", "java");
ScannerPlugin gitPlugin = result.get("scmgit");
@@ -73,7 +100,7 @@ public class ScannerPluginInstallerTest {
public void fail_if_json_of_installed_plugins_is_not_valid() {
WsTestUtil.mockReader(wsClient, "api/plugins/installed", new StringReader("not json"));
- assertThatThrownBy(() -> underTest.installRemotes())
+ assertThatThrownBy(() -> underTest.installRequiredPlugins())
.isInstanceOf(IllegalStateException.class)
.hasMessage("Fail to parse response of api/plugins/installed");
}
@@ -87,7 +114,7 @@ public class ScannerPluginInstallerTest {
enqueueDownload("java", "def");
enqueueDownload("cobol", "ghi");
- Map<String, ScannerPlugin> result = underTest.installRemotes();
+ Map<String, ScannerPlugin> result = underTest.installRequiredPlugins();
assertThat(result.keySet()).containsExactlyInAnyOrder("java", "cobol");
}
@@ -101,7 +128,7 @@ public class ScannerPluginInstallerTest {
enqueueDownload("cobol", "ghi");
enqueueNotFoundDownload("java", "def");
- assertThatThrownBy(() -> underTest.installRemotes())
+ assertThatThrownBy(() -> underTest.installRequiredPlugins())
.isInstanceOf(IllegalStateException.class)
.hasMessage("Fail to download plugin [java]. Not found.");
}
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 7950dda8040..5fdb95cae22 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
@@ -21,9 +21,16 @@ package org.sonar.scanner.bootstrap;
import com.google.common.collect.ImmutableMap;
import java.io.File;
+import java.util.Collection;
import java.util.Collections;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Optional;
+import java.util.Set;
import org.junit.Test;
import org.sonar.api.Plugin;
+import org.sonar.api.config.Configuration;
import org.sonar.core.platform.ExplodedPlugin;
import org.sonar.core.platform.PluginClassLoader;
import org.sonar.core.platform.PluginInfo;
@@ -32,9 +39,12 @@ import org.sonar.core.plugin.PluginType;
import static org.assertj.core.api.Assertions.assertThat;
import static org.junit.Assert.fail;
+import static org.mockito.ArgumentMatchers.any;
import static org.mockito.ArgumentMatchers.anyCollection;
import static org.mockito.ArgumentMatchers.anyMap;
+import static org.mockito.ArgumentMatchers.anySet;
import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.never;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
@@ -43,31 +53,58 @@ public class ScannerPluginRepositoryTest {
PluginInstaller installer = mock(PluginInstaller.class);
PluginClassLoader loader = mock(PluginClassLoader.class);
PluginJarExploder exploder = new FakePluginJarExploder();
- ScannerPluginRepository underTest = new ScannerPluginRepository(installer, exploder, loader);
+ Configuration properties = mock(Configuration.class);
+ ScannerPluginRepository underTest = new ScannerPluginRepository(installer, exploder, loader, properties);
@Test
public void install_and_load_plugins() {
- PluginInfo info = new PluginInfo("java");
- ImmutableMap<String, ScannerPlugin> plugins = ImmutableMap.of("java", new ScannerPlugin("java", 1L, PluginType.EXTERNAL, info));
- Plugin instance = mock(Plugin.class);
- when(loader.load(anyMap())).thenReturn(ImmutableMap.of("java", instance));
- when(installer.installRemotes()).thenReturn(plugins);
+ PluginInfo squidInfo = new PluginInfo("squid");
+ PluginInfo javaInfo = new PluginInfo("java");
+ Map<String, ScannerPlugin> globalPlugins = Map.of("squid", new ScannerPlugin("squid", 1L, PluginType.BUNDLED, squidInfo));
+ Map<String, ScannerPlugin> languagePlugins = Map.of("java", new ScannerPlugin("java", 1L, PluginType.EXTERNAL, javaInfo));
+ Plugin squidInstance = mock(Plugin.class);
+ Plugin javaInstance = mock(Plugin.class);
+ when(loader.load(anyMap()))
+ .thenReturn(ImmutableMap.of("squid", squidInstance))
+ .thenReturn(ImmutableMap.of("java", javaInstance));
+
+ when(installer.installRequiredPlugins()).thenReturn(globalPlugins);
+ when(installer.installPluginsForLanguages(anySet())).thenReturn(languagePlugins);
underTest.start();
- assertThat(underTest.getPluginInfos()).containsOnly(info);
- assertThat(underTest.getPluginsByKey()).isEqualTo(plugins);
- assertThat(underTest.getPluginInfo("java")).isSameAs(info);
- assertThat(underTest.getPluginInstance("java")).isSameAs(instance);
- assertThat(underTest.getPluginInstances()).containsOnly(instance);
- assertThat(underTest.getBundledPluginsInfos()).isEmpty();
- assertThat(underTest.getExternalPluginsInfos()).isEqualTo(underTest.getPluginInfos());
+ assertThat(underTest.getPluginInfos()).containsOnly(squidInfo);
+ assertThat(underTest.getPluginsByKey()).isEqualTo(globalPlugins);
+ assertThat(underTest.getPluginInfo("squid")).isSameAs(squidInfo);
+ assertThat(underTest.getPluginInstance("squid")).isSameAs(squidInstance);
+
+ Collection<PluginInfo> result = underTest.installPluginsForLanguages(new HashSet<>(List.of("java")));
+
+ assertThat(result).containsOnly(javaInfo);
+ assertThat(underTest.getPluginInfos()).containsExactlyInAnyOrder(squidInfo, javaInfo);
+ assertThat(underTest.getExternalPluginsInfos()).containsExactlyInAnyOrder(javaInfo);
+ assertThat(underTest.getPluginsByKey().values()).containsExactlyInAnyOrder(globalPlugins.get("squid"), languagePlugins.get("java"));
underTest.stop();
verify(loader).unload(anyCollection());
}
@Test
+ public void should_install_all_plugins_when_loadall_flag_is_set() {
+ when(properties.getBoolean("sonar.plugins.loadAll")).thenReturn(Optional.of(true));
+
+ underTest.start();
+
+ verify(installer).installAllPlugins();
+ verify(installer, never()).installRequiredPlugins();
+
+ Collection<PluginInfo> result = underTest.installPluginsForLanguages(Set.of("java"));
+
+ assertThat(result).isEmpty();
+ verify(installer, never()).installPluginsForLanguages(any());
+ }
+
+ @Test
public void fail_if_requesting_missing_plugin() {
underTest.start();