1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
/*
* SonarQube
* Copyright (C) 2009-2017 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program 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.
*
* This program 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.db.source;
import java.util.Arrays;
import java.util.List;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
import org.sonar.db.protobuf.DbFileSources;
import static org.assertj.core.api.Assertions.assertThat;
public class FileSourceDtoTest {
private static final String LOREM_IPSUM = "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam ac magna libero. " +
"Integer eu quam vulputate, interdum ante quis, sodales mauris. Nam mollis ornare dolor at maximus. Cras pharetra aliquam fringilla. " +
"Nunc hendrerit, elit eu mattis fermentum, ligula metus malesuada nunc, non fermentum augue tellus eu odio. Praesent ut vestibulum nibh. " +
"Curabitur sit amet dignissim magna, at efficitur dolor. Ut non felis aliquam justo euismod gravida. Morbi eleifend vitae ante eu pulvinar. " +
"Aliquam rhoncus magna quis lorem posuere semper.";
@Rule
public ExpectedException expectedException = ExpectedException.none();
@Test
public void encode_and_decode_test_data() {
List<DbFileSources.Test> tests = Arrays.asList(
DbFileSources.Test.newBuilder()
.setName("name#1")
.build(),
DbFileSources.Test.newBuilder()
.setName("name#2")
.build());
FileSourceDto underTest = new FileSourceDto().setTestData(tests);
assertThat(underTest.getTestData()).hasSize(2);
assertThat(underTest.getTestData().get(0).getName()).isEqualTo("name#1");
}
@Test
public void getSourceData_throws_ISE_with_id_fileUuid_and_projectUuid_in_message_when_data_cant_be_read() {
long id = 12L;
String fileUuid = "file uuid";
String projectUuid = "project uuid";
FileSourceDto underTest = new FileSourceDto()
.setBinaryData(new byte[] {1, 2, 3, 4, 5})
.setId(id)
.setFileUuid(fileUuid)
.setProjectUuid(projectUuid);
expectedException.expect(IllegalStateException.class);
expectedException.expectMessage("Fail to decompress and deserialize source data [id=" + id + ",fileUuid=" + fileUuid + ",projectUuid=" + projectUuid + "]");
underTest.getSourceData();
}
@Test
public void getSourceData_reads_Data_object_bigger_than_default_size_limit() {
DbFileSources.Data build = createOver64MBDataStructure();
byte[] bytes = FileSourceDto.encodeSourceData(build);
DbFileSources.Data data = new FileSourceDto().decodeSourceData(bytes);
assertThat(data.getLinesCount()).isEqualTo(build.getLinesCount());
}
private static DbFileSources.Data createOver64MBDataStructure() {
DbFileSources.Data.Builder dataBuilder = DbFileSources.Data.newBuilder();
DbFileSources.Line.Builder lineBuilder = DbFileSources.Line.newBuilder();
for (int i = 0; i < 199999; i++) {
dataBuilder.addLines(
lineBuilder.setSource(LOREM_IPSUM)
.setLine(i)
.build());
}
return dataBuilder.build();
}
}
|