Mercurial > hg > orthanc
comparison UnitTestsSources/UnitTestsMain.cpp @ 726:edffcf3ce7ab
sonar
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Wed, 19 Feb 2014 12:39:17 +0100 |
parents | UnitTestsSources/main.cpp@0da078f3affc |
children | 52b5316a2517 |
comparison
equal
deleted
inserted
replaced
725:ef4569ae7952 | 726:edffcf3ce7ab |
---|---|
1 #include "../Core/EnumerationDictionary.h" | |
2 | |
3 #include "gtest/gtest.h" | |
4 | |
5 #include <ctype.h> | |
6 | |
7 #include "../Core/Compression/ZlibCompressor.h" | |
8 #include "../Core/DicomFormat/DicomTag.h" | |
9 #include "../Core/HttpServer/HttpHandler.h" | |
10 #include "../Core/OrthancException.h" | |
11 #include "../Core/Toolbox.h" | |
12 #include "../Core/Uuid.h" | |
13 #include "../OrthancServer/FromDcmtkBridge.h" | |
14 #include "../OrthancServer/OrthancInitialization.h" | |
15 | |
16 using namespace Orthanc; | |
17 | |
18 | |
19 TEST(Uuid, Generation) | |
20 { | |
21 for (int i = 0; i < 10; i++) | |
22 { | |
23 std::string s = Toolbox::GenerateUuid(); | |
24 ASSERT_TRUE(Toolbox::IsUuid(s)); | |
25 } | |
26 } | |
27 | |
28 TEST(Uuid, Test) | |
29 { | |
30 ASSERT_FALSE(Toolbox::IsUuid("")); | |
31 ASSERT_FALSE(Toolbox::IsUuid("012345678901234567890123456789012345")); | |
32 ASSERT_TRUE(Toolbox::IsUuid("550e8400-e29b-41d4-a716-446655440000")); | |
33 ASSERT_FALSE(Toolbox::IsUuid("550e8400-e29b-41d4-a716-44665544000_")); | |
34 ASSERT_FALSE(Toolbox::IsUuid("01234567890123456789012345678901234_")); | |
35 ASSERT_FALSE(Toolbox::StartsWithUuid("550e8400-e29b-41d4-a716-44665544000")); | |
36 ASSERT_TRUE(Toolbox::StartsWithUuid("550e8400-e29b-41d4-a716-446655440000")); | |
37 ASSERT_TRUE(Toolbox::StartsWithUuid("550e8400-e29b-41d4-a716-446655440000 ok")); | |
38 ASSERT_FALSE(Toolbox::StartsWithUuid("550e8400-e29b-41d4-a716-446655440000ok")); | |
39 } | |
40 | |
41 TEST(Toolbox, IsSHA1) | |
42 { | |
43 ASSERT_FALSE(Toolbox::IsSHA1("")); | |
44 ASSERT_FALSE(Toolbox::IsSHA1("01234567890123456789012345678901234567890123")); | |
45 ASSERT_FALSE(Toolbox::IsSHA1("012345678901234567890123456789012345678901234")); | |
46 ASSERT_TRUE(Toolbox::IsSHA1("b5ed549f-956400ce-69a8c063-bf5b78be-2732a4b9")); | |
47 | |
48 std::string s; | |
49 Toolbox::ComputeSHA1(s, "The quick brown fox jumps over the lazy dog"); | |
50 ASSERT_TRUE(Toolbox::IsSHA1(s)); | |
51 ASSERT_EQ("2fd4e1c6-7a2d28fc-ed849ee1-bb76e739-1b93eb12", s); | |
52 | |
53 ASSERT_FALSE(Toolbox::IsSHA1("b5ed549f-956400ce-69a8c063-bf5b78be-2732a4b_")); | |
54 } | |
55 | |
56 static void StringToVector(std::vector<uint8_t>& v, | |
57 const std::string& s) | |
58 { | |
59 v.resize(s.size()); | |
60 for (size_t i = 0; i < s.size(); i++) | |
61 v[i] = s[i]; | |
62 } | |
63 | |
64 | |
65 TEST(Zlib, Basic) | |
66 { | |
67 std::string s = Toolbox::GenerateUuid(); | |
68 s = s + s + s + s; | |
69 | |
70 std::string compressed, compressed2; | |
71 ZlibCompressor c; | |
72 c.Compress(compressed, s); | |
73 | |
74 std::vector<uint8_t> v, vv; | |
75 StringToVector(v, s); | |
76 c.Compress(compressed2, v); | |
77 ASSERT_EQ(compressed, compressed2); | |
78 | |
79 std::string uncompressed; | |
80 c.Uncompress(uncompressed, compressed); | |
81 ASSERT_EQ(s.size(), uncompressed.size()); | |
82 ASSERT_EQ(0, memcmp(&s[0], &uncompressed[0], s.size())); | |
83 | |
84 StringToVector(vv, compressed); | |
85 c.Uncompress(uncompressed, vv); | |
86 ASSERT_EQ(s.size(), uncompressed.size()); | |
87 ASSERT_EQ(0, memcmp(&s[0], &uncompressed[0], s.size())); | |
88 } | |
89 | |
90 | |
91 TEST(Zlib, Level) | |
92 { | |
93 std::string s = Toolbox::GenerateUuid(); | |
94 s = s + s + s + s; | |
95 | |
96 std::string compressed, compressed2; | |
97 ZlibCompressor c; | |
98 c.SetCompressionLevel(9); | |
99 c.Compress(compressed, s); | |
100 | |
101 c.SetCompressionLevel(0); | |
102 c.Compress(compressed2, s); | |
103 | |
104 ASSERT_TRUE(compressed.size() < compressed2.size()); | |
105 } | |
106 | |
107 | |
108 TEST(Zlib, Corrupted) | |
109 { | |
110 std::string s = Toolbox::GenerateUuid(); | |
111 s = s + s + s + s; | |
112 | |
113 std::string compressed; | |
114 ZlibCompressor c; | |
115 c.Compress(compressed, s); | |
116 | |
117 compressed[compressed.size() - 1] = 'a'; | |
118 std::string u; | |
119 | |
120 ASSERT_THROW(c.Uncompress(u, compressed), OrthancException); | |
121 } | |
122 | |
123 | |
124 TEST(Zlib, Empty) | |
125 { | |
126 std::string s = ""; | |
127 std::vector<uint8_t> v, vv; | |
128 | |
129 std::string compressed, compressed2; | |
130 ZlibCompressor c; | |
131 c.Compress(compressed, s); | |
132 c.Compress(compressed2, v); | |
133 ASSERT_EQ(compressed, compressed2); | |
134 | |
135 std::string uncompressed; | |
136 c.Uncompress(uncompressed, compressed); | |
137 ASSERT_EQ(0u, uncompressed.size()); | |
138 | |
139 StringToVector(vv, compressed); | |
140 c.Uncompress(uncompressed, vv); | |
141 ASSERT_EQ(0u, uncompressed.size()); | |
142 } | |
143 | |
144 | |
145 TEST(ParseGetQuery, Basic) | |
146 { | |
147 HttpHandler::Arguments a; | |
148 HttpHandler::ParseGetQuery(a, "aaa=baaa&bb=a&aa=c"); | |
149 ASSERT_EQ(3u, a.size()); | |
150 ASSERT_EQ(a["aaa"], "baaa"); | |
151 ASSERT_EQ(a["bb"], "a"); | |
152 ASSERT_EQ(a["aa"], "c"); | |
153 } | |
154 | |
155 TEST(ParseGetQuery, BasicEmpty) | |
156 { | |
157 HttpHandler::Arguments a; | |
158 HttpHandler::ParseGetQuery(a, "aaa&bb=aa&aa"); | |
159 ASSERT_EQ(3u, a.size()); | |
160 ASSERT_EQ(a["aaa"], ""); | |
161 ASSERT_EQ(a["bb"], "aa"); | |
162 ASSERT_EQ(a["aa"], ""); | |
163 } | |
164 | |
165 TEST(ParseGetQuery, Single) | |
166 { | |
167 HttpHandler::Arguments a; | |
168 HttpHandler::ParseGetQuery(a, "aaa=baaa"); | |
169 ASSERT_EQ(1u, a.size()); | |
170 ASSERT_EQ(a["aaa"], "baaa"); | |
171 } | |
172 | |
173 TEST(ParseGetQuery, SingleEmpty) | |
174 { | |
175 HttpHandler::Arguments a; | |
176 HttpHandler::ParseGetQuery(a, "aaa"); | |
177 ASSERT_EQ(1u, a.size()); | |
178 ASSERT_EQ(a["aaa"], ""); | |
179 } | |
180 | |
181 TEST(DicomFormat, Tag) | |
182 { | |
183 ASSERT_EQ("PatientName", FromDcmtkBridge::GetName(DicomTag(0x0010, 0x0010))); | |
184 | |
185 DicomTag t = FromDcmtkBridge::ParseTag("SeriesDescription"); | |
186 ASSERT_EQ(0x0008, t.GetGroup()); | |
187 ASSERT_EQ(0x103E, t.GetElement()); | |
188 | |
189 t = FromDcmtkBridge::ParseTag("0020-e040"); | |
190 ASSERT_EQ(0x0020, t.GetGroup()); | |
191 ASSERT_EQ(0xe040, t.GetElement()); | |
192 | |
193 // Test ==() and !=() operators | |
194 ASSERT_TRUE(DICOM_TAG_PATIENT_ID == DicomTag(0x0010, 0x0020)); | |
195 ASSERT_FALSE(DICOM_TAG_PATIENT_ID != DicomTag(0x0010, 0x0020)); | |
196 } | |
197 | |
198 | |
199 TEST(Uri, SplitUriComponents) | |
200 { | |
201 UriComponents c; | |
202 Toolbox::SplitUriComponents(c, "/cou/hello/world"); | |
203 ASSERT_EQ(3u, c.size()); | |
204 ASSERT_EQ("cou", c[0]); | |
205 ASSERT_EQ("hello", c[1]); | |
206 ASSERT_EQ("world", c[2]); | |
207 | |
208 Toolbox::SplitUriComponents(c, "/cou/hello/world/"); | |
209 ASSERT_EQ(3u, c.size()); | |
210 ASSERT_EQ("cou", c[0]); | |
211 ASSERT_EQ("hello", c[1]); | |
212 ASSERT_EQ("world", c[2]); | |
213 | |
214 Toolbox::SplitUriComponents(c, "/cou/hello/world/a"); | |
215 ASSERT_EQ(4u, c.size()); | |
216 ASSERT_EQ("cou", c[0]); | |
217 ASSERT_EQ("hello", c[1]); | |
218 ASSERT_EQ("world", c[2]); | |
219 ASSERT_EQ("a", c[3]); | |
220 | |
221 Toolbox::SplitUriComponents(c, "/"); | |
222 ASSERT_EQ(0u, c.size()); | |
223 | |
224 Toolbox::SplitUriComponents(c, "/hello"); | |
225 ASSERT_EQ(1u, c.size()); | |
226 ASSERT_EQ("hello", c[0]); | |
227 | |
228 Toolbox::SplitUriComponents(c, "/hello/"); | |
229 ASSERT_EQ(1u, c.size()); | |
230 ASSERT_EQ("hello", c[0]); | |
231 | |
232 ASSERT_THROW(Toolbox::SplitUriComponents(c, ""), OrthancException); | |
233 ASSERT_THROW(Toolbox::SplitUriComponents(c, "a"), OrthancException); | |
234 ASSERT_THROW(Toolbox::SplitUriComponents(c, "/coucou//coucou"), OrthancException); | |
235 | |
236 c.clear(); | |
237 c.push_back("test"); | |
238 ASSERT_EQ("/", Toolbox::FlattenUri(c, 10)); | |
239 } | |
240 | |
241 | |
242 TEST(Uri, Child) | |
243 { | |
244 UriComponents c1; Toolbox::SplitUriComponents(c1, "/hello/world"); | |
245 UriComponents c2; Toolbox::SplitUriComponents(c2, "/hello/hello"); | |
246 UriComponents c3; Toolbox::SplitUriComponents(c3, "/hello"); | |
247 UriComponents c4; Toolbox::SplitUriComponents(c4, "/world"); | |
248 UriComponents c5; Toolbox::SplitUriComponents(c5, "/"); | |
249 | |
250 ASSERT_TRUE(Toolbox::IsChildUri(c1, c1)); | |
251 ASSERT_FALSE(Toolbox::IsChildUri(c1, c2)); | |
252 ASSERT_FALSE(Toolbox::IsChildUri(c1, c3)); | |
253 ASSERT_FALSE(Toolbox::IsChildUri(c1, c4)); | |
254 ASSERT_FALSE(Toolbox::IsChildUri(c1, c5)); | |
255 | |
256 ASSERT_FALSE(Toolbox::IsChildUri(c2, c1)); | |
257 ASSERT_TRUE(Toolbox::IsChildUri(c2, c2)); | |
258 ASSERT_FALSE(Toolbox::IsChildUri(c2, c3)); | |
259 ASSERT_FALSE(Toolbox::IsChildUri(c2, c4)); | |
260 ASSERT_FALSE(Toolbox::IsChildUri(c2, c5)); | |
261 | |
262 ASSERT_TRUE(Toolbox::IsChildUri(c3, c1)); | |
263 ASSERT_TRUE(Toolbox::IsChildUri(c3, c2)); | |
264 ASSERT_TRUE(Toolbox::IsChildUri(c3, c3)); | |
265 ASSERT_FALSE(Toolbox::IsChildUri(c3, c4)); | |
266 ASSERT_FALSE(Toolbox::IsChildUri(c3, c5)); | |
267 | |
268 ASSERT_FALSE(Toolbox::IsChildUri(c4, c1)); | |
269 ASSERT_FALSE(Toolbox::IsChildUri(c4, c2)); | |
270 ASSERT_FALSE(Toolbox::IsChildUri(c4, c3)); | |
271 ASSERT_TRUE(Toolbox::IsChildUri(c4, c4)); | |
272 ASSERT_FALSE(Toolbox::IsChildUri(c4, c5)); | |
273 | |
274 ASSERT_TRUE(Toolbox::IsChildUri(c5, c1)); | |
275 ASSERT_TRUE(Toolbox::IsChildUri(c5, c2)); | |
276 ASSERT_TRUE(Toolbox::IsChildUri(c5, c3)); | |
277 ASSERT_TRUE(Toolbox::IsChildUri(c5, c4)); | |
278 ASSERT_TRUE(Toolbox::IsChildUri(c5, c5)); | |
279 } | |
280 | |
281 TEST(Uri, AutodetectMimeType) | |
282 { | |
283 ASSERT_EQ("", Toolbox::AutodetectMimeType("../NOTES")); | |
284 ASSERT_EQ("", Toolbox::AutodetectMimeType("")); | |
285 ASSERT_EQ("", Toolbox::AutodetectMimeType("/")); | |
286 ASSERT_EQ("", Toolbox::AutodetectMimeType("a/a")); | |
287 | |
288 ASSERT_EQ("text/plain", Toolbox::AutodetectMimeType("../NOTES.txt")); | |
289 ASSERT_EQ("text/plain", Toolbox::AutodetectMimeType("../coucou.xml/NOTES.txt")); | |
290 ASSERT_EQ("text/xml", Toolbox::AutodetectMimeType("../.xml")); | |
291 | |
292 ASSERT_EQ("application/javascript", Toolbox::AutodetectMimeType("NOTES.js")); | |
293 ASSERT_EQ("application/json", Toolbox::AutodetectMimeType("NOTES.json")); | |
294 ASSERT_EQ("application/pdf", Toolbox::AutodetectMimeType("NOTES.pdf")); | |
295 ASSERT_EQ("text/css", Toolbox::AutodetectMimeType("NOTES.css")); | |
296 ASSERT_EQ("text/html", Toolbox::AutodetectMimeType("NOTES.html")); | |
297 ASSERT_EQ("text/plain", Toolbox::AutodetectMimeType("NOTES.txt")); | |
298 ASSERT_EQ("text/xml", Toolbox::AutodetectMimeType("NOTES.xml")); | |
299 ASSERT_EQ("image/gif", Toolbox::AutodetectMimeType("NOTES.gif")); | |
300 ASSERT_EQ("image/jpeg", Toolbox::AutodetectMimeType("NOTES.jpg")); | |
301 ASSERT_EQ("image/jpeg", Toolbox::AutodetectMimeType("NOTES.jpeg")); | |
302 ASSERT_EQ("image/png", Toolbox::AutodetectMimeType("NOTES.png")); | |
303 } | |
304 | |
305 TEST(Toolbox, ComputeMD5) | |
306 { | |
307 std::string s; | |
308 | |
309 // # echo -n "Hello" | md5sum | |
310 | |
311 Toolbox::ComputeMD5(s, "Hello"); | |
312 ASSERT_EQ("8b1a9953c4611296a827abf8c47804d7", s); | |
313 Toolbox::ComputeMD5(s, ""); | |
314 ASSERT_EQ("d41d8cd98f00b204e9800998ecf8427e", s); | |
315 } | |
316 | |
317 TEST(Toolbox, ComputeSHA1) | |
318 { | |
319 std::string s; | |
320 | |
321 Toolbox::ComputeSHA1(s, "The quick brown fox jumps over the lazy dog"); | |
322 ASSERT_EQ("2fd4e1c6-7a2d28fc-ed849ee1-bb76e739-1b93eb12", s); | |
323 Toolbox::ComputeSHA1(s, ""); | |
324 ASSERT_EQ("da39a3ee-5e6b4b0d-3255bfef-95601890-afd80709", s); | |
325 } | |
326 | |
327 | |
328 TEST(Toolbox, Base64) | |
329 { | |
330 ASSERT_EQ("", Toolbox::EncodeBase64("")); | |
331 ASSERT_EQ("YQ==", Toolbox::EncodeBase64("a")); | |
332 | |
333 const std::string hello = "SGVsbG8gd29ybGQ="; | |
334 ASSERT_EQ(hello, Toolbox::EncodeBase64("Hello world")); | |
335 ASSERT_EQ("Hello world", Toolbox::DecodeBase64(hello)); | |
336 } | |
337 | |
338 TEST(Toolbox, PathToExecutable) | |
339 { | |
340 printf("[%s]\n", Toolbox::GetPathToExecutable().c_str()); | |
341 printf("[%s]\n", Toolbox::GetDirectoryOfExecutable().c_str()); | |
342 } | |
343 | |
344 TEST(Toolbox, StripSpaces) | |
345 { | |
346 ASSERT_EQ("", Toolbox::StripSpaces(" \t \r \n ")); | |
347 ASSERT_EQ("coucou", Toolbox::StripSpaces(" coucou \t \r \n ")); | |
348 ASSERT_EQ("cou cou", Toolbox::StripSpaces(" cou cou \n ")); | |
349 ASSERT_EQ("c", Toolbox::StripSpaces(" \n\t c\r \n ")); | |
350 } | |
351 | |
352 TEST(Toolbox, Case) | |
353 { | |
354 std::string s = "CoU"; | |
355 std::string ss; | |
356 | |
357 Toolbox::ToUpperCase(ss, s); | |
358 ASSERT_EQ("COU", ss); | |
359 Toolbox::ToLowerCase(ss, s); | |
360 ASSERT_EQ("cou", ss); | |
361 | |
362 s = "CoU"; | |
363 Toolbox::ToUpperCase(s); | |
364 ASSERT_EQ("COU", s); | |
365 | |
366 s = "CoU"; | |
367 Toolbox::ToLowerCase(s); | |
368 ASSERT_EQ("cou", s); | |
369 } | |
370 | |
371 | |
372 #include <glog/logging.h> | |
373 | |
374 TEST(Logger, Basic) | |
375 { | |
376 LOG(INFO) << "I say hello"; | |
377 } | |
378 | |
379 TEST(Toolbox, ConvertFromLatin1) | |
380 { | |
381 // This is a Latin-1 test string | |
382 const unsigned char data[10] = { 0xe0, 0xe9, 0xea, 0xe7, 0x26, 0xc6, 0x61, 0x62, 0x63, 0x00 }; | |
383 | |
384 /*FILE* f = fopen("/tmp/tutu", "w"); | |
385 fwrite(&data[0], 9, 1, f); | |
386 fclose(f);*/ | |
387 | |
388 std::string s((char*) &data[0], 10); | |
389 ASSERT_EQ("&abc", Toolbox::ConvertToAscii(s)); | |
390 | |
391 // Open in Emacs, then save with UTF-8 encoding, then "hexdump -C" | |
392 std::string utf8 = Toolbox::ConvertToUtf8(s, "ISO-8859-1"); | |
393 ASSERT_EQ(15u, utf8.size()); | |
394 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[0])); | |
395 ASSERT_EQ(0xa0, static_cast<unsigned char>(utf8[1])); | |
396 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[2])); | |
397 ASSERT_EQ(0xa9, static_cast<unsigned char>(utf8[3])); | |
398 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[4])); | |
399 ASSERT_EQ(0xaa, static_cast<unsigned char>(utf8[5])); | |
400 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[6])); | |
401 ASSERT_EQ(0xa7, static_cast<unsigned char>(utf8[7])); | |
402 ASSERT_EQ(0x26, static_cast<unsigned char>(utf8[8])); | |
403 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[9])); | |
404 ASSERT_EQ(0x86, static_cast<unsigned char>(utf8[10])); | |
405 ASSERT_EQ(0x61, static_cast<unsigned char>(utf8[11])); | |
406 ASSERT_EQ(0x62, static_cast<unsigned char>(utf8[12])); | |
407 ASSERT_EQ(0x63, static_cast<unsigned char>(utf8[13])); | |
408 ASSERT_EQ(0x00, static_cast<unsigned char>(utf8[14])); // Null-terminated string | |
409 } | |
410 | |
411 TEST(Toolbox, UrlDecode) | |
412 { | |
413 std::string s; | |
414 | |
415 s = "Hello%20World"; | |
416 Toolbox::UrlDecode(s); | |
417 ASSERT_EQ("Hello World", s); | |
418 | |
419 s = "%21%23%24%26%27%28%29%2A%2B%2c%2f%3A%3b%3d%3f%40%5B%5D%90%ff"; | |
420 Toolbox::UrlDecode(s); | |
421 std::string ss = "!#$&'()*+,/:;=?@[]"; | |
422 ss.push_back((char) 144); | |
423 ss.push_back((char) 255); | |
424 ASSERT_EQ(ss, s); | |
425 | |
426 s = "(2000%2C00A4)+Other"; | |
427 Toolbox::UrlDecode(s); | |
428 ASSERT_EQ("(2000,00A4) Other", s); | |
429 } | |
430 | |
431 | |
432 #if defined(__linux) | |
433 TEST(OrthancInitialization, AbsoluteDirectory) | |
434 { | |
435 ASSERT_EQ("/tmp/hello", InterpretRelativePath("/tmp", "hello")); | |
436 ASSERT_EQ("/tmp", InterpretRelativePath("/tmp", "/tmp")); | |
437 } | |
438 #endif | |
439 | |
440 | |
441 | |
442 #include "../OrthancServer/ServerEnumerations.h" | |
443 | |
444 TEST(EnumerationDictionary, Simple) | |
445 { | |
446 Toolbox::EnumerationDictionary<MetadataType> d; | |
447 | |
448 ASSERT_THROW(d.Translate("ReceptionDate"), OrthancException); | |
449 ASSERT_EQ(MetadataType_ModifiedFrom, d.Translate("5")); | |
450 ASSERT_EQ(256, d.Translate("256")); | |
451 | |
452 d.Add(MetadataType_Instance_ReceptionDate, "ReceptionDate"); | |
453 | |
454 ASSERT_EQ(MetadataType_Instance_ReceptionDate, d.Translate("ReceptionDate")); | |
455 ASSERT_EQ(MetadataType_Instance_ReceptionDate, d.Translate("2")); | |
456 ASSERT_EQ("ReceptionDate", d.Translate(MetadataType_Instance_ReceptionDate)); | |
457 | |
458 ASSERT_THROW(d.Add(MetadataType_Instance_ReceptionDate, "Hello"), OrthancException); | |
459 ASSERT_THROW(d.Add(MetadataType_ModifiedFrom, "ReceptionDate"), OrthancException); // already used | |
460 ASSERT_THROW(d.Add(MetadataType_ModifiedFrom, "1024"), OrthancException); // cannot register numbers | |
461 d.Add(MetadataType_ModifiedFrom, "ModifiedFrom"); // ok | |
462 } | |
463 | |
464 | |
465 TEST(EnumerationDictionary, ServerEnumerations) | |
466 { | |
467 ASSERT_STREQ("Patient", EnumerationToString(ResourceType_Patient)); | |
468 ASSERT_STREQ("Study", EnumerationToString(ResourceType_Study)); | |
469 ASSERT_STREQ("Series", EnumerationToString(ResourceType_Series)); | |
470 ASSERT_STREQ("Instance", EnumerationToString(ResourceType_Instance)); | |
471 | |
472 ASSERT_STREQ("ModifiedSeries", EnumerationToString(ChangeType_ModifiedSeries)); | |
473 | |
474 ASSERT_STREQ("Failure", EnumerationToString(StoreStatus_Failure)); | |
475 ASSERT_STREQ("Success", EnumerationToString(StoreStatus_Success)); | |
476 | |
477 ASSERT_STREQ("CompletedSeries", EnumerationToString(ChangeType_CompletedSeries)); | |
478 | |
479 ASSERT_EQ("IndexInSeries", EnumerationToString(MetadataType_Instance_IndexInSeries)); | |
480 ASSERT_EQ("LastUpdate", EnumerationToString(MetadataType_LastUpdate)); | |
481 | |
482 ASSERT_EQ(ResourceType_Patient, StringToResourceType("PATienT")); | |
483 ASSERT_EQ(ResourceType_Study, StringToResourceType("STudy")); | |
484 ASSERT_EQ(ResourceType_Series, StringToResourceType("SeRiEs")); | |
485 ASSERT_EQ(ResourceType_Instance, StringToResourceType("INStance")); | |
486 ASSERT_EQ(ResourceType_Instance, StringToResourceType("IMagE")); | |
487 ASSERT_THROW(StringToResourceType("heLLo"), OrthancException); | |
488 | |
489 ASSERT_EQ(2047, StringToMetadata("2047")); | |
490 ASSERT_THROW(StringToMetadata("Ceci est un test"), OrthancException); | |
491 ASSERT_THROW(RegisterUserMetadata(128, ""), OrthancException); // too low (< 1024) | |
492 ASSERT_THROW(RegisterUserMetadata(128000, ""), OrthancException); // too high (> 65535) | |
493 RegisterUserMetadata(2047, "Ceci est un test"); | |
494 ASSERT_EQ(2047, StringToMetadata("2047")); | |
495 ASSERT_EQ(2047, StringToMetadata("Ceci est un test")); | |
496 } | |
497 | |
498 | |
499 | |
500 TEST(Toolbox, WriteFile) | |
501 { | |
502 std::string path; | |
503 | |
504 { | |
505 Toolbox::TemporaryFile tmp; | |
506 path = tmp.GetPath(); | |
507 | |
508 std::string s; | |
509 s.append("Hello"); | |
510 s.push_back('\0'); | |
511 s.append("World"); | |
512 ASSERT_EQ(11u, s.size()); | |
513 | |
514 Toolbox::WriteFile(s, path.c_str()); | |
515 | |
516 std::string t; | |
517 Toolbox::ReadFile(t, path.c_str()); | |
518 | |
519 ASSERT_EQ(11u, t.size()); | |
520 ASSERT_EQ(0, t[5]); | |
521 ASSERT_EQ(0, memcmp(s.c_str(), t.c_str(), s.size())); | |
522 } | |
523 | |
524 std::string u; | |
525 ASSERT_THROW(Toolbox::ReadFile(u, path.c_str()), OrthancException); | |
526 } | |
527 | |
528 | |
529 TEST(Toolbox, Wildcard) | |
530 { | |
531 ASSERT_EQ("abcd", Toolbox::WildcardToRegularExpression("abcd")); | |
532 ASSERT_EQ("ab.*cd", Toolbox::WildcardToRegularExpression("ab*cd")); | |
533 ASSERT_EQ("ab..cd", Toolbox::WildcardToRegularExpression("ab??cd")); | |
534 ASSERT_EQ("a.*b.c.*d", Toolbox::WildcardToRegularExpression("a*b?c*d")); | |
535 ASSERT_EQ("a\\{b\\]", Toolbox::WildcardToRegularExpression("a{b]")); | |
536 } | |
537 | |
538 | |
539 TEST(Toolbox, Tokenize) | |
540 { | |
541 std::vector<std::string> t; | |
542 | |
543 Toolbox::TokenizeString(t, "", ','); | |
544 ASSERT_EQ(1, t.size()); | |
545 ASSERT_EQ("", t[0]); | |
546 | |
547 Toolbox::TokenizeString(t, "abc", ','); | |
548 ASSERT_EQ(1, t.size()); | |
549 ASSERT_EQ("abc", t[0]); | |
550 | |
551 Toolbox::TokenizeString(t, "ab,cd,ef,", ','); | |
552 ASSERT_EQ(4, t.size()); | |
553 ASSERT_EQ("ab", t[0]); | |
554 ASSERT_EQ("cd", t[1]); | |
555 ASSERT_EQ("ef", t[2]); | |
556 ASSERT_EQ("", t[3]); | |
557 } | |
558 | |
559 | |
560 | |
561 #if defined(__linux) | |
562 #include <endian.h> | |
563 #endif | |
564 | |
565 TEST(Toolbox, Endianness) | |
566 { | |
567 // Parts of this test come from Adam Conrad | |
568 // http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=728822#5 | |
569 | |
570 #if defined(_WIN32) | |
571 ASSERT_EQ(Endianness_Little, Toolbox::DetectEndianness()); | |
572 | |
573 #elif defined(__linux) | |
574 | |
575 #if !defined(__BYTE_ORDER) | |
576 # error Support your platform here | |
577 #endif | |
578 | |
579 # if __BYTE_ORDER == __BIG_ENDIAN | |
580 ASSERT_EQ(Endianness_Big, Toolbox::DetectEndianness()); | |
581 # else // __LITTLE_ENDIAN | |
582 ASSERT_EQ(Endianness_Little, Toolbox::DetectEndianness()); | |
583 # endif | |
584 | |
585 #else | |
586 #error Support your platform here | |
587 #endif | |
588 } | |
589 | |
590 | |
591 | |
592 int main(int argc, char **argv) | |
593 { | |
594 // Initialize Google's logging library. | |
595 FLAGS_logtostderr = true; | |
596 FLAGS_minloglevel = 0; | |
597 | |
598 // Go to trace-level verbosity | |
599 //FLAGS_v = 1; | |
600 | |
601 Toolbox::DetectEndianness(); | |
602 | |
603 google::InitGoogleLogging("Orthanc"); | |
604 | |
605 OrthancInitialize(); | |
606 ::testing::InitGoogleTest(&argc, argv); | |
607 int result = RUN_ALL_TESTS(); | |
608 OrthancFinalize(); | |
609 return result; | |
610 } |