diff options
author | Fabrice Bellingard <bellingard@gmail.com> | 2011-09-08 14:21:19 +0200 |
---|---|---|
committer | Fabrice Bellingard <bellingard@gmail.com> | 2011-09-08 14:23:30 +0200 |
commit | cf9829861fca004f21640c27d692adb064b0f098 (patch) | |
tree | 25c8ef4f4f4b1b528203bbcb180c92ca49af7fce /sonar-testing-harness/src/main | |
parent | ae6cd424cdfce583739a61ffc387aa8efc04cb2d (diff) | |
download | sonarqube-cf9829861fca004f21640c27d692adb064b0f098.tar.gz sonarqube-cf9829861fca004f21640c27d692adb064b0f098.zip |
SONAR-2693 Improve I18n Harmcrest matcher
- #isBundleSynchronized replace by #isBundleUpToDate
- #assertAllBundlesUpToDate static method added to avoid specifying
files one by one
- if bundles are Core bundles translations, then the original bundles
are searched on Github using the Sonar version specified by the
"sonar.version" property in the POM
Diffstat (limited to 'sonar-testing-harness/src/main')
-rw-r--r-- | sonar-testing-harness/src/main/java/org/sonar/test/i18n/BundleSynchronizedMatcher.java | 35 | ||||
-rw-r--r-- | sonar-testing-harness/src/main/java/org/sonar/test/i18n/I18nMatchers.java | 47 |
2 files changed, 75 insertions, 7 deletions
diff --git a/sonar-testing-harness/src/main/java/org/sonar/test/i18n/BundleSynchronizedMatcher.java b/sonar-testing-harness/src/main/java/org/sonar/test/i18n/BundleSynchronizedMatcher.java index 8d794b01dfc..23baf7771d5 100644 --- a/sonar-testing-harness/src/main/java/org/sonar/test/i18n/BundleSynchronizedMatcher.java +++ b/sonar-testing-harness/src/main/java/org/sonar/test/i18n/BundleSynchronizedMatcher.java @@ -33,7 +33,9 @@ import java.io.IOException; import java.net.MalformedURLException; import java.net.URL; import java.util.Collection; +import java.util.MissingResourceException; import java.util.Properties; +import java.util.ResourceBundle; import java.util.Set; import org.apache.commons.io.IOUtils; @@ -163,17 +165,38 @@ public class BundleSynchronizedMatcher extends BaseMatcher<String> { } protected File getBundleFileFromGithub(String defaultBundleName) { - File bundle = new File("target/l10n/download/" + defaultBundleName); + File localBundle = new File("target/l10n/download/" + defaultBundleName); try { - saveUrl(remote_file_path + defaultBundleName, bundle); + String sonarVersion = getSonarVersionFromBundle(); + String remoteFile = computeGitHubURL(defaultBundleName, sonarVersion); + saveUrlToLocalFile(remoteFile, localBundle); } catch (MalformedURLException e) { fail("Could not download the original core bundle at: " + remote_file_path + defaultBundleName); } catch (IOException e) { fail("Could not download the original core bundle at: " + remote_file_path + defaultBundleName); } - assertThat("File 'target/tmp/" + defaultBundleName + "' has been downloaded but does not exist.", bundle, notNullValue()); - assertThat("File 'target/tmp/" + defaultBundleName + "' has been downloaded but does not exist.", bundle.exists(), is(true)); - return bundle; + assertThat("File 'target/tmp/" + defaultBundleName + "' has been downloaded but does not exist.", localBundle, notNullValue()); + assertThat("File 'target/tmp/" + defaultBundleName + "' has been downloaded but does not exist.", localBundle.exists(), is(true)); + return localBundle; + } + + protected String computeGitHubURL(String defaultBundleName, String sonarVersion) { + String computedURL = remote_file_path + defaultBundleName; + if (sonarVersion != null && !sonarVersion.startsWith("${") && !sonarVersion.contains("-SNAPSHOT")) { + computedURL = computedURL.replace("/master/", "/" + sonarVersion + "/"); + } + return computedURL; + } + + protected String getSonarVersionFromBundle() { + String version = null; + try { + ResourceBundle bundle = ResourceBundle.getBundle("version"); + version = bundle.getString("sonar.version"); + } catch (MissingResourceException e) { + // no problem, we won't use any specific version + } + return version; } protected File getBundleFileFromClasspath(String bundleName) { @@ -194,7 +217,7 @@ public class BundleSynchronizedMatcher extends BaseMatcher<String> { return CORE_BUNDLES.contains(defaultBundleName); } - private void saveUrl(String url, File localFile) throws MalformedURLException, IOException { + private void saveUrlToLocalFile(String url, File localFile) throws MalformedURLException, IOException { if (localFile.exists()) { localFile.delete(); } diff --git a/sonar-testing-harness/src/main/java/org/sonar/test/i18n/I18nMatchers.java b/sonar-testing-harness/src/main/java/org/sonar/test/i18n/I18nMatchers.java index 6d24a634eb6..90bc31e817e 100644 --- a/sonar-testing-harness/src/main/java/org/sonar/test/i18n/I18nMatchers.java +++ b/sonar-testing-harness/src/main/java/org/sonar/test/i18n/I18nMatchers.java @@ -19,12 +19,57 @@ */ package org.sonar.test.i18n; +import static org.junit.Assert.assertThat; +import static org.junit.Assert.fail; + +import java.io.File; +import java.util.Collection; +import java.util.Map; + +import org.apache.commons.io.FileUtils; +import org.apache.commons.lang.StringUtils; +import org.sonar.test.TestUtils; + +import com.google.common.collect.Maps; + public final class I18nMatchers { private I18nMatchers() { } - public static BundleSynchronizedMatcher isBundleSynchronized() { + public static BundleSynchronizedMatcher isBundleUpToDate() { return new BundleSynchronizedMatcher(); } + + public static void assertAllBundlesUpToDate() { + File bundleFolder = TestUtils.getResource(BundleSynchronizedMatcher.L10N_PATH); + if (bundleFolder == null || !bundleFolder.isDirectory()) { + fail("No bundle found in '" + BundleSynchronizedMatcher.L10N_PATH + "'"); + } + + Collection<File> bundles = FileUtils.listFiles(bundleFolder, new String[] { "properties" }, false); + Map<String, String> failedAssertionMessages = Maps.newHashMap(); + for (File bundle : bundles) { + String bundleName = bundle.getName(); + if (bundleName.indexOf('_') > 0) { + try { + assertThat(bundleName, isBundleUpToDate()); + } catch (AssertionError e) { + failedAssertionMessages.put(bundleName, e.getMessage()); + } + } + } + + if ( !failedAssertionMessages.isEmpty()) { + StringBuilder message = new StringBuilder(); + message.append(failedAssertionMessages.size()); + message.append(" bundles are not up-to-date: "); + message.append(StringUtils.join(failedAssertionMessages.keySet(), ", ")); + message.append("\n\n"); + message.append(StringUtils.join(failedAssertionMessages.values(), "\n\n")); + fail(message.toString()); + } + + } + } |