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.

ScannerReportReaderTest.java 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341
  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.protocol.output;
  21. import com.google.common.collect.Lists;
  22. import java.io.File;
  23. import java.io.FileOutputStream;
  24. import java.io.InputStream;
  25. import org.apache.commons.io.FileUtils;
  26. import org.apache.commons.io.IOUtils;
  27. import org.junit.Before;
  28. import org.junit.Rule;
  29. import org.junit.Test;
  30. import org.junit.rules.TemporaryFolder;
  31. import org.sonar.core.util.CloseableIterator;
  32. import org.sonar.scanner.protocol.output.ScannerReport.Measure.StringValue;
  33. import org.sonar.scanner.protocol.output.ScannerReport.SyntaxHighlightingRule.HighlightingType;
  34. import static java.util.Arrays.asList;
  35. import static java.util.Collections.singletonList;
  36. import static org.assertj.core.api.Assertions.assertThat;
  37. public class ScannerReportReaderTest {
  38. private static int UNKNOWN_COMPONENT_REF = 123;
  39. @Rule
  40. public TemporaryFolder temp = new TemporaryFolder();
  41. private File dir;
  42. private ScannerReportReader underTest;
  43. @Before
  44. public void setUp() throws Exception {
  45. dir = temp.newFolder();
  46. underTest = new ScannerReportReader(dir);
  47. }
  48. @Test
  49. public void read_metadata() {
  50. ScannerReportWriter writer = new ScannerReportWriter(dir);
  51. ScannerReport.Metadata.Builder metadata = ScannerReport.Metadata.newBuilder()
  52. .setAnalysisDate(15000000L)
  53. .setProjectKey("PROJECT_A")
  54. .setRootComponentRef(1)
  55. .setCrossProjectDuplicationActivated(true);
  56. writer.writeMetadata(metadata.build());
  57. ScannerReport.Metadata readMetadata = underTest.readMetadata();
  58. assertThat(readMetadata.getAnalysisDate()).isEqualTo(15000000L);
  59. assertThat(readMetadata.getProjectKey()).isEqualTo("PROJECT_A");
  60. assertThat(readMetadata.getRootComponentRef()).isEqualTo(1);
  61. assertThat(readMetadata.getCrossProjectDuplicationActivated()).isTrue();
  62. }
  63. @Test(expected = IllegalStateException.class)
  64. public void fail_if_missing_metadata_file() {
  65. underTest.readMetadata();
  66. }
  67. @Test
  68. public void read_components() {
  69. ScannerReportWriter writer = new ScannerReportWriter(dir);
  70. ScannerReport.Component.Builder component = ScannerReport.Component.newBuilder()
  71. .setRef(1)
  72. .setProjectRelativePath("src/main/java/Foo.java");
  73. writer.writeComponent(component.build());
  74. assertThat(underTest.readComponent(1).getProjectRelativePath()).isEqualTo("src/main/java/Foo.java");
  75. }
  76. @Test(expected = IllegalStateException.class)
  77. public void fail_if_missing_file_on_component() {
  78. underTest.readComponent(UNKNOWN_COMPONENT_REF);
  79. }
  80. @Test
  81. public void read_issues() {
  82. ScannerReportWriter writer = new ScannerReportWriter(dir);
  83. ScannerReport.Issue issue = ScannerReport.Issue.newBuilder()
  84. .build();
  85. writer.writeComponentIssues(1, asList(issue));
  86. assertThat(underTest.readComponentIssues(1)).toIterable().hasSize(1);
  87. assertThat(underTest.readComponentIssues(200)).isExhausted();
  88. }
  89. @Test
  90. public void read_external_issues() {
  91. ScannerReportWriter writer = new ScannerReportWriter(dir);
  92. ScannerReport.ExternalIssue issue = ScannerReport.ExternalIssue.newBuilder()
  93. .build();
  94. writer.appendComponentExternalIssue(1, issue);
  95. assertThat(underTest.readComponentExternalIssues(1)).toIterable().hasSize(1);
  96. assertThat(underTest.readComponentExternalIssues(200)).toIterable().isEmpty();
  97. }
  98. @Test
  99. public void empty_list_if_no_issue_found() {
  100. assertThat(underTest.readComponentIssues(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  101. }
  102. @Test
  103. public void read_measures() {
  104. ScannerReportWriter writer = new ScannerReportWriter(dir);
  105. ScannerReport.Measure.Builder measure = ScannerReport.Measure.newBuilder()
  106. .setStringValue(StringValue.newBuilder().setValue("value_a"));
  107. writer.appendComponentMeasure(1, measure.build());
  108. assertThat(underTest.readComponentMeasures(1)).toIterable().hasSize(1);
  109. }
  110. @Test
  111. public void empty_list_if_no_measure_found() {
  112. assertThat(underTest.readComponentMeasures(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  113. }
  114. @Test
  115. public void read_changesets() {
  116. ScannerReportWriter writer = new ScannerReportWriter(dir);
  117. ScannerReport.Changesets.Builder scm = ScannerReport.Changesets.newBuilder()
  118. .setComponentRef(1)
  119. .addChangeset(ScannerReport.Changesets.Changeset.newBuilder().setDate(123_456_789).setAuthor("jack.daniels").setRevision("123-456-789"));
  120. writer.writeComponentChangesets(scm.build());
  121. assertThat(underTest.readChangesets(1).getChangesetList()).hasSize(1);
  122. assertThat(underTest.readChangesets(1).getChangeset(0).getDate()).isEqualTo(123_456_789L);
  123. }
  124. @Test
  125. public void null_if_no_changeset_found() {
  126. assertThat(underTest.readChangesets(UNKNOWN_COMPONENT_REF)).isNull();
  127. }
  128. @Test
  129. public void read_duplications() {
  130. ScannerReportWriter writer = new ScannerReportWriter(dir);
  131. writer.writeMetadata(ScannerReport.Metadata.newBuilder()
  132. .setRootComponentRef(1).build());
  133. writer.writeComponent(ScannerReport.Component.newBuilder()
  134. .setRef(1).build());
  135. ScannerReport.Duplication duplication = ScannerReport.Duplication.newBuilder()
  136. .setOriginPosition(ScannerReport.TextRange.newBuilder()
  137. .setStartLine(1)
  138. .setEndLine(5)
  139. .build())
  140. .addDuplicate(ScannerReport.Duplicate.newBuilder()
  141. .setOtherFileRef(2)
  142. .setRange(ScannerReport.TextRange.newBuilder()
  143. .setStartLine(6)
  144. .setEndLine(10)
  145. .build())
  146. .build())
  147. .build();
  148. writer.writeComponentDuplications(1, asList(duplication));
  149. ScannerReportReader sut = new ScannerReportReader(dir);
  150. assertThat(sut.readComponentDuplications(1)).toIterable().hasSize(1);
  151. }
  152. @Test
  153. public void empty_list_if_no_duplication_found() {
  154. assertThat(underTest.readComponentDuplications(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  155. }
  156. @Test
  157. public void read_duplication_blocks() {
  158. ScannerReportWriter writer = new ScannerReportWriter(dir);
  159. writer.writeMetadata(ScannerReport.Metadata.newBuilder()
  160. .setRootComponentRef(1).build());
  161. writer.writeComponent(ScannerReport.Component.newBuilder()
  162. .setRef(1).build());
  163. ScannerReport.CpdTextBlock duplicationBlock = ScannerReport.CpdTextBlock.newBuilder()
  164. .setHash("abcdefghijklmnop")
  165. .setStartLine(1)
  166. .setEndLine(2)
  167. .setStartTokenIndex(10)
  168. .setEndTokenIndex(15)
  169. .build();
  170. writer.writeCpdTextBlocks(1, singletonList(duplicationBlock));
  171. ScannerReportReader sut = new ScannerReportReader(dir);
  172. assertThat(sut.readCpdTextBlocks(1)).toIterable().hasSize(1);
  173. }
  174. @Test
  175. public void empty_list_if_no_duplication_block_found() {
  176. assertThat(underTest.readComponentDuplications(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  177. }
  178. @Test
  179. public void read_syntax_highlighting() {
  180. ScannerReportWriter writer = new ScannerReportWriter(dir);
  181. writer.writeMetadata(ScannerReport.Metadata.newBuilder()
  182. .setRootComponentRef(1)
  183. .build());
  184. writer.writeComponent(ScannerReport.Component.newBuilder()
  185. .setRef(1).build());
  186. writer.writeComponentSyntaxHighlighting(1, asList(
  187. ScannerReport.SyntaxHighlightingRule.newBuilder()
  188. .setRange(ScannerReport.TextRange.newBuilder()
  189. .setStartLine(1)
  190. .setEndLine(10)
  191. .build())
  192. .setType(HighlightingType.ANNOTATION)
  193. .build()));
  194. try (CloseableIterator<ScannerReport.SyntaxHighlightingRule> it = underTest.readComponentSyntaxHighlighting(1)) {
  195. ScannerReport.SyntaxHighlightingRule syntaxHighlighting = it.next();
  196. assertThat(syntaxHighlighting.getRange()).isNotNull();
  197. assertThat(syntaxHighlighting.getRange().getStartLine()).isEqualTo(1);
  198. assertThat(syntaxHighlighting.getRange().getEndLine()).isEqualTo(10);
  199. assertThat(syntaxHighlighting.getType()).isEqualTo(HighlightingType.ANNOTATION);
  200. }
  201. }
  202. @Test
  203. public void return_empty_if_no_highlighting_found() {
  204. assertThat(underTest.readComponentSyntaxHighlighting(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  205. }
  206. @Test
  207. public void read_symbols() {
  208. ScannerReportWriter writer = new ScannerReportWriter(dir);
  209. writer.writeMetadata(ScannerReport.Metadata.newBuilder()
  210. .setRootComponentRef(1)
  211. .build());
  212. writer.writeComponent(ScannerReport.Component.newBuilder()
  213. .setRef(1).build());
  214. writer.writeComponentSymbols(1, asList(ScannerReport.Symbol.newBuilder()
  215. .setDeclaration(ScannerReport.TextRange.newBuilder()
  216. .setStartLine(1)
  217. .setStartOffset(3)
  218. .setEndLine(1)
  219. .setEndOffset(5)
  220. .build())
  221. .addReference(ScannerReport.TextRange.newBuilder()
  222. .setStartLine(10)
  223. .setStartOffset(15)
  224. .setEndLine(11)
  225. .setEndOffset(2)
  226. .build())
  227. .build()));
  228. underTest = new ScannerReportReader(dir);
  229. assertThat(underTest.readComponentSymbols(1)).toIterable().hasSize(1);
  230. }
  231. @Test
  232. public void empty_list_if_no_symbol_found() {
  233. assertThat(underTest.readComponentSymbols(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  234. }
  235. @Test
  236. public void read_coverage() {
  237. ScannerReportWriter writer = new ScannerReportWriter(dir);
  238. writer.writeMetadata(ScannerReport.Metadata.newBuilder()
  239. .setRootComponentRef(1)
  240. .build());
  241. writer.writeComponent(ScannerReport.Component.newBuilder()
  242. .setRef(1).build());
  243. writer.writeComponentCoverage(1, asList(
  244. ScannerReport.LineCoverage.newBuilder()
  245. .setLine(1)
  246. .setConditions(1)
  247. .setHits(true)
  248. .setCoveredConditions(1)
  249. .build(),
  250. ScannerReport.LineCoverage.newBuilder()
  251. .setLine(2)
  252. .setConditions(5)
  253. .setHits(false)
  254. .setCoveredConditions(4)
  255. .build()));
  256. underTest = new ScannerReportReader(dir);
  257. try (CloseableIterator<ScannerReport.LineCoverage> it = new ScannerReportReader(dir).readComponentCoverage(1)) {
  258. ScannerReport.LineCoverage coverage = it.next();
  259. assertThat(coverage.getLine()).isEqualTo(1);
  260. assertThat(coverage.getConditions()).isEqualTo(1);
  261. assertThat(coverage.getHits()).isTrue();
  262. assertThat(coverage.getCoveredConditions()).isEqualTo(1);
  263. }
  264. }
  265. @Test
  266. public void return_empty_iterator_if_no_coverage_found() {
  267. assertThat(underTest.readComponentCoverage(UNKNOWN_COMPONENT_REF)).toIterable().isEmpty();
  268. }
  269. @Test
  270. public void read_source_lines() throws Exception {
  271. ScannerReportWriter writer = new ScannerReportWriter(dir);
  272. File file = writer.getFileStructure().fileFor(FileStructure.Domain.SOURCE, 1);
  273. FileUtils.writeLines(file, Lists.newArrayList("line1", "line2"));
  274. File sourceFile = new ScannerReportReader(dir).readFileSource(1);
  275. assertThat(sourceFile).isEqualTo(file);
  276. }
  277. @Test
  278. public void read_file_source() throws Exception {
  279. ScannerReportWriter writer = new ScannerReportWriter(dir);
  280. try (FileOutputStream outputStream = new FileOutputStream(writer.getSourceFile(1))) {
  281. IOUtils.write("line1\nline2", outputStream);
  282. }
  283. try (InputStream inputStream = FileUtils.openInputStream(underTest.readFileSource(1))) {
  284. assertThat(IOUtils.readLines(inputStream)).containsOnly("line1", "line2");
  285. }
  286. }
  287. @Test
  288. public void return_null_when_no_file_source() {
  289. assertThat(underTest.readFileSource(UNKNOWN_COMPONENT_REF)).isNull();
  290. }
  291. }