You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

MetadataGeneratorTest.java 6.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2019 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.scanner.scan.filesystem;
  21. import java.io.IOException;
  22. import java.nio.charset.StandardCharsets;
  23. import java.nio.file.Path;
  24. import java.nio.file.Paths;
  25. import org.apache.commons.io.FileUtils;
  26. import org.junit.Assert;
  27. import org.junit.Before;
  28. import org.junit.Rule;
  29. import org.junit.Test;
  30. import org.junit.rules.TemporaryFolder;
  31. import org.mockito.Mock;
  32. import org.mockito.MockitoAnnotations;
  33. import org.sonar.api.batch.fs.InputFile;
  34. import org.sonar.api.batch.fs.internal.DefaultInputFile;
  35. import org.sonar.api.batch.fs.internal.FileMetadata;
  36. import org.sonar.api.batch.fs.internal.TestInputFileBuilder;
  37. import org.sonar.api.utils.PathUtils;
  38. import org.sonar.scanner.issue.ignore.pattern.IssueExclusionPatternInitializer;
  39. import org.sonar.scanner.issue.ignore.pattern.PatternMatcher;
  40. import org.sonar.scanner.issue.ignore.scanner.IssueExclusionsLoader;
  41. import static org.apache.commons.codec.digest.DigestUtils.md5Hex;
  42. import static org.assertj.core.api.Assertions.assertThat;
  43. import static org.mockito.Mockito.mock;
  44. import static org.mockito.Mockito.when;
  45. public class MetadataGeneratorTest {
  46. @Rule
  47. public TemporaryFolder temp = new TemporaryFolder();
  48. @Mock
  49. private StatusDetection statusDetection;
  50. @Mock
  51. private DefaultModuleFileSystem fs;
  52. private FileMetadata metadata;
  53. private MetadataGenerator generator;
  54. @Before
  55. public void setUp() throws IOException {
  56. MockitoAnnotations.initMocks(this);
  57. metadata = new FileMetadata();
  58. IssueExclusionsLoader issueExclusionsLoader = new IssueExclusionsLoader(mock(IssueExclusionPatternInitializer.class), mock(PatternMatcher.class));
  59. generator = new MetadataGenerator(statusDetection, metadata, issueExclusionsLoader);
  60. }
  61. @Test
  62. public void should_detect_charset_from_BOM() {
  63. Path basedir = Paths.get("src/test/resources/org/sonar/scanner/scan/filesystem/");
  64. assertThat(createInputFileWithMetadata(basedir.resolve("without_BOM.txt")).charset())
  65. .isEqualTo(StandardCharsets.US_ASCII);
  66. assertThat(createInputFileWithMetadata(basedir.resolve("UTF-8.txt")).charset())
  67. .isEqualTo(StandardCharsets.UTF_8);
  68. assertThat(createInputFileWithMetadata(basedir.resolve("UTF-16BE.txt")).charset())
  69. .isEqualTo(StandardCharsets.UTF_16BE);
  70. assertThat(createInputFileWithMetadata(basedir.resolve("UTF-16LE.txt")).charset())
  71. .isEqualTo(StandardCharsets.UTF_16LE);
  72. assertThat(createInputFileWithMetadata(basedir.resolve("UTF-32BE.txt")).charset())
  73. .isEqualTo(MetadataGenerator.UTF_32BE);
  74. assertThat(createInputFileWithMetadata(basedir.resolve("UTF-32LE.txt")).charset())
  75. .isEqualTo(MetadataGenerator.UTF_32LE);
  76. }
  77. private DefaultInputFile createInputFileWithMetadata(Path filePath) {
  78. return createInputFileWithMetadata(filePath.getParent(), filePath.getFileName().toString());
  79. }
  80. private DefaultInputFile createInputFileWithMetadata(Path baseDir, String relativePath) {
  81. DefaultInputFile inputFile = new TestInputFileBuilder("struts", relativePath)
  82. .setModuleBaseDir(baseDir)
  83. .build();
  84. generator.setMetadata("module", inputFile, StandardCharsets.US_ASCII);
  85. return inputFile;
  86. }
  87. @Test
  88. public void start_with_bom() throws Exception {
  89. Path tempFile = temp.newFile().toPath();
  90. FileUtils.write(tempFile.toFile(), "\uFEFFfoo\nbar\r\nbaz", StandardCharsets.UTF_8, true);
  91. DefaultInputFile inputFile = createInputFileWithMetadata(tempFile);
  92. assertThat(inputFile.lines()).isEqualTo(3);
  93. assertThat(inputFile.nonBlankLines()).isEqualTo(3);
  94. assertThat(inputFile.hash()).isEqualTo(md5Hex("foo\nbar\nbaz"));
  95. assertThat(inputFile.originalLineStartOffsets()).containsOnly(0, 4, 9);
  96. assertThat(inputFile.originalLineEndOffsets()).containsOnly(3, 7, 12);
  97. }
  98. @Test
  99. public void use_default_charset_if_detection_fails() throws IOException {
  100. Path tempFile = temp.newFile().toPath();
  101. byte invalidWindows1252 = (byte) 129;
  102. byte[] b = {(byte) 0xDF, (byte) 0xFF, (byte) 0xFF, invalidWindows1252};
  103. FileUtils.writeByteArrayToFile(tempFile.toFile(), b);
  104. DefaultInputFile inputFile = createInputFileWithMetadata(tempFile);
  105. assertThat(inputFile.charset()).isEqualTo(StandardCharsets.US_ASCII);
  106. }
  107. @Test
  108. public void non_existing_file_should_throw_exception() {
  109. try {
  110. createInputFileWithMetadata(Paths.get(""), "non_existing");
  111. Assert.fail();
  112. } catch (IllegalStateException e) {
  113. assertThat(e.getMessage()).endsWith("Unable to read file " + Paths.get("").resolve("non_existing").toAbsolutePath());
  114. assertThat(e.getCause()).isInstanceOf(IllegalStateException.class);
  115. }
  116. }
  117. @Test
  118. public void complete_input_file() throws Exception {
  119. // file system
  120. Path baseDir = temp.newFolder().toPath();
  121. Path srcFile = baseDir.resolve("src/main/java/foo/Bar.java");
  122. FileUtils.touch(srcFile.toFile());
  123. FileUtils.write(srcFile.toFile(), "single line");
  124. // status
  125. DefaultInputFile inputFile = createInputFileWithMetadata(baseDir, "src/main/java/foo/Bar.java");
  126. when(statusDetection.status("foo", inputFile, "6c1d64c0b3555892fe7273e954f6fb5a"))
  127. .thenReturn(InputFile.Status.ADDED);
  128. assertThat(inputFile.type()).isEqualTo(InputFile.Type.MAIN);
  129. assertThat(inputFile.file()).isEqualTo(srcFile.toFile());
  130. assertThat(inputFile.absolutePath()).isEqualTo(PathUtils.sanitize(srcFile.toAbsolutePath().toString()));
  131. assertThat(inputFile.key()).isEqualTo("struts:src/main/java/foo/Bar.java");
  132. assertThat(inputFile.relativePath()).isEqualTo("src/main/java/foo/Bar.java");
  133. assertThat(inputFile.lines()).isEqualTo(1);
  134. }
  135. }