77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
1 //===- SpecialCaseListTest.cpp - Unit tests for SpecialCaseList -----------===//
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
2 //
|
147
|
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
4 // See https://llvm.org/LICENSE.txt for license information.
|
|
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
6 //
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
7 //===----------------------------------------------------------------------===//
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
8
|
121
|
9 #include "llvm/Support/SpecialCaseList.h"
|
83
|
10 #include "llvm/Support/FileSystem.h"
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
11 #include "llvm/Support/MemoryBuffer.h"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
12 #include "gtest/gtest.h"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
13
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
14 using namespace llvm;
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
15
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
16 namespace {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
17
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
18 class SpecialCaseListTest : public ::testing::Test {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
19 protected:
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
20 std::unique_ptr<SpecialCaseList> makeSpecialCaseList(StringRef List,
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
21 std::string &Error) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
22 std::unique_ptr<MemoryBuffer> MB = MemoryBuffer::getMemBuffer(List);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
23 return SpecialCaseList::create(MB.get(), Error);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
24 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
25
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
26 std::unique_ptr<SpecialCaseList> makeSpecialCaseList(StringRef List) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
27 std::string Error;
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
28 auto SCL = makeSpecialCaseList(List, Error);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
29 assert(SCL);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
30 assert(Error == "");
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
31 return SCL;
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
32 }
|
83
|
33
|
|
34 std::string makeSpecialCaseListFile(StringRef Contents) {
|
|
35 int FD;
|
|
36 SmallString<64> Path;
|
|
37 sys::fs::createTemporaryFile("SpecialCaseListTest", "temp", FD, Path);
|
|
38 raw_fd_ostream OF(FD, true, true);
|
|
39 OF << Contents;
|
|
40 OF.close();
|
|
41 return Path.str();
|
|
42 }
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
43 };
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
44
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
45 TEST_F(SpecialCaseListTest, Basic) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
46 std::unique_ptr<SpecialCaseList> SCL =
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
47 makeSpecialCaseList("# This is a comment.\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
48 "\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
49 "src:hello\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
50 "src:bye\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
51 "src:hi=category\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
52 "src:z*=category\n");
|
121
|
53 EXPECT_TRUE(SCL->inSection("", "src", "hello"));
|
|
54 EXPECT_TRUE(SCL->inSection("", "src", "bye"));
|
|
55 EXPECT_TRUE(SCL->inSection("", "src", "hi", "category"));
|
|
56 EXPECT_TRUE(SCL->inSection("", "src", "zzzz", "category"));
|
|
57 EXPECT_FALSE(SCL->inSection("", "src", "hi"));
|
|
58 EXPECT_FALSE(SCL->inSection("", "fun", "hello"));
|
|
59 EXPECT_FALSE(SCL->inSection("", "src", "hello", "category"));
|
134
|
60
|
|
61 EXPECT_EQ(3u, SCL->inSectionBlame("", "src", "hello"));
|
|
62 EXPECT_EQ(4u, SCL->inSectionBlame("", "src", "bye"));
|
|
63 EXPECT_EQ(5u, SCL->inSectionBlame("", "src", "hi", "category"));
|
|
64 EXPECT_EQ(6u, SCL->inSectionBlame("", "src", "zzzz", "category"));
|
|
65 EXPECT_EQ(0u, SCL->inSectionBlame("", "src", "hi"));
|
|
66 EXPECT_EQ(0u, SCL->inSectionBlame("", "fun", "hello"));
|
|
67 EXPECT_EQ(0u, SCL->inSectionBlame("", "src", "hello", "category"));
|
|
68 }
|
|
69
|
|
70 TEST_F(SpecialCaseListTest, CorrectErrorLineNumberWithBlankLine) {
|
|
71 std::string Error;
|
|
72 EXPECT_EQ(nullptr, makeSpecialCaseList("# This is a comment.\n"
|
|
73 "\n"
|
|
74 "[not valid\n",
|
|
75 Error));
|
|
76 EXPECT_TRUE(
|
|
77 ((StringRef)Error).startswith("malformed section header on line 3:"));
|
|
78
|
|
79 EXPECT_EQ(nullptr, makeSpecialCaseList("\n\n\n"
|
|
80 "[not valid\n",
|
|
81 Error));
|
|
82 EXPECT_TRUE(
|
|
83 ((StringRef)Error).startswith("malformed section header on line 4:"));
|
121
|
84 }
|
|
85
|
|
86 TEST_F(SpecialCaseListTest, SectionRegexErrorHandling) {
|
|
87 std::string Error;
|
|
88 EXPECT_EQ(makeSpecialCaseList("[address", Error), nullptr);
|
|
89 EXPECT_TRUE(((StringRef)Error).startswith("malformed section header "));
|
|
90
|
|
91 EXPECT_EQ(makeSpecialCaseList("[[]", Error), nullptr);
|
|
92 EXPECT_TRUE(((StringRef)Error).startswith("malformed regex for section [: "));
|
|
93
|
|
94 EXPECT_EQ(makeSpecialCaseList("src:=", Error), nullptr);
|
|
95 EXPECT_TRUE(((StringRef)Error).endswith("Supplied regexp was blank"));
|
|
96 }
|
|
97
|
|
98 TEST_F(SpecialCaseListTest, Section) {
|
|
99 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("src:global\n"
|
|
100 "[sect1|sect2]\n"
|
|
101 "src:test1\n"
|
|
102 "[sect3*]\n"
|
|
103 "src:test2\n");
|
|
104 EXPECT_TRUE(SCL->inSection("arbitrary", "src", "global"));
|
|
105 EXPECT_TRUE(SCL->inSection("", "src", "global"));
|
|
106 EXPECT_TRUE(SCL->inSection("sect1", "src", "test1"));
|
|
107 EXPECT_FALSE(SCL->inSection("sect1-arbitrary", "src", "test1"));
|
|
108 EXPECT_FALSE(SCL->inSection("sect", "src", "test1"));
|
|
109 EXPECT_FALSE(SCL->inSection("sect1", "src", "test2"));
|
|
110 EXPECT_TRUE(SCL->inSection("sect2", "src", "test1"));
|
|
111 EXPECT_TRUE(SCL->inSection("sect3", "src", "test2"));
|
|
112 EXPECT_TRUE(SCL->inSection("sect3-arbitrary", "src", "test2"));
|
|
113 EXPECT_FALSE(SCL->inSection("", "src", "test1"));
|
|
114 EXPECT_FALSE(SCL->inSection("", "src", "test2"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
115 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
116
|
83
|
117 TEST_F(SpecialCaseListTest, GlobalInit) {
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
118 std::unique_ptr<SpecialCaseList> SCL =
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
119 makeSpecialCaseList("global:foo=init\n");
|
121
|
120 EXPECT_FALSE(SCL->inSection("", "global", "foo"));
|
|
121 EXPECT_FALSE(SCL->inSection("", "global", "bar"));
|
|
122 EXPECT_TRUE(SCL->inSection("", "global", "foo", "init"));
|
|
123 EXPECT_FALSE(SCL->inSection("", "global", "bar", "init"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
124
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
125 SCL = makeSpecialCaseList("type:t2=init\n");
|
121
|
126 EXPECT_FALSE(SCL->inSection("", "type", "t1"));
|
|
127 EXPECT_FALSE(SCL->inSection("", "type", "t2"));
|
|
128 EXPECT_FALSE(SCL->inSection("", "type", "t1", "init"));
|
|
129 EXPECT_TRUE(SCL->inSection("", "type", "t2", "init"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
130
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
131 SCL = makeSpecialCaseList("src:hello=init\n");
|
121
|
132 EXPECT_FALSE(SCL->inSection("", "src", "hello"));
|
|
133 EXPECT_FALSE(SCL->inSection("", "src", "bye"));
|
|
134 EXPECT_TRUE(SCL->inSection("", "src", "hello", "init"));
|
|
135 EXPECT_FALSE(SCL->inSection("", "src", "bye", "init"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
136 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
137
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
138 TEST_F(SpecialCaseListTest, Substring) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
139 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("src:hello\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
140 "fun:foo\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
141 "global:bar\n");
|
121
|
142 EXPECT_FALSE(SCL->inSection("", "src", "othello"));
|
|
143 EXPECT_FALSE(SCL->inSection("", "fun", "tomfoolery"));
|
|
144 EXPECT_FALSE(SCL->inSection("", "global", "bartender"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
145
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
146 SCL = makeSpecialCaseList("fun:*foo*\n");
|
121
|
147 EXPECT_TRUE(SCL->inSection("", "fun", "tomfoolery"));
|
|
148 EXPECT_TRUE(SCL->inSection("", "fun", "foobar"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
149 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
150
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
151 TEST_F(SpecialCaseListTest, InvalidSpecialCaseList) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
152 std::string Error;
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
153 EXPECT_EQ(nullptr, makeSpecialCaseList("badline", Error));
|
83
|
154 EXPECT_EQ("malformed line 1: 'badline'", Error);
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
155 EXPECT_EQ(nullptr, makeSpecialCaseList("src:bad[a-", Error));
|
83
|
156 EXPECT_EQ("malformed regex in line 1: 'bad[a-': invalid character range",
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
157 Error);
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
158 EXPECT_EQ(nullptr, makeSpecialCaseList("src:a.c\n"
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
159 "fun:fun(a\n",
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
160 Error));
|
83
|
161 EXPECT_EQ("malformed regex in line 2: 'fun(a': parentheses not balanced",
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
162 Error);
|
83
|
163 std::vector<std::string> Files(1, "unexisting");
|
|
164 EXPECT_EQ(nullptr, SpecialCaseList::create(Files, Error));
|
|
165 EXPECT_EQ(0U, Error.find("can't open file 'unexisting':"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
166 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
167
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
168 TEST_F(SpecialCaseListTest, EmptySpecialCaseList) {
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
169 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("");
|
121
|
170 EXPECT_FALSE(SCL->inSection("", "foo", "bar"));
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
171 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
172
|
83
|
173 TEST_F(SpecialCaseListTest, MultipleBlacklists) {
|
|
174 std::vector<std::string> Files;
|
|
175 Files.push_back(makeSpecialCaseListFile("src:bar\n"
|
|
176 "src:*foo*\n"
|
|
177 "src:ban=init\n"));
|
|
178 Files.push_back(makeSpecialCaseListFile("src:baz\n"
|
|
179 "src:*fog*\n"));
|
|
180 auto SCL = SpecialCaseList::createOrDie(Files);
|
121
|
181 EXPECT_TRUE(SCL->inSection("", "src", "bar"));
|
|
182 EXPECT_TRUE(SCL->inSection("", "src", "baz"));
|
|
183 EXPECT_FALSE(SCL->inSection("", "src", "ban"));
|
|
184 EXPECT_TRUE(SCL->inSection("", "src", "ban", "init"));
|
|
185 EXPECT_TRUE(SCL->inSection("", "src", "tomfoolery"));
|
|
186 EXPECT_TRUE(SCL->inSection("", "src", "tomfoglery"));
|
120
|
187 for (auto &Path : Files)
|
|
188 sys::fs::remove(Path);
|
77
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
189 }
|
Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
190
|
121
|
191 TEST_F(SpecialCaseListTest, NoTrigramsInRules) {
|
|
192 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("fun:b.r\n"
|
|
193 "fun:za*az\n");
|
|
194 EXPECT_TRUE(SCL->inSection("", "fun", "bar"));
|
|
195 EXPECT_FALSE(SCL->inSection("", "fun", "baz"));
|
|
196 EXPECT_TRUE(SCL->inSection("", "fun", "zakaz"));
|
|
197 EXPECT_FALSE(SCL->inSection("", "fun", "zaraza"));
|
83
|
198 }
|
121
|
199
|
|
200 TEST_F(SpecialCaseListTest, NoTrigramsInARule) {
|
|
201 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("fun:*bar*\n"
|
|
202 "fun:za*az\n");
|
|
203 EXPECT_TRUE(SCL->inSection("", "fun", "abara"));
|
|
204 EXPECT_FALSE(SCL->inSection("", "fun", "bor"));
|
|
205 EXPECT_TRUE(SCL->inSection("", "fun", "zakaz"));
|
|
206 EXPECT_FALSE(SCL->inSection("", "fun", "zaraza"));
|
|
207 }
|
|
208
|
|
209 TEST_F(SpecialCaseListTest, RepetitiveRule) {
|
|
210 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("fun:*bar*bar*bar*bar*\n"
|
|
211 "fun:bar*\n");
|
|
212 EXPECT_TRUE(SCL->inSection("", "fun", "bara"));
|
|
213 EXPECT_FALSE(SCL->inSection("", "fun", "abara"));
|
|
214 EXPECT_TRUE(SCL->inSection("", "fun", "barbarbarbar"));
|
|
215 EXPECT_TRUE(SCL->inSection("", "fun", "abarbarbarbar"));
|
|
216 EXPECT_FALSE(SCL->inSection("", "fun", "abarbarbar"));
|
|
217 }
|
|
218
|
|
219 TEST_F(SpecialCaseListTest, SpecialSymbolRule) {
|
|
220 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("src:*c\\+\\+abi*\n");
|
|
221 EXPECT_TRUE(SCL->inSection("", "src", "c++abi"));
|
|
222 EXPECT_FALSE(SCL->inSection("", "src", "c\\+\\+abi"));
|
|
223 }
|
|
224
|
|
225 TEST_F(SpecialCaseListTest, PopularTrigram) {
|
|
226 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("fun:*aaaaaa*\n"
|
|
227 "fun:*aaaaa*\n"
|
|
228 "fun:*aaaa*\n"
|
|
229 "fun:*aaa*\n");
|
|
230 EXPECT_TRUE(SCL->inSection("", "fun", "aaa"));
|
|
231 EXPECT_TRUE(SCL->inSection("", "fun", "aaaa"));
|
|
232 EXPECT_TRUE(SCL->inSection("", "fun", "aaaabbbaaa"));
|
|
233 }
|
|
234
|
|
235 TEST_F(SpecialCaseListTest, EscapedSymbols) {
|
|
236 std::unique_ptr<SpecialCaseList> SCL = makeSpecialCaseList("src:*c\\+\\+abi*\n"
|
|
237 "src:*hello\\\\world*\n");
|
|
238 EXPECT_TRUE(SCL->inSection("", "src", "dir/c++abi"));
|
|
239 EXPECT_FALSE(SCL->inSection("", "src", "dir/c\\+\\+abi"));
|
|
240 EXPECT_FALSE(SCL->inSection("", "src", "c\\+\\+abi"));
|
|
241 EXPECT_TRUE(SCL->inSection("", "src", "C:\\hello\\world"));
|
|
242 EXPECT_TRUE(SCL->inSection("", "src", "hello\\world"));
|
|
243 EXPECT_FALSE(SCL->inSection("", "src", "hello\\\\world"));
|
|
244 }
|
|
245
|
|
246 }
|