diff options
author | Simon Brandhof <simon.brandhof@gmail.com> | 2014-02-24 17:00:06 +0100 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@gmail.com> | 2014-02-24 17:00:06 +0100 |
commit | 9409d0c2e94126127b0546117a8089f6bff5a637 (patch) | |
tree | 589cd427a3546576e75b75dbab464c136ee772b3 /sonar-plugin-api | |
parent | 7a7927c95bdaacf87b6a0f7d9611e77b1060d636 (diff) | |
download | sonarqube-9409d0c2e94126127b0546117a8089f6bff5a637.tar.gz sonarqube-9409d0c2e94126127b0546117a8089f6bff5a637.zip |
Fix some quality flaws
Diffstat (limited to 'sonar-plugin-api')
3 files changed, 112 insertions, 2 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/DefaultFileSystem.java b/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/DefaultFileSystem.java index ad5486a21e3..6a21a8d6c15 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/DefaultFileSystem.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/DefaultFileSystem.java @@ -161,7 +161,7 @@ public class DefaultFileSystem implements FileSystem { * This method is called before each search of files. */ protected void doPreloadFiles() { - + // nothing to do by default } public static abstract class Cache { diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/PathPattern.java b/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/PathPattern.java index 186226fb47b..6b34b4b1d3b 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/PathPattern.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/batch/fs/internal/PathPattern.java @@ -79,7 +79,7 @@ public abstract class PathPattern { if (!caseSensitiveFileExtension) { String extension = sanitizeExtension(FilenameUtils.getExtension(inputFile.file().getName())); if (StringUtils.isNotBlank(extension)) { - StringUtils.removeEndIgnoreCase(path, extension); + path = StringUtils.removeEndIgnoreCase(path, extension); path = path + extension; } } diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/batch/fs/internal/PathPatternTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/batch/fs/internal/PathPatternTest.java new file mode 100644 index 00000000000..ca63ffb344a --- /dev/null +++ b/sonar-plugin-api/src/test/java/org/sonar/api/batch/fs/internal/PathPatternTest.java @@ -0,0 +1,110 @@ +/* + * 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.api.batch.fs.internal; + +import org.junit.Rule; +import org.junit.Test; +import org.junit.rules.TemporaryFolder; +import org.sonar.api.batch.fs.InputFile; + +import java.io.File; + +import static org.fest.assertions.Assertions.assertThat; + +public class PathPatternTest { + @Rule + public TemporaryFolder temp = new TemporaryFolder(); + + @Test + public void match_relative_path() throws Exception { + PathPattern pattern = PathPattern.create("**/*Foo.java"); + assertThat(pattern.toString()).isEqualTo("**/*Foo.java"); + + File file = new File(temp.newFolder(), "src/main/java/org/MyFoo.java"); + InputFile inputFile = new DefaultInputFile("src/main/java/org/MyFoo.java").setFile(file); + assertThat(pattern.match(inputFile)).isTrue(); + + // case sensitive by default + file = new File(temp.newFolder(), "src/main/java/org/MyFoo.JAVA"); + inputFile = new DefaultInputFile("src/main/java/org/MyFoo.JAVA").setFile(file); + assertThat(pattern.match(inputFile)).isFalse(); + + file = new File(temp.newFolder(), "src/main/java/org/Other.java"); + inputFile = new DefaultInputFile("src/main/java/org/Other.java").setFile(file); + assertThat(pattern.match(inputFile)).isFalse(); + } + + @Test + public void match_relative_path_and_insensitive_file_extension() throws Exception { + PathPattern pattern = PathPattern.create("**/*Foo.java"); + + File file = new File(temp.newFolder(), "src/main/java/org/MyFoo.JAVA"); + InputFile inputFile = new DefaultInputFile("src/main/java/org/MyFoo.JAVA").setFile(file); + assertThat(pattern.match(inputFile, false)).isTrue(); + + file = new File(temp.newFolder(), "src/main/java/org/Other.java"); + inputFile = new DefaultInputFile("src/main/java/org/Other.java").setFile(file); + assertThat(pattern.match(inputFile, false)).isFalse(); + } + + @Test + public void match_absolute_path() throws Exception { + PathPattern pattern = PathPattern.create("file:**/src/main/**Foo.java"); + assertThat(pattern.toString()).isEqualTo("file:**/src/main/**Foo.java"); + + File file = new File(temp.newFolder(), "src/main/java/org/MyFoo.java"); + InputFile inputFile = new DefaultInputFile("src/main/java/org/MyFoo.java").setFile(file); + assertThat(pattern.match(inputFile)).isTrue(); + + // case sensitive by default + file = new File(temp.newFolder(), "src/main/java/org/MyFoo.JAVA"); + inputFile = new DefaultInputFile("src/main/java/org/MyFoo.JAVA").setFile(file); + assertThat(pattern.match(inputFile)).isFalse(); + + file = new File(temp.newFolder(), "src/main/java/org/Other.java"); + inputFile = new DefaultInputFile("src/main/java/org/Other.java").setFile(file); + assertThat(pattern.match(inputFile)).isFalse(); + } + + @Test + public void match_absolute_path_and_insensitive_file_extension() throws Exception { + PathPattern pattern = PathPattern.create("file:**/src/main/**Foo.java"); + assertThat(pattern.toString()).isEqualTo("file:**/src/main/**Foo.java"); + + File file = new File(temp.newFolder(), "src/main/java/org/MyFoo.JAVA"); + InputFile inputFile = new DefaultInputFile("src/main/java/org/MyFoo.JAVA").setFile(file); + assertThat(pattern.match(inputFile, false)).isTrue(); + + file = new File(temp.newFolder(), "src/main/java/org/Other.JAVA"); + inputFile = new DefaultInputFile("src/main/java/org/Other.JAVA").setFile(file); + assertThat(pattern.match(inputFile, false)).isFalse(); + } + + @Test + public void create_array_of_patterns() throws Exception { + PathPattern[] patterns = PathPattern.create(new String[]{ + "**/src/main/**Foo.java", + "file:**/src/main/**Bar.java" + }); + assertThat(patterns).hasSize(2); + assertThat(patterns[0].toString()).isEqualTo("**/src/main/**Foo.java"); + assertThat(patterns[1].toString()).isEqualTo("file:**/src/main/**Bar.java"); + } +} |