diff options
author | Julien HENRY <julien.henry@sonarsource.com> | 2024-09-04 11:46:59 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2024-09-12 20:02:54 +0000 |
commit | 1d44e3b465b8df3ad3a0c63d17b2b24ef529fd79 (patch) | |
tree | 3b86b40a8d1d656b934dd284f7eadc007c61661f /sonar-scanner-engine/src/it/java | |
parent | e56fc5a6aa170161d32e171cf3b499a691924bd2 (diff) | |
download | sonarqube-1d44e3b465b8df3ad3a0c63d17b2b24ef529fd79.tar.gz sonarqube-1d44e3b465b8df3ad3a0c63d17b2b24ef529fd79.zip |
SONAR-22914 Move the ScannerMediumTester to testFixtures
Diffstat (limited to 'sonar-scanner-engine/src/it/java')
-rw-r--r-- | sonar-scanner-engine/src/it/java/org/sonar/scanner/mediumtest/ScannerMediumTester.java | 616 |
1 files changed, 0 insertions, 616 deletions
diff --git a/sonar-scanner-engine/src/it/java/org/sonar/scanner/mediumtest/ScannerMediumTester.java b/sonar-scanner-engine/src/it/java/org/sonar/scanner/mediumtest/ScannerMediumTester.java deleted file mode 100644 index 59eb6290e79..00000000000 --- a/sonar-scanner-engine/src/it/java/org/sonar/scanner/mediumtest/ScannerMediumTester.java +++ /dev/null @@ -1,616 +0,0 @@ -/* - * 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.scanner.mediumtest; - -import java.io.File; -import java.io.FileInputStream; -import java.io.IOException; -import java.io.InputStreamReader; -import java.io.Reader; -import java.nio.charset.StandardCharsets; -import java.nio.file.Path; -import java.util.ArrayList; -import java.util.Collections; -import java.util.Date; -import java.util.HashMap; -import java.util.LinkedList; -import java.util.List; -import java.util.Map; -import java.util.Optional; -import java.util.Properties; -import java.util.Set; -import javax.annotation.CheckForNull; -import javax.annotation.Nullable; -import javax.annotation.Priority; -import org.apache.commons.io.FileUtils; -import org.junit.jupiter.api.extension.AfterTestExecutionCallback; -import org.junit.jupiter.api.extension.BeforeTestExecutionCallback; -import org.junit.jupiter.api.extension.ExtensionContext; -import org.junit.rules.ExternalResource; -import org.sonar.api.Plugin; -import org.sonar.api.SonarEdition; -import org.sonar.api.SonarProduct; -import org.sonar.api.SonarQubeSide; -import org.sonar.api.SonarRuntime; -import org.sonar.api.batch.rule.LoadedActiveRule; -import org.sonar.api.impl.server.RulesDefinitionContext; -import org.sonar.api.measures.CoreMetrics; -import org.sonar.api.measures.Metric; -import org.sonar.api.rule.RuleKey; -import org.sonar.api.server.rule.RulesDefinition; -import org.sonar.api.server.rule.RulesDefinition.Repository; -import org.sonar.api.utils.DateUtils; -import org.sonar.api.utils.Version; -import org.sonar.batch.bootstrapper.Batch; -import org.sonar.batch.bootstrapper.EnvironmentInformation; -import org.sonar.batch.bootstrapper.LogOutput; -import org.sonar.scanner.bootstrap.GlobalAnalysisMode; -import org.sonar.scanner.cache.AnalysisCacheLoader; -import org.sonar.scanner.protocol.internal.SensorCacheData; -import org.sonar.scanner.report.CeTaskReportDataHolder; -import org.sonar.scanner.repository.FileData; -import org.sonar.scanner.repository.MetricsRepository; -import org.sonar.scanner.repository.MetricsRepositoryLoader; -import org.sonar.scanner.repository.NewCodePeriodLoader; -import org.sonar.scanner.repository.ProjectRepositories; -import org.sonar.scanner.repository.ProjectRepositoriesLoader; -import org.sonar.scanner.repository.QualityProfileLoader; -import org.sonar.scanner.repository.SingleProjectRepository; -import org.sonar.scanner.repository.settings.GlobalSettingsLoader; -import org.sonar.scanner.repository.settings.ProjectSettingsLoader; -import org.sonar.scanner.rule.ActiveRulesLoader; -import org.sonar.scanner.rule.RulesLoader; -import org.sonar.scanner.scan.ScanProperties; -import org.sonar.scanner.scan.branch.BranchConfiguration; -import org.sonar.scanner.scan.branch.BranchConfigurationLoader; -import org.sonar.scanner.scan.branch.BranchType; -import org.sonar.scanner.scan.branch.ProjectBranches; -import org.sonarqube.ws.NewCodePeriods; -import org.sonarqube.ws.Qualityprofiles.SearchWsResponse.QualityProfile; -import org.sonarqube.ws.Rules.Rule; - -import static java.util.Collections.emptySet; - -/** - * Main utility class for writing scanner medium tests. - */ -public class ScannerMediumTester extends ExternalResource implements BeforeTestExecutionCallback, AfterTestExecutionCallback { - - private static Path userHome = null; - private final Map<String, String> globalProperties = new HashMap<>(); - private final FakeMetricsRepositoryLoader globalRefProvider = new FakeMetricsRepositoryLoader(); - private final FakeBranchConfigurationLoader branchConfigurationLoader = new FakeBranchConfigurationLoader(); - private final FakeBranchConfiguration branchConfiguration = new FakeBranchConfiguration(); - private final FakeProjectRepositoriesLoader projectRefProvider = new FakeProjectRepositoriesLoader(); - private final FakePluginInstaller pluginInstaller = new FakePluginInstaller(); - private final FakeGlobalSettingsLoader globalSettingsLoader = new FakeGlobalSettingsLoader(); - private final FakeProjectSettingsLoader projectSettingsLoader = new FakeProjectSettingsLoader(); - private final FakeNewCodePeriodLoader newCodePeriodLoader = new FakeNewCodePeriodLoader(); - private final FakeAnalysisCacheLoader analysisCacheLoader = new FakeAnalysisCacheLoader(); - private final FakeRulesLoader rulesLoader = new FakeRulesLoader(); - private final FakeQualityProfileLoader qualityProfiles = new FakeQualityProfileLoader(); - private final FakeActiveRulesLoader activeRules = new FakeActiveRulesLoader(); - private final FakeSonarRuntime sonarRuntime = new FakeSonarRuntime(); - private final CeTaskReportDataHolder reportMetadataHolder = new CeTaskReportDataHolderExt(); - private final FakeLanguagesLoader languagesLoader = new FakeLanguagesLoader(); - private final FakeLanguagesProvider languagesProvider = new FakeLanguagesProvider(); - private LogOutput logOutput = null; - - private static void createWorkingDirs() throws IOException { - destroyWorkingDirs(); - - userHome = java.nio.file.Files.createTempDirectory("mediumtest-userHome"); - } - - private static void destroyWorkingDirs() throws IOException { - if (userHome != null) { - FileUtils.deleteDirectory(userHome.toFile()); - userHome = null; - } - } - - public ScannerMediumTester setLogOutput(LogOutput logOutput) { - this.logOutput = logOutput; - return this; - } - - public ScannerMediumTester registerPlugin(String pluginKey, File location) { - return registerPlugin(pluginKey, location, 1L); - } - - public ScannerMediumTester registerPlugin(String pluginKey, File location, long lastUpdatedAt) { - pluginInstaller.add(pluginKey, location, lastUpdatedAt); - return this; - } - - public ScannerMediumTester registerPlugin(String pluginKey, Plugin instance) { - pluginInstaller.add(pluginKey, instance); - return this; - } - - public ScannerMediumTester registerOptionalPlugin(String pluginKey, Set<String> requiredForLanguages, Plugin instance) { - pluginInstaller.addOptional(pluginKey, requiredForLanguages, instance); - return this; - } - - public ScannerMediumTester registerCoreMetrics() { - for (Metric<?> m : CoreMetrics.getMetrics()) { - registerMetric(m); - } - return this; - } - - public ScannerMediumTester registerMetric(Metric<?> metric) { - globalRefProvider.add(metric); - return this; - } - - public ScannerMediumTester addQProfile(String language, String name) { - qualityProfiles.add(language, name); - return this; - } - - public ScannerMediumTester addRule(Rule rule) { - rulesLoader.addRule(rule); - return this; - } - - public ScannerMediumTester addRule(String key, String repoKey, String internalKey, String name) { - Rule.Builder builder = Rule.newBuilder(); - builder.setKey(key); - builder.setRepo(repoKey); - if (internalKey != null) { - builder.setInternalKey(internalKey); - } - builder.setName(name); - - rulesLoader.addRule(builder.build()); - return this; - } - - public ScannerMediumTester addRules(RulesDefinition rulesDefinition) { - RulesDefinition.Context context = new RulesDefinitionContext(); - rulesDefinition.define(context); - List<Repository> repositories = context.repositories(); - for (Repository repo : repositories) { - for (RulesDefinition.Rule rule : repo.rules()) { - this.addRule(rule.key(), rule.repository().key(), rule.internalKey(), rule.name()); - } - } - return this; - } - - public ScannerMediumTester addDefaultQProfile(String language, String name) { - addQProfile(language, name); - return this; - } - - public ScannerMediumTester bootstrapProperties(Map<String, String> props) { - globalProperties.putAll(props); - return this; - } - - public ScannerMediumTester activateRule(LoadedActiveRule activeRule) { - activeRules.addActiveRule(activeRule); - return this; - } - - public ScannerMediumTester addActiveRule(String repositoryKey, String ruleKey, @Nullable String templateRuleKey, String name, @Nullable String severity, - @Nullable String internalKey, @Nullable String language) { - LoadedActiveRule r = new LoadedActiveRule(); - - r.setInternalKey(internalKey); - r.setRuleKey(RuleKey.of(repositoryKey, ruleKey)); - r.setName(name); - r.setTemplateRuleKey(templateRuleKey); - r.setLanguage(language); - r.setSeverity(severity); - r.setDeprecatedKeys(emptySet()); - - activeRules.addActiveRule(r); - return this; - } - - public ScannerMediumTester addFileData(String path, FileData fileData) { - projectRefProvider.addFileData(path, fileData); - return this; - } - - public ScannerMediumTester addGlobalServerSettings(String key, String value) { - globalSettingsLoader.getGlobalSettings().put(key, value); - return this; - } - - public ScannerMediumTester addProjectServerSettings(String key, String value) { - projectSettingsLoader.getProjectSettings().put(key, value); - return this; - } - - public ScannerMediumTester setNewCodePeriod(NewCodePeriods.NewCodePeriodType type, String value) { - newCodePeriodLoader.set(NewCodePeriods.ShowWSResponse.newBuilder().setType(type).setValue(value).build()); - return this; - } - - @Override - public void afterTestExecution(ExtensionContext extensionContext) { - after(); - } - - @Override - public void beforeTestExecution(ExtensionContext extensionContext) { - before(); - } - - @Override - protected void before() { - try { - createWorkingDirs(); - } catch (IOException e) { - throw new IllegalStateException(e); - } - registerCoreMetrics(); - globalProperties.put(GlobalAnalysisMode.MEDIUM_TEST_ENABLED, "true"); - globalProperties.put(ScanProperties.KEEP_REPORT_PROP_KEY, "true"); - globalProperties.put("sonar.userHome", userHome.toString()); - } - - @Override - protected void after() { - try { - destroyWorkingDirs(); - } catch (IOException e) { - throw new IllegalStateException(e); - } - } - - - public AnalysisBuilder newAnalysis() { - return new AnalysisBuilder(this); - } - - public AnalysisBuilder newAnalysis(File sonarProps) { - Properties prop = new Properties(); - try (Reader reader = new InputStreamReader(new FileInputStream(sonarProps), StandardCharsets.UTF_8)) { - prop.load(reader); - } catch (Exception e) { - throw new IllegalStateException("Unable to read configuration file", e); - } - AnalysisBuilder builder = new AnalysisBuilder(this); - builder.property("sonar.projectBaseDir", sonarProps.getParentFile().getAbsolutePath()); - for (Map.Entry<Object, Object> entry : prop.entrySet()) { - builder.property(entry.getKey().toString(), entry.getValue().toString()); - } - return builder; - } - - public void addLanguage(String key, String name, String... suffixes) { - languagesLoader.addLanguage(key, name, suffixes, new String[0]); - languagesProvider.addLanguage(key, name, true); - } - - public void addLanguage(String key, String name, boolean publishAllFiles, String... suffixes) { - languagesLoader.addLanguage(key, name, suffixes, new String[0]); - languagesProvider.addLanguage(key, name, publishAllFiles); - } - - public static class AnalysisBuilder { - private final Map<String, String> taskProperties = new HashMap<>(); - private final ScannerMediumTester tester; - - public AnalysisBuilder(ScannerMediumTester tester) { - this.tester = tester; - } - - public AnalysisResult execute() { - AnalysisResult result = new AnalysisResult(); - Map<String, String> props = new HashMap<>(); - props.putAll(tester.globalProperties); - props.putAll(taskProperties); - - Batch.Builder builder = Batch.builder() - .setGlobalProperties(props) - .setEnableLoggingConfiguration(true) - .addComponents(new EnvironmentInformation("mediumTest", "1.0"), - tester.pluginInstaller, - tester.globalRefProvider, - tester.qualityProfiles, - tester.rulesLoader, - tester.branchConfigurationLoader, - tester.projectRefProvider, - tester.activeRules, - tester.globalSettingsLoader, - tester.projectSettingsLoader, - tester.newCodePeriodLoader, - tester.analysisCacheLoader, - tester.sonarRuntime, - tester.reportMetadataHolder, - tester.languagesLoader, - tester.languagesProvider, - result); - if (tester.logOutput != null) { - builder.setLogOutput(tester.logOutput); - } else { - builder.setEnableLoggingConfiguration(false); - } - builder.build().execute(); - - return result; - } - - public AnalysisBuilder properties(Map<String, String> props) { - taskProperties.putAll(props); - return this; - } - - public AnalysisBuilder property(String key, String value) { - taskProperties.put(key, value); - return this; - } - - } - - @Priority(1) - private static class FakeRulesLoader implements RulesLoader { - private List<Rule> rules = new LinkedList<>(); - - public FakeRulesLoader addRule(Rule rule) { - rules.add(rule); - return this; - } - - @Override - public List<Rule> load() { - return rules; - } - } - - @Priority(1) - private static class FakeActiveRulesLoader implements ActiveRulesLoader { - private List<LoadedActiveRule> activeRules = new LinkedList<>(); - - public void addActiveRule(LoadedActiveRule activeRule) { - this.activeRules.add(activeRule); - } - - @Override - public List<LoadedActiveRule> load(String qualityProfileKey) { - return activeRules; - } - } - - @Priority(1) - private static class FakeMetricsRepositoryLoader implements MetricsRepositoryLoader { - - private int metricId = 1; - - private List<Metric> metrics = new ArrayList<>(); - - @Override - public MetricsRepository load() { - return new MetricsRepository(metrics); - } - - public FakeMetricsRepositoryLoader add(Metric<?> metric) { - metric.setUuid("metric" + metricId++); - metrics.add(metric); - metricId++; - return this; - } - - } - - @Priority(1) - private static class FakeProjectRepositoriesLoader implements ProjectRepositoriesLoader { - private Map<String, FileData> fileDataMap = new HashMap<>(); - - @Override - public ProjectRepositories load(String projectKey, @Nullable String branchBase) { - return new SingleProjectRepository(fileDataMap); - } - - public FakeProjectRepositoriesLoader addFileData(String path, FileData fileData) { - fileDataMap.put(path, fileData); - return this; - } - - } - - @Priority(1) - private static class FakeBranchConfiguration implements BranchConfiguration { - - private BranchType branchType = BranchType.BRANCH; - private String branchName = null; - private String branchTarget = null; - private String referenceBranchName = null; - - @Override - public BranchType branchType() { - return branchType; - } - - @CheckForNull - @Override - public String branchName() { - return branchName; - } - - @CheckForNull - @Override - public String targetBranchName() { - return branchTarget; - } - - @CheckForNull - @Override - public String referenceBranchName() { - return referenceBranchName; - } - - @Override - public String pullRequestKey() { - return "1'"; - } - } - - @Priority(1) - private static class FakeSonarRuntime implements SonarRuntime { - - private SonarEdition edition; - - FakeSonarRuntime() { - this.edition = SonarEdition.COMMUNITY; - } - - @Override - public Version getApiVersion() { - return Version.create(7, 8); - } - - @Override - public SonarProduct getProduct() { - return SonarProduct.SONARQUBE; - } - - @Override - public SonarQubeSide getSonarQubeSide() { - return SonarQubeSide.SCANNER; - } - - @Override - public SonarEdition getEdition() { - return edition; - } - - public void setEdition(SonarEdition edition) { - this.edition = edition; - } - } - - public ScannerMediumTester setBranchType(BranchType branchType) { - branchConfiguration.branchType = branchType; - return this; - } - - public ScannerMediumTester setBranchName(String branchName) { - this.branchConfiguration.branchName = branchName; - return this; - } - - public ScannerMediumTester setBranchTarget(String branchTarget) { - this.branchConfiguration.branchTarget = branchTarget; - return this; - } - - public ScannerMediumTester setReferenceBranchName(String referenceBranchNam) { - this.branchConfiguration.referenceBranchName = referenceBranchNam; - return this; - } - - public ScannerMediumTester setEdition(SonarEdition edition) { - this.sonarRuntime.setEdition(edition); - return this; - } - - @Priority(1) - private class FakeBranchConfigurationLoader implements BranchConfigurationLoader { - @Override - public BranchConfiguration load(Map<String, String> projectSettings, ProjectBranches branches) { - return branchConfiguration; - } - } - - @Priority(1) - private static class FakeQualityProfileLoader implements QualityProfileLoader { - - private List<QualityProfile> qualityProfiles = new LinkedList<>(); - - public void add(String language, String name) { - qualityProfiles.add(QualityProfile.newBuilder() - .setLanguage(language) - .setKey(name) - .setName(name) - .setRulesUpdatedAt(DateUtils.formatDateTime(new Date(1234567891212L))) - .build()); - } - - @Override - public List<QualityProfile> load(String projectKey) { - return qualityProfiles; - } - } - - @Priority(1) - private static class FakeAnalysisCacheLoader implements AnalysisCacheLoader { - @Override - public Optional<SensorCacheData> load() { - return Optional.empty(); - } - } - - @Priority(1) - private static class FakeGlobalSettingsLoader implements GlobalSettingsLoader { - - private Map<String, String> globalSettings = new HashMap<>(); - - public Map<String, String> getGlobalSettings() { - return globalSettings; - } - - @Override - public Map<String, String> loadGlobalSettings() { - return Collections.unmodifiableMap(globalSettings); - } - } - - @Priority(1) - private static class FakeNewCodePeriodLoader implements NewCodePeriodLoader { - private NewCodePeriods.ShowWSResponse response; - - @Override - public NewCodePeriods.ShowWSResponse load(String projectKey, String branchName) { - return response; - } - - public void set(NewCodePeriods.ShowWSResponse response) { - this.response = response; - } - } - - @Priority(1) - private static class FakeProjectSettingsLoader implements ProjectSettingsLoader { - - private Map<String, String> projectSettings = new HashMap<>(); - - public Map<String, String> getProjectSettings() { - return projectSettings; - } - - @Override - public Map<String, String> loadProjectSettings() { - return Collections.unmodifiableMap(projectSettings); - } - } - - @Priority(1) - private static class CeTaskReportDataHolderExt extends CeTaskReportDataHolder { - - } - -} |