diff options
-rw-r--r-- | sonar-deprecated/pom.xml | 5 | ||||
-rw-r--r-- | sonar-testing-harness/pom.xml | 5 | ||||
-rw-r--r-- | sonar-testing-harness/src/main/java/org/sonar/test/i18n/RuleRepositoryTestHelper.java | 67 |
3 files changed, 74 insertions, 3 deletions
diff --git a/sonar-deprecated/pom.xml b/sonar-deprecated/pom.xml index 1a21f72325e..82394aebe91 100644 --- a/sonar-deprecated/pom.xml +++ b/sonar-deprecated/pom.xml @@ -39,9 +39,8 @@ </dependency> <dependency> - <groupId>${project.groupId}</groupId> - <artifactId>sonar-testing-harness</artifactId> - <version>${project.version}</version> + <groupId>org.hamcrest</groupId> + <artifactId>hamcrest-all</artifactId> <scope>test</scope> </dependency> <dependency> diff --git a/sonar-testing-harness/pom.xml b/sonar-testing-harness/pom.xml index e32a3a72f43..9e42d67fdb3 100644 --- a/sonar-testing-harness/pom.xml +++ b/sonar-testing-harness/pom.xml @@ -46,6 +46,11 @@ </dependency> <dependency> <groupId>org.codehaus.sonar</groupId> + <artifactId>sonar-deprecated</artifactId> + <version>${project.version}</version> + </dependency> + <dependency> + <groupId>org.codehaus.sonar</groupId> <artifactId>sonar-plugin-api</artifactId> <version>${project.version}</version> <type>test-jar</type> diff --git a/sonar-testing-harness/src/main/java/org/sonar/test/i18n/RuleRepositoryTestHelper.java b/sonar-testing-harness/src/main/java/org/sonar/test/i18n/RuleRepositoryTestHelper.java new file mode 100644 index 00000000000..62c45d8f77b --- /dev/null +++ b/sonar-testing-harness/src/main/java/org/sonar/test/i18n/RuleRepositoryTestHelper.java @@ -0,0 +1,67 @@ +/* + * SonarQube, open source software quality management tool. + * Copyright (C) 2008-2013 SonarSource + * mailto:contact AT sonarsource DOT com + * + * SonarQube 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. + * + * SonarQube 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.test.i18n; + +import com.google.common.io.Closeables; +import org.sonar.api.rules.Rule; +import org.sonar.api.rules.RuleRepository; +import org.sonar.api.utils.SonarException; +import org.sonar.test.TestUtils; + +import java.io.IOException; +import java.io.InputStream; +import java.util.List; +import java.util.Properties; + +public final class RuleRepositoryTestHelper { + private RuleRepositoryTestHelper() { + // Static utility class + } + + public static List<Rule> createRulesWithNameAndDescription(String pluginKey, RuleRepository repository) { + Properties props = loadProperties(String.format("/org/sonar/l10n/%s.properties", pluginKey)); + + List<Rule> rules = repository.createRules(); + for (Rule rule : rules) { + String name = props.getProperty(String.format("rule.%s.%s.name", repository.getKey(), rule.getKey())); + String description = TestUtils.getResourceContent(String.format("/org/sonar/l10n/%s/rules/%s/%s.html", pluginKey, repository.getKey(), rule.getKey())); + + rule.setName(name); + rule.setDescription(description); + } + + return rules; + } + + private static Properties loadProperties(String resourcePath) { + Properties properties = new Properties(); + + InputStream input = null; + try { + input = TestUtils.class.getResourceAsStream(resourcePath); + properties.load(input); + return properties; + } catch (IOException e) { + throw new SonarException("Unable to read properties " + resourcePath, e); + } finally { + Closeables.closeQuietly(input); + } + } +} |