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.

FileSourceDtoTest.java 4.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  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.db.source;
  21. import com.google.common.base.Joiner;
  22. import java.util.Collections;
  23. import java.util.List;
  24. import java.util.Random;
  25. import java.util.stream.Collectors;
  26. import java.util.stream.IntStream;
  27. import org.junit.Rule;
  28. import org.junit.Test;
  29. import org.junit.rules.ExpectedException;
  30. import org.sonar.db.protobuf.DbFileSources;
  31. import static org.assertj.core.api.Assertions.assertThat;
  32. public class FileSourceDtoTest {
  33. private static final String LOREM_IPSUM = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam ac magna libero. " +
  34. "Integer eu quam vulputate, interdum ante quis, sodales mauris. Nam mollis ornare dolor at maximus. Cras pharetra aliquam fringilla. " +
  35. "Nunc hendrerit, elit eu mattis fermentum, ligula metus malesuada nunc, non fermentum augue tellus eu odio. Praesent ut vestibulum nibh. " +
  36. "Curabitur sit amet dignissim magna, at efficitur dolor. Ut non felis aliquam justo euismod gravida. Morbi eleifend vitae ante eu pulvinar. " +
  37. "Aliquam rhoncus magna quis lorem posuere semper.";
  38. @Rule
  39. public ExpectedException expectedException = ExpectedException.none();
  40. @Test
  41. public void getSourceData_throws_ISE_with_id_fileUuid_and_projectUuid_in_message_when_data_cant_be_read() {
  42. long id = 12L;
  43. String fileUuid = "file uuid";
  44. String projectUuid = "project uuid";
  45. FileSourceDto underTest = new FileSourceDto()
  46. .setBinaryData(new byte[] {1, 2, 3, 4, 5})
  47. .setId(id)
  48. .setFileUuid(fileUuid)
  49. .setProjectUuid(projectUuid);
  50. expectedException.expect(IllegalStateException.class);
  51. expectedException.expectMessage("Fail to decompress and deserialize source data [id=" + id + ",fileUuid=" + fileUuid + ",projectUuid=" + projectUuid + "]");
  52. underTest.getSourceData();
  53. }
  54. @Test
  55. public void getSourceData_reads_Data_object_bigger_than_default_size_limit() {
  56. DbFileSources.Data build = createOver64MBDataStructure();
  57. byte[] bytes = FileSourceDto.encodeSourceData(build);
  58. DbFileSources.Data data = new FileSourceDto().decodeSourceData(bytes);
  59. assertThat(data.getLinesCount()).isEqualTo(build.getLinesCount());
  60. }
  61. private static DbFileSources.Data createOver64MBDataStructure() {
  62. DbFileSources.Data.Builder dataBuilder = DbFileSources.Data.newBuilder();
  63. DbFileSources.Line.Builder lineBuilder = DbFileSources.Line.newBuilder();
  64. for (int i = 0; i < 199999; i++) {
  65. dataBuilder.addLines(
  66. lineBuilder.setSource(LOREM_IPSUM)
  67. .setLine(i)
  68. .build());
  69. }
  70. return dataBuilder.build();
  71. }
  72. @Test
  73. public void new_FileSourceDto_as_lineCount_0_and_rawLineHashes_to_null() {
  74. FileSourceDto underTest = new FileSourceDto();
  75. assertThat(underTest.getLineCount()).isZero();
  76. assertThat(underTest.getLineHashes()).isEmpty();
  77. assertThat(underTest.getRawLineHashes()).isNull();
  78. }
  79. @Test
  80. public void setLineHashes_null_sets_lineCount_to_0_and_rawLineHashes_to_null() {
  81. FileSourceDto underTest = new FileSourceDto();
  82. underTest.setLineHashes(null);
  83. assertThat(underTest.getLineCount()).isZero();
  84. assertThat(underTest.getLineHashes()).isEmpty();
  85. assertThat(underTest.getRawLineHashes()).isNull();
  86. }
  87. @Test
  88. public void setLineHashes_empty_sets_lineCount_to_1_and_rawLineHashes_to_null() {
  89. FileSourceDto underTest = new FileSourceDto();
  90. underTest.setLineHashes(Collections.emptyList());
  91. assertThat(underTest.getLineCount()).isEqualTo(1);
  92. assertThat(underTest.getLineHashes()).isEmpty();
  93. assertThat(underTest.getRawLineHashes()).isNull();
  94. }
  95. @Test
  96. public void setLineHashes_sets_lineCount_to_size_of_list_and_rawLineHashes_to_join_by_line_return() {
  97. FileSourceDto underTest = new FileSourceDto();
  98. int expected = 1 + new Random().nextInt(96);
  99. List<String> lineHashes = IntStream.range(0, expected).mapToObj(String::valueOf).collect(Collectors.toList());
  100. underTest.setLineHashes(lineHashes);
  101. assertThat(underTest.getLineCount()).isEqualTo(expected);
  102. assertThat(underTest.getRawLineHashes()).isEqualTo(Joiner.on('\n').join(lineHashes));
  103. }
  104. }