diff options
author | simonbrandhof <simon.brandhof@gmail.com> | 2010-09-06 14:08:06 +0000 |
---|---|---|
committer | simonbrandhof <simon.brandhof@gmail.com> | 2010-09-06 14:08:06 +0000 |
commit | aeadc1f9129274949daaa57738c7c4550bdfbc7b (patch) | |
tree | 08dadf5ef7474fc41d1d48f74648f1ba8b55f34d /sonar-deprecated | |
download | sonarqube-aeadc1f9129274949daaa57738c7c4550bdfbc7b.tar.gz sonarqube-aeadc1f9129274949daaa57738c7c4550bdfbc7b.zip |
SONAR-236 remove deprecated code from checkstyle plugin + display default value of rule parameters in Q profile console
Diffstat (limited to 'sonar-deprecated')
6 files changed, 587 insertions, 0 deletions
diff --git a/sonar-deprecated/pom.xml b/sonar-deprecated/pom.xml new file mode 100644 index 00000000000..8737359a0ae --- /dev/null +++ b/sonar-deprecated/pom.xml @@ -0,0 +1,43 @@ +<?xml version="1.0" encoding="UTF-8"?> +<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + <modelVersion>4.0.0</modelVersion> + <parent> + <groupId>org.codehaus.sonar</groupId> + <artifactId>sonar</artifactId> + <version>2.3-SNAPSHOT</version> + </parent> + <artifactId>sonar-deprecated</artifactId> + <name>Sonar :: Deprecated</name> + + <dependencies> + <dependency> + <groupId>${project.groupId}</groupId> + <artifactId>sonar-core</artifactId> + </dependency> + <dependency> + <groupId>${project.groupId}</groupId> + <artifactId>sonar-plugin-api</artifactId> + </dependency> + + <dependency> + <groupId>junit</groupId> + <artifactId>junit</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>org.mockito</groupId> + <artifactId>mockito-all</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>org.hamcrest</groupId> + <artifactId>hamcrest-all</artifactId> + <scope>test</scope> + </dependency> + <dependency> + <groupId>org.dbunit</groupId> + <artifactId>dbunit</artifactId> + <scope>test</scope> + </dependency> + </dependencies> +</project>
\ No newline at end of file diff --git a/sonar-deprecated/src/main/java/org/sonar/api/batch/AbstractPurge.java b/sonar-deprecated/src/main/java/org/sonar/api/batch/AbstractPurge.java new file mode 100644 index 00000000000..f4218432165 --- /dev/null +++ b/sonar-deprecated/src/main/java/org/sonar/api/batch/AbstractPurge.java @@ -0,0 +1,35 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2009 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * Sonar 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. + * + * Sonar 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 Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.api.batch; + +import org.sonar.api.database.DatabaseSession; + +/** + * @since 1.10 + * @deprecated database components have been moved to sonar-database. Please extend org.sonar.core.purge.AbstractPurge. + */ +@Deprecated +public abstract class AbstractPurge extends org.sonar.core.purge.AbstractPurge { + + public AbstractPurge(DatabaseSession session) { + super(session); + } + +} diff --git a/sonar-deprecated/src/main/java/org/sonar/api/database/daos/MeasuresDao.java b/sonar-deprecated/src/main/java/org/sonar/api/database/daos/MeasuresDao.java new file mode 100644 index 00000000000..383864d37c8 --- /dev/null +++ b/sonar-deprecated/src/main/java/org/sonar/api/database/daos/MeasuresDao.java @@ -0,0 +1,75 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2009 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * Sonar 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. + * + * Sonar 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 Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.api.database.daos; + +import org.sonar.api.measures.Metric; + +import java.util.Collection; +import java.util.List; + +@Deprecated +public class MeasuresDao { + + private org.sonar.jpa.dao.MeasuresDao target; + + public MeasuresDao(org.sonar.jpa.dao.MeasuresDao target) { + this.target = target; + } + public Metric getMetric(Metric metric) { + return target.getMetric(metric); + } + + public List<Metric> getMetrics(List<Metric> metrics) { + return target.getMetrics(metrics); + } + + public Metric getMetric(String metricName) { + return target.getMetric(metricName); + } + + public Collection<Metric> getMetrics() { + return target.getMetrics(); + } + + public Collection<Metric> getEnabledMetrics() { + return target.getEnabledMetrics(); + } + + public Collection<Metric> getUserDefinedMetrics() { + return target.getUserDefinedMetrics(); + } + + public void disableAutomaticMetrics() { + target.disableAutomaticMetrics(); + } + + public void registerMetrics(Collection<Metric> metrics) { + target.registerMetrics(metrics); + } + + public void persistMetric(Metric metric) { + target.persistMetric(metric); + } + + public void disabledMetrics(Collection<Metric> metrics) { + target.disabledMetrics(metrics); + } + +} diff --git a/sonar-deprecated/src/main/java/org/sonar/api/database/daos/RulesDao.java b/sonar-deprecated/src/main/java/org/sonar/api/database/daos/RulesDao.java new file mode 100644 index 00000000000..1d5d5fb90bc --- /dev/null +++ b/sonar-deprecated/src/main/java/org/sonar/api/database/daos/RulesDao.java @@ -0,0 +1,97 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2009 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * Sonar 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. + * + * Sonar 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 Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.api.database.daos; + +import org.sonar.api.database.model.RuleFailureModel; +import org.sonar.api.database.model.Snapshot; +import org.sonar.api.profiles.RulesProfile; +import org.sonar.api.rules.ActiveRule; +import org.sonar.api.rules.Rule; +import org.sonar.api.rules.RuleParam; +import org.sonar.api.rules.RulesCategory; + +import java.util.List; + +@Deprecated +public class RulesDao { + + private org.sonar.jpa.dao.RulesDao target; + + public RulesDao(org.sonar.jpa.dao.RulesDao target) { + this.target = target; + } + + public List<Rule> getRules() { + return target.getRules(); + } + + public List<Rule> getRulesByPlugin(String pluginKey) { + return target.getRulesByPlugin(pluginKey); + } + + public List<Rule> getRulesByCategory(RulesCategory categ) { + return target.getRulesByCategory(categ); + } + + public Rule getRuleByKey(String pluginKey, String ruleKey) { + return target.getRuleByKey(pluginKey, ruleKey); + } + + public Long countRules(List<String> plugins, String categoryName) { + return target.countRules(plugins, categoryName); + } + + public List<RulesCategory> getCategories() { + return target.getCategories(); + } + + public RulesCategory getCategory(String key) { + return target.getCategory(key); + } + + + public List<RuleParam> getRuleParams() { + return target.getRuleParams(); + } + + public RuleParam getRuleParam(Rule rule, String paramKey) { + return target.getRuleParam(rule, paramKey); + } + + public void addActiveRulesToProfile(List<ActiveRule> activeRules, int profileId, String pluginKey) { + target.addActiveRulesToProfile(activeRules, profileId, pluginKey); + } + + public List<RuleFailureModel> getViolations(Snapshot snapshot) { + return target.getViolations(snapshot); + } + + public void synchronizeRuleOfActiveRule(ActiveRule activeRule, String pluginKey) { + target.synchronizeRuleOfActiveRule(activeRule, pluginKey); + } + + public boolean isRuleParamEqual(RuleParam ruleParam, RuleParam ruleParamFromDatabase, String ruleKey, String pluginKey) { + return target.isRuleParamEqual(ruleParam, ruleParamFromDatabase, ruleKey, pluginKey); + } + + public RulesProfile getProfileById(int profileId) { + return target.getProfileById(profileId); + } +} diff --git a/sonar-deprecated/src/main/java/org/sonar/api/rules/DefaultRulesManager.java b/sonar-deprecated/src/main/java/org/sonar/api/rules/DefaultRulesManager.java new file mode 100644 index 00000000000..dce362a38a6 --- /dev/null +++ b/sonar-deprecated/src/main/java/org/sonar/api/rules/DefaultRulesManager.java @@ -0,0 +1,247 @@ +/* + * Sonar, open source software quality management tool. + * Copyright (C) 2009 SonarSource SA + * mailto:contact AT sonarsource DOT com + * + * Sonar 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. + * + * Sonar 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 Sonar; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02 + */ +package org.sonar.api.rules; + +import org.apache.commons.collections.CollectionUtils; +import org.sonar.api.Plugin; +import org.sonar.api.Plugins; +import org.sonar.jpa.dao.RulesDao; +import org.sonar.api.resources.Language; + +import java.util.*; + +/** + * A class to manage and access rules defined in Sonar. + * + * @deprecated UGLY CLASS - WILL BE COMPLETELY REFACTORED IN SONAR 2.3 + */ +@Deprecated +public class DefaultRulesManager extends RulesManager { + + private final Set<Language> languages; + private final RulesRepository<?>[] repositories; + private final Map<Language, List<RulesRepository<?>>> rulesByLanguage; + private final Map<Language, List<Plugin>> pluginsByLanguage; + private final Map<String, Map<String, Rule>> rulesByPluginAndKey = new HashMap<String, Map<String, Rule>>(); + private final RulesDao rulesDao; + private final Plugins plugins; + + /** + * Creates a RuleManager + * @param plugins the plugins dictionnary + * @param repositories the repositories of rules + * @param dao the dao object + */ + public DefaultRulesManager(Plugins plugins, RulesRepository[] repositories, RulesDao dao) { + this.plugins = plugins; + this.rulesDao = dao; + + languages = new HashSet<Language>(); + rulesByLanguage = new HashMap<Language, List<RulesRepository<?>>>(); + pluginsByLanguage = new HashMap<Language, List<Plugin>>(); + this.repositories = repositories; + + for (RulesRepository<?> repository : repositories) { + languages.add(repository.getLanguage()); + + List<RulesRepository<?>> list = rulesByLanguage.get(repository.getLanguage()); + if (list == null) { + list = new ArrayList<RulesRepository<?>>(); + rulesByLanguage.put(repository.getLanguage(), list); + } + list.add(repository); + + List<Plugin> languagePlugins = pluginsByLanguage.get(repository.getLanguage()); + if (languagePlugins == null) { + languagePlugins = new ArrayList<Plugin>(); + pluginsByLanguage.put(repository.getLanguage(), languagePlugins); + } + languagePlugins.add(plugins.getPluginByExtension(repository)); + } + } + + /** + * Constructor for tests only + * + * @param dao the dao + */ + protected DefaultRulesManager(RulesDao dao, Plugins plugins) { + this.rulesDao = dao; + this.plugins = plugins; + languages = new HashSet<Language>(); + rulesByLanguage = new HashMap<Language, List<RulesRepository<?>>>(); + pluginsByLanguage = new HashMap<Language, List<Plugin>>(); + repositories = null; + + } + + /** + * Returns the list of languages for which there is a rule repository + * + * @return a Set of languages + */ + public Set<Language> getLanguages() { + return languages; + } + + /** + * Gets the list of Rules Repositories available for a language + * + * @param language the language + * @return the list of rules repositories + */ + public List<RulesRepository<?>> getRulesRepositories(Language language) { + List<RulesRepository<?>> rulesRepositories = rulesByLanguage.get(language); + if (CollectionUtils.isNotEmpty(rulesRepositories)) { + return rulesRepositories; + } + return Collections.emptyList(); + } + + /** + * Gets the complete list of Rules Repositories in the Sonar instance + * + * @return the list of rules repositories + */ + public List<RulesRepository<?>> getRulesRepositories() { + return Arrays.asList(repositories); + } + + /** + * Gets the list of rules plugins for a given language + * @param language the language + * @return the list of plugins + */ + public List<Plugin> getPlugins(Language language) { + List<Plugin> result = pluginsByLanguage.get(language); + if (!CollectionUtils.isEmpty(result)) { + return result; + } + return Collections.emptyList(); + } + + /** + * Gets count of rules by categories defined for a given language + * + * @param language the language + * @return a Map with the category as key and the count as value + */ + public Map<String, Long> countRulesByCategory(Language language) { + return countRulesByCategory(language, rulesDao); + } + + protected Map<String, Long> countRulesByCategory(Language language, RulesDao rulesDao) { + Map<String, Long> countByCategory = new HashMap<String, Long>(); + List<Plugin> result = getPlugins(language); + if (!CollectionUtils.isEmpty(result)) { + List<String> keys = getPluginKeys(getPlugins(language)); + for (RulesCategory rulesCategory : rulesDao.getCategories()) { + Long rulesCount = rulesDao.countRules(keys, rulesCategory.getName()); + countByCategory.put(rulesCategory.getName(), rulesCount); + } + } + return countByCategory; + } + + private List<String> getPluginKeys(List<Plugin> plugins) { + ArrayList<String> keys = new ArrayList<String>(); + for (Plugin plugin : plugins) { + keys.add(plugin.getKey()); + } + return keys; + } + + /** + * Get the list of rules plugin that implement a mechanism of export for a given language + * + * @param language the language + * @return the list of plugins + */ + public List<Plugin> getExportablePlugins(Language language) { + List<Plugin> targets = new ArrayList<Plugin>(); + List<RulesRepository<?>> rulesRepositories = getRulesRepositories(language); + for (RulesRepository<?> repository : rulesRepositories) { + if (repository instanceof ConfigurationExportable) { + targets.add(plugins.getPluginByExtension(repository)); + } + } + return targets; + } + + /** + * Get the list of rules plugin that implement a mechanism of import for a given language + * + * @param language the language + * @return the list of plugins + */ + public List<Plugin> getImportablePlugins(Language language) { + List<Plugin> targets = new ArrayList<Plugin>(); + for (RulesRepository<?> repository : getRulesRepositories(language)) { + if (repository instanceof ConfigurationImportable) { + targets.add(plugins.getPluginByExtension(repository)); + } + } + return targets; + } + + /** + * Gets a list of rules indexed by their key for a given plugin + * @param pluginKey the plugin key + * @return a Map with the rule key and the rule + */ + public Map<String, Rule> getPluginRulesIndexedByKey(String pluginKey) { + Map<String, Rule> rulesByKey = rulesByPluginAndKey.get(pluginKey); + if (rulesByKey == null) { + rulesByKey = new HashMap<String, Rule>(); + List<Rule> rules = rulesDao.getRulesByPlugin(pluginKey); + if (rules != null) { + for (Rule rule : rules) { + rulesByKey.put(rule.getKey(), rule); + } + } + rulesByPluginAndKey.put(pluginKey, rulesByKey); + } + return rulesByKey; + } + + /** + * Gets a collection of rules belonging to a plugin + * + * @param pluginKey the plugin key + * @return the collection of rules + */ + public Collection<Rule> getPluginRules(String pluginKey) { + Map<String, Rule> rulesByKey = getPluginRulesIndexedByKey(pluginKey); + return rulesByKey.values(); + } + + /** + * Gets a rule belonging to a defined plugin based on its key + * + * @param pluginKey the plugin key + * @param ruleKey the rule key + * @return the rule + */ + public Rule getPluginRule(String pluginKey, String ruleKey) { + Map<String, Rule> rulesByKey = getPluginRulesIndexedByKey(pluginKey); + return rulesByKey.get(ruleKey); + } + +} diff --git a/sonar-deprecated/src/test/java/org/sonar/api/rules/DefaultRulesManagerTest.java b/sonar-deprecated/src/test/java/org/sonar/api/rules/DefaultRulesManagerTest.java new file mode 100644 index 00000000000..62aa2a3a077 --- /dev/null +++ b/sonar-deprecated/src/test/java/org/sonar/api/rules/DefaultRulesManagerTest.java @@ -0,0 +1,90 @@ +/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2009 SonarSource SA
+ * mailto:contact AT sonarsource DOT com
+ *
+ * Sonar 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.
+ *
+ * Sonar 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 Sonar; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
+ */
+package org.sonar.api.rules;
+
+import org.junit.Test;
+import org.sonar.api.Plugin;
+import org.sonar.api.Plugins;
+import org.sonar.jpa.dao.RulesDao;
+import org.sonar.api.resources.Language;
+import org.sonar.jpa.dao.DaoFacade;
+
+import java.util.Collections;
+import java.util.List;
+import java.util.Map;
+
+import static org.hamcrest.CoreMatchers.is;
+import static org.hamcrest.MatcherAssert.assertThat;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+
+public class DefaultRulesManagerTest {
+
+ @Test
+ public void shouldReturnsZeroRulesByCategoryWhenNoPluginsForALanguage() {
+ DefaultRulesManager rulesManager = createRulesManagerForAlanguageWithNoPlugins();
+
+ Language language = mock(Language.class);
+ Map<String, Long> result = rulesManager.countRulesByCategory(language);
+ assertThat(result.size(), is(0));
+ }
+
+ @Test
+ public void shouldReturnsZeroExportablePluginsWhenLanguageHasNoRulesPlugin() {
+ DefaultRulesManager rulesManager = createRulesManagerForAlanguageWithNoPlugins();
+
+ Language language = mock(Language.class);
+ List<Plugin> result = rulesManager.getExportablePlugins(language);
+ assertThat(result.size(), is(0));
+ }
+
+ @Test
+ public void shouldReturnsZeroImportablePluginsWhenLanguageHasNoRulesPlugin() {
+ DefaultRulesManager rulesManager = createRulesManagerForAlanguageWithNoPlugins();
+
+ Language language = mock(Language.class);
+ List<Plugin> result = rulesManager.getImportablePlugins(language);
+ assertThat(result.size(), is(0));
+ }
+
+ @Test
+ public void shouldReturnZeroPluginWhenLanguageHasNoRulesPlugin() {
+ DefaultRulesManager rulesManager = createRulesManagerForAlanguageWithNoPlugins();
+ Language language = mock(Language.class);
+ List<Plugin> result = rulesManager.getPlugins(language);
+ assertThat(result.size(), is(0));
+ }
+
+ @Test
+ public void shouldReturnZeroRulesRepositoryWhenLanguageHasNoRulesRepository() {
+ DefaultRulesManager rulesManager = createRulesManagerForAlanguageWithNoPlugins();
+ Language language = mock(Language.class);
+ List<RulesRepository<?>> result = rulesManager.getRulesRepositories(language);
+ assertThat(result.size(), is(0));
+ }
+
+ private DefaultRulesManager createRulesManagerForAlanguageWithNoPlugins() {
+ DaoFacade dao = mock(DaoFacade.class);
+ RulesDao rulesDao = mock(RulesDao.class);
+ when(rulesDao.getCategories()).thenReturn(Collections.<RulesCategory>emptyList());
+ DefaultRulesManager rulesManager = new DefaultRulesManager(rulesDao, new Plugins(null));
+ return rulesManager;
+ }
+}
|