diff options
5 files changed, 78 insertions, 23 deletions
diff --git a/sonar-batch/src/main/java/org/sonar/batch/DefaultProfileLoader.java b/sonar-batch/src/main/java/org/sonar/batch/DefaultProfileLoader.java index 6554b60c029..035d6209063 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/DefaultProfileLoader.java +++ b/sonar-batch/src/main/java/org/sonar/batch/DefaultProfileLoader.java @@ -19,11 +19,9 @@ */ package org.sonar.batch; -import com.google.common.base.Joiner; import org.apache.commons.lang.StringUtils; import org.sonar.api.config.Settings; import org.sonar.api.profiles.RulesProfile; -import org.sonar.api.resources.Languages; import org.sonar.api.resources.Project; import org.sonar.api.rules.ActiveRule; import org.sonar.api.utils.SonarException; @@ -36,17 +34,18 @@ public class DefaultProfileLoader implements ProfileLoader { this.dao = dao; } - public RulesProfile load(Project project, Settings settings, Languages languages) { - if (!languages.allKey().contains(project.getLanguageKey())) { - String languageList = Joiner.on(", ").join(languages.allKey()); - throw new SonarException("You must install a plugin that supports the language '" + project.getLanguageKey() + - "'. Supported language keys are: " + languageList); - } + public RulesProfile load(Project project, Settings settings) { String profileName = StringUtils.defaultIfBlank( settings.getString("sonar.profile"), settings.getString("sonar.profile." + project.getLanguageKey())); + if (StringUtils.isBlank(profileName)) { + // This means that the current language is not supported by any installed plugin, otherwise at least a + // "Default <Language Name>" profile would have been created by ActivateDefaultProfiles class. + throw new SonarException("You must install a plugin that supports the language '" + project.getLanguageKey() + "'"); + } + RulesProfile profile = dao.getProfile(project.getLanguageKey(), profileName); if (profile == null) { throw new SonarException("Quality profile not found : " + profileName + ", language " + project.getLanguageKey()); diff --git a/sonar-batch/src/main/java/org/sonar/batch/ProfileLoader.java b/sonar-batch/src/main/java/org/sonar/batch/ProfileLoader.java index 10479d7d21c..c844cef918f 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/ProfileLoader.java +++ b/sonar-batch/src/main/java/org/sonar/batch/ProfileLoader.java @@ -21,15 +21,13 @@ package org.sonar.batch; import org.sonar.api.config.Settings; import org.sonar.api.profiles.RulesProfile; -import org.sonar.api.resources.Languages; import org.sonar.api.resources.Project; public interface ProfileLoader { /** * Loads quality profile for specified project. - * @param languages remove this parameter when Languages is no more in scope ModuleScanContainer */ - RulesProfile load(Project project, Settings settings, Languages languages); + RulesProfile load(Project project, Settings settings); } diff --git a/sonar-batch/src/main/java/org/sonar/batch/ProfileProvider.java b/sonar-batch/src/main/java/org/sonar/batch/ProfileProvider.java index e93a61b100c..a645c9e99a1 100644 --- a/sonar-batch/src/main/java/org/sonar/batch/ProfileProvider.java +++ b/sonar-batch/src/main/java/org/sonar/batch/ProfileProvider.java @@ -19,6 +19,7 @@ */ package org.sonar.batch; +import com.google.common.base.Joiner; import org.picocontainer.injectors.ProviderAdapter; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -26,6 +27,7 @@ import org.sonar.api.config.Settings; import org.sonar.api.profiles.RulesProfile; import org.sonar.api.resources.Languages; import org.sonar.api.resources.Project; +import org.sonar.api.utils.SonarException; public class ProfileProvider extends ProviderAdapter { @@ -35,7 +37,14 @@ public class ProfileProvider extends ProviderAdapter { public RulesProfile provide(Project project, ProfileLoader profileLoader, Settings settings, Languages languages) { if (profile == null) { - profile = profileLoader.load(project, settings, languages); + // TODO Move this check to ProjectReactorValidator when Languages is available as TaskComponent + if (!languages.allKey().contains(project.getLanguageKey())) { + String languageList = Joiner.on(", ").join(languages.allKey()); + throw new SonarException("You must install a plugin that supports the language '" + project.getLanguageKey() + + "'. Supported language keys are: " + languageList); + } + + profile = profileLoader.load(project, settings); LOG.info("Quality profile : {}", profile); } return profile; diff --git a/sonar-batch/src/test/java/org/sonar/batch/DefaultProfileLoaderTest.java b/sonar-batch/src/test/java/org/sonar/batch/DefaultProfileLoaderTest.java index 836effb1b03..98004894633 100644 --- a/sonar-batch/src/test/java/org/sonar/batch/DefaultProfileLoaderTest.java +++ b/sonar-batch/src/test/java/org/sonar/batch/DefaultProfileLoaderTest.java @@ -69,7 +69,7 @@ public class DefaultProfileLoaderTest { settings.setProperty("sonar.profile.java", "legacy profile"); when(dao.getProfile(Java.KEY, "legacy profile")).thenReturn(RulesProfile.create("legacy profile", "java")); - RulesProfile profile = new DefaultProfileLoader(dao).load(javaProject, settings, languages); + RulesProfile profile = new DefaultProfileLoader(dao).load(javaProject, settings); assertThat(profile.getName()).isEqualTo("legacy profile"); } @@ -81,19 +81,19 @@ public class DefaultProfileLoaderTest { thrown.expect(SonarException.class); thrown.expectMessage("Quality profile not found : unknown, language java"); - new DefaultProfileLoader(dao).load(javaProject, settings, languages); + new DefaultProfileLoader(dao).load(javaProject, settings); } /** - * SONAR-3125, SONAR-4515 + * SONAR-3125 */ @Test public void should_give_explicit_message_if_default_profile_not_found() { Project cobolProject = newProject("cobol"); thrown.expect(SonarException.class); - thrown.expectMessage("You must install a plugin that supports the language 'cobol'. Supported language keys are: java, js"); - new DefaultProfileLoader(dao).load(cobolProject, new Settings(), languages); + thrown.expectMessage("You must install a plugin that supports the language 'cobol'"); + new DefaultProfileLoader(dao).load(cobolProject, new Settings()); } private Project newProject(String language) { diff --git a/sonar-batch/src/test/java/org/sonar/batch/ProfileProviderTest.java b/sonar-batch/src/test/java/org/sonar/batch/ProfileProviderTest.java index 7cc8ecddf80..4276ee3b404 100644 --- a/sonar-batch/src/test/java/org/sonar/batch/ProfileProviderTest.java +++ b/sonar-batch/src/test/java/org/sonar/batch/ProfileProviderTest.java @@ -19,11 +19,18 @@ */ package org.sonar.batch; +import org.apache.commons.configuration.PropertiesConfiguration; +import org.junit.Before; +import org.junit.Rule; import org.junit.Test; +import org.junit.rules.ExpectedException; import org.sonar.api.config.Settings; import org.sonar.api.profiles.RulesProfile; +import org.sonar.api.resources.AbstractLanguage; +import org.sonar.api.resources.Language; import org.sonar.api.resources.Languages; import org.sonar.api.resources.Project; +import org.sonar.api.utils.SonarException; import static org.hamcrest.Matchers.is; import static org.junit.Assert.assertThat; @@ -35,18 +42,60 @@ import static org.mockito.Mockito.verifyNoMoreInteractions; import static org.mockito.Mockito.when; public class ProfileProviderTest { + + @Rule + public ExpectedException thrown = ExpectedException.none(); + + private Project javaProject; + private Languages languages; + + @Before + public void setUp() { + + Language java = new AbstractLanguage("java", "Java") { + public String[] getFileSuffixes() { + return null; + }; + }; + Language cobol = new AbstractLanguage("js", "JavaScript") { + public String[] getFileSuffixes() { + return null; + }; + }; + languages = new Languages(java, cobol); + javaProject = newProject("java"); + } + @Test public void shouldProvideProfile() { ProfileProvider provider = new ProfileProvider(); ProfileLoader loader = mock(ProfileLoader.class); - Project project = new Project("project"); RulesProfile profile = RulesProfile.create(); - Languages languages = mock(Languages.class); - when(loader.load(eq(project), any(Settings.class), eq(languages))).thenReturn(profile); + when(loader.load(eq(javaProject), any(Settings.class))).thenReturn(profile); - assertThat(provider.provide(project, loader, new Settings(), languages), is(profile)); - assertThat(provider.provide(project, loader, new Settings(), languages), is(profile)); - verify(loader).load(eq(project), any(Settings.class), eq(languages)); + assertThat(provider.provide(javaProject, loader, new Settings(), languages), is(profile)); + assertThat(provider.provide(javaProject, loader, new Settings(), languages), is(profile)); + verify(loader).load(eq(javaProject), any(Settings.class)); verifyNoMoreInteractions(loader); } + + /** + * SONAR-4515 + */ + @Test + public void should_give_explicit_message_if_language_not_found() { + Project cobolProject = newProject("cobol"); + + ProfileProvider provider = new ProfileProvider(); + + thrown.expect(SonarException.class); + thrown.expectMessage("You must install a plugin that supports the language 'cobol'. Supported language keys are: java, js"); + provider.provide(cobolProject, mock(ProfileLoader.class), new Settings(), languages); + } + + private Project newProject(String language) { + PropertiesConfiguration configuration = new PropertiesConfiguration(); + configuration.setProperty("sonar.language", language); + return new Project("project").setConfiguration(configuration); + } } |