Mercurial > hg > orthanc
annotate UnitTests/main.cpp @ 467:322c1b497036
cancel and listener for commands
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 12 Jul 2013 14:42:27 +0200 |
parents | 30086c1aca30 |
children | 4aae0261515e |
rev | line source |
---|---|
434
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
1 #include "../Core/EnumerationDictionary.h" |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
2 |
0 | 3 #include "gtest/gtest.h" |
4 | |
5 #include <ctype.h> | |
6 | |
7 #include "../Core/Compression/ZlibCompressor.h" | |
8 #include "../Core/DicomFormat/DicomTag.h" | |
63 | 9 #include "../OrthancCppClient/HttpClient.h" |
0 | 10 #include "../Core/HttpServer/HttpHandler.h" |
63 | 11 #include "../Core/OrthancException.h" |
0 | 12 #include "../Core/Toolbox.h" |
13 #include "../Core/Uuid.h" | |
63 | 14 #include "../OrthancServer/FromDcmtkBridge.h" |
15 #include "../OrthancServer/OrthancInitialization.h" | |
450 | 16 #include "../Core/MultiThreading/SharedMessageQueue.h" |
0 | 17 |
63 | 18 using namespace Orthanc; |
0 | 19 |
20 | |
21 TEST(Uuid, Generation) | |
22 { | |
23 for (int i = 0; i < 10; i++) | |
24 { | |
25 std::string s = Toolbox::GenerateUuid(); | |
26 ASSERT_TRUE(Toolbox::IsUuid(s)); | |
27 } | |
28 } | |
29 | |
30 TEST(Uuid, Test) | |
31 { | |
32 ASSERT_FALSE(Toolbox::IsUuid("")); | |
33 ASSERT_FALSE(Toolbox::IsUuid("012345678901234567890123456789012345")); | |
34 ASSERT_TRUE(Toolbox::IsUuid("550e8400-e29b-41d4-a716-446655440000")); | |
402 | 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); | |
0 | 52 } |
53 | |
54 TEST(Zlib, Basic) | |
55 { | |
56 std::string s = Toolbox::GenerateUuid(); | |
57 s = s + s + s + s; | |
58 | |
59 std::string compressed; | |
60 ZlibCompressor c; | |
61 c.Compress(compressed, s); | |
62 | |
63 std::string uncompressed; | |
64 c.Uncompress(uncompressed, compressed); | |
65 | |
66 ASSERT_EQ(s.size(), uncompressed.size()); | |
67 ASSERT_EQ(0, memcmp(&s[0], &uncompressed[0], s.size())); | |
68 } | |
69 | |
70 TEST(Zlib, Empty) | |
71 { | |
72 std::string s = ""; | |
73 | |
74 std::string compressed; | |
75 ZlibCompressor c; | |
76 c.Compress(compressed, s); | |
77 | |
78 std::string uncompressed; | |
79 c.Uncompress(uncompressed, compressed); | |
80 | |
81 ASSERT_EQ(0u, uncompressed.size()); | |
82 } | |
83 | |
84 TEST(ParseGetQuery, Basic) | |
85 { | |
86 HttpHandler::Arguments a; | |
87 HttpHandler::ParseGetQuery(a, "aaa=baaa&bb=a&aa=c"); | |
88 ASSERT_EQ(3u, a.size()); | |
89 ASSERT_EQ(a["aaa"], "baaa"); | |
90 ASSERT_EQ(a["bb"], "a"); | |
91 ASSERT_EQ(a["aa"], "c"); | |
92 } | |
93 | |
94 TEST(ParseGetQuery, BasicEmpty) | |
95 { | |
96 HttpHandler::Arguments a; | |
97 HttpHandler::ParseGetQuery(a, "aaa&bb=aa&aa"); | |
98 ASSERT_EQ(3u, a.size()); | |
99 ASSERT_EQ(a["aaa"], ""); | |
100 ASSERT_EQ(a["bb"], "aa"); | |
101 ASSERT_EQ(a["aa"], ""); | |
102 } | |
103 | |
104 TEST(ParseGetQuery, Single) | |
105 { | |
106 HttpHandler::Arguments a; | |
107 HttpHandler::ParseGetQuery(a, "aaa=baaa"); | |
108 ASSERT_EQ(1u, a.size()); | |
109 ASSERT_EQ(a["aaa"], "baaa"); | |
110 } | |
111 | |
112 TEST(ParseGetQuery, SingleEmpty) | |
113 { | |
114 HttpHandler::Arguments a; | |
115 HttpHandler::ParseGetQuery(a, "aaa"); | |
116 ASSERT_EQ(1u, a.size()); | |
117 ASSERT_EQ(a["aaa"], ""); | |
118 } | |
119 | |
120 TEST(DicomFormat, Tag) | |
121 { | |
122 ASSERT_EQ("PatientName", FromDcmtkBridge::GetName(DicomTag(0x0010, 0x0010))); | |
123 | |
304 | 124 DicomTag t = FromDcmtkBridge::ParseTag("SeriesDescription"); |
0 | 125 ASSERT_EQ(0x0008, t.GetGroup()); |
126 ASSERT_EQ(0x103E, t.GetElement()); | |
304 | 127 |
128 t = FromDcmtkBridge::ParseTag("0020-e040"); | |
129 ASSERT_EQ(0x0020, t.GetGroup()); | |
130 ASSERT_EQ(0xe040, t.GetElement()); | |
0 | 131 } |
132 | |
133 | |
134 TEST(Uri, SplitUriComponents) | |
135 { | |
136 UriComponents c; | |
137 Toolbox::SplitUriComponents(c, "/cou/hello/world"); | |
138 ASSERT_EQ(3u, c.size()); | |
139 ASSERT_EQ("cou", c[0]); | |
140 ASSERT_EQ("hello", c[1]); | |
141 ASSERT_EQ("world", c[2]); | |
142 | |
143 Toolbox::SplitUriComponents(c, "/cou/hello/world/"); | |
144 ASSERT_EQ(3u, c.size()); | |
145 ASSERT_EQ("cou", c[0]); | |
146 ASSERT_EQ("hello", c[1]); | |
147 ASSERT_EQ("world", c[2]); | |
148 | |
149 Toolbox::SplitUriComponents(c, "/cou/hello/world/a"); | |
150 ASSERT_EQ(4u, c.size()); | |
151 ASSERT_EQ("cou", c[0]); | |
152 ASSERT_EQ("hello", c[1]); | |
153 ASSERT_EQ("world", c[2]); | |
154 ASSERT_EQ("a", c[3]); | |
155 | |
156 Toolbox::SplitUriComponents(c, "/"); | |
157 ASSERT_EQ(0u, c.size()); | |
158 | |
159 Toolbox::SplitUriComponents(c, "/hello"); | |
160 ASSERT_EQ(1u, c.size()); | |
161 ASSERT_EQ("hello", c[0]); | |
162 | |
163 Toolbox::SplitUriComponents(c, "/hello/"); | |
164 ASSERT_EQ(1u, c.size()); | |
165 ASSERT_EQ("hello", c[0]); | |
166 | |
63 | 167 ASSERT_THROW(Toolbox::SplitUriComponents(c, ""), OrthancException); |
168 ASSERT_THROW(Toolbox::SplitUriComponents(c, "a"), OrthancException); | |
207 | 169 ASSERT_THROW(Toolbox::SplitUriComponents(c, "/coucou//coucou"), OrthancException); |
0 | 170 } |
171 | |
172 | |
173 TEST(Uri, Child) | |
174 { | |
175 UriComponents c1; Toolbox::SplitUriComponents(c1, "/hello/world"); | |
176 UriComponents c2; Toolbox::SplitUriComponents(c2, "/hello/hello"); | |
177 UriComponents c3; Toolbox::SplitUriComponents(c3, "/hello"); | |
178 UriComponents c4; Toolbox::SplitUriComponents(c4, "/world"); | |
179 UriComponents c5; Toolbox::SplitUriComponents(c5, "/"); | |
180 | |
181 ASSERT_TRUE(Toolbox::IsChildUri(c1, c1)); | |
182 ASSERT_FALSE(Toolbox::IsChildUri(c1, c2)); | |
183 ASSERT_FALSE(Toolbox::IsChildUri(c1, c3)); | |
184 ASSERT_FALSE(Toolbox::IsChildUri(c1, c4)); | |
185 ASSERT_FALSE(Toolbox::IsChildUri(c1, c5)); | |
186 | |
187 ASSERT_FALSE(Toolbox::IsChildUri(c2, c1)); | |
188 ASSERT_TRUE(Toolbox::IsChildUri(c2, c2)); | |
189 ASSERT_FALSE(Toolbox::IsChildUri(c2, c3)); | |
190 ASSERT_FALSE(Toolbox::IsChildUri(c2, c4)); | |
191 ASSERT_FALSE(Toolbox::IsChildUri(c2, c5)); | |
192 | |
193 ASSERT_TRUE(Toolbox::IsChildUri(c3, c1)); | |
194 ASSERT_TRUE(Toolbox::IsChildUri(c3, c2)); | |
195 ASSERT_TRUE(Toolbox::IsChildUri(c3, c3)); | |
196 ASSERT_FALSE(Toolbox::IsChildUri(c3, c4)); | |
197 ASSERT_FALSE(Toolbox::IsChildUri(c3, c5)); | |
198 | |
199 ASSERT_FALSE(Toolbox::IsChildUri(c4, c1)); | |
200 ASSERT_FALSE(Toolbox::IsChildUri(c4, c2)); | |
201 ASSERT_FALSE(Toolbox::IsChildUri(c4, c3)); | |
202 ASSERT_TRUE(Toolbox::IsChildUri(c4, c4)); | |
203 ASSERT_FALSE(Toolbox::IsChildUri(c4, c5)); | |
204 | |
205 ASSERT_TRUE(Toolbox::IsChildUri(c5, c1)); | |
206 ASSERT_TRUE(Toolbox::IsChildUri(c5, c2)); | |
207 ASSERT_TRUE(Toolbox::IsChildUri(c5, c3)); | |
208 ASSERT_TRUE(Toolbox::IsChildUri(c5, c4)); | |
209 ASSERT_TRUE(Toolbox::IsChildUri(c5, c5)); | |
210 } | |
211 | |
212 TEST(Uri, AutodetectMimeType) | |
213 { | |
214 ASSERT_EQ("", Toolbox::AutodetectMimeType("../NOTES")); | |
215 ASSERT_EQ("", Toolbox::AutodetectMimeType("")); | |
216 ASSERT_EQ("", Toolbox::AutodetectMimeType("/")); | |
217 ASSERT_EQ("", Toolbox::AutodetectMimeType("a/a")); | |
218 | |
219 ASSERT_EQ("text/plain", Toolbox::AutodetectMimeType("../NOTES.txt")); | |
220 ASSERT_EQ("text/plain", Toolbox::AutodetectMimeType("../coucou.xml/NOTES.txt")); | |
221 ASSERT_EQ("text/xml", Toolbox::AutodetectMimeType("../.xml")); | |
222 | |
223 ASSERT_EQ("application/javascript", Toolbox::AutodetectMimeType("NOTES.js")); | |
224 ASSERT_EQ("application/json", Toolbox::AutodetectMimeType("NOTES.json")); | |
225 ASSERT_EQ("application/pdf", Toolbox::AutodetectMimeType("NOTES.pdf")); | |
226 ASSERT_EQ("text/css", Toolbox::AutodetectMimeType("NOTES.css")); | |
227 ASSERT_EQ("text/html", Toolbox::AutodetectMimeType("NOTES.html")); | |
228 ASSERT_EQ("text/plain", Toolbox::AutodetectMimeType("NOTES.txt")); | |
229 ASSERT_EQ("text/xml", Toolbox::AutodetectMimeType("NOTES.xml")); | |
230 ASSERT_EQ("image/gif", Toolbox::AutodetectMimeType("NOTES.gif")); | |
231 ASSERT_EQ("image/jpeg", Toolbox::AutodetectMimeType("NOTES.jpg")); | |
232 ASSERT_EQ("image/jpeg", Toolbox::AutodetectMimeType("NOTES.jpeg")); | |
233 ASSERT_EQ("image/png", Toolbox::AutodetectMimeType("NOTES.png")); | |
234 } | |
235 | |
22 | 236 TEST(Toolbox, ComputeMD5) |
237 { | |
238 std::string s; | |
239 | |
240 // # echo -n "Hello" | md5sum | |
241 | |
242 Toolbox::ComputeMD5(s, "Hello"); | |
243 ASSERT_EQ("8b1a9953c4611296a827abf8c47804d7", s); | |
244 Toolbox::ComputeMD5(s, ""); | |
245 ASSERT_EQ("d41d8cd98f00b204e9800998ecf8427e", s); | |
246 } | |
247 | |
177 | 248 TEST(Toolbox, ComputeSHA1) |
249 { | |
250 std::string s; | |
251 | |
252 Toolbox::ComputeSHA1(s, "The quick brown fox jumps over the lazy dog"); | |
253 ASSERT_EQ("2fd4e1c6-7a2d28fc-ed849ee1-bb76e739-1b93eb12", s); | |
254 Toolbox::ComputeSHA1(s, ""); | |
255 ASSERT_EQ("da39a3ee-5e6b4b0d-3255bfef-95601890-afd80709", s); | |
256 } | |
257 | |
258 | |
24 | 259 TEST(Toolbox, Base64) |
260 { | |
261 ASSERT_EQ("", Toolbox::EncodeBase64("")); | |
262 ASSERT_EQ("YQ==", Toolbox::EncodeBase64("a")); | |
263 ASSERT_EQ("SGVsbG8gd29ybGQ=", Toolbox::EncodeBase64("Hello world")); | |
264 } | |
265 | |
87
8517e2c44283
path to configuration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
63
diff
changeset
|
266 TEST(Toolbox, PathToExecutable) |
8517e2c44283
path to configuration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
63
diff
changeset
|
267 { |
8517e2c44283
path to configuration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
63
diff
changeset
|
268 printf("[%s]\n", Toolbox::GetPathToExecutable().c_str()); |
8517e2c44283
path to configuration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
63
diff
changeset
|
269 printf("[%s]\n", Toolbox::GetDirectoryOfExecutable().c_str()); |
8517e2c44283
path to configuration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
63
diff
changeset
|
270 } |
8517e2c44283
path to configuration
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
63
diff
changeset
|
271 |
247
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
272 TEST(Toolbox, StripSpaces) |
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
273 { |
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
274 ASSERT_EQ("", Toolbox::StripSpaces(" \t \r \n ")); |
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
275 ASSERT_EQ("coucou", Toolbox::StripSpaces(" coucou \t \r \n ")); |
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
276 ASSERT_EQ("cou cou", Toolbox::StripSpaces(" cou cou \n ")); |
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
277 ASSERT_EQ("c", Toolbox::StripSpaces(" \n\t c\r \n ")); |
c9b3ba0fd140
path management in zip files
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
235
diff
changeset
|
278 } |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
279 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
280 |
102
7593b57dc1bf
switch to google log
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
281 #include <glog/logging.h> |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
282 |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
283 TEST(Logger, Basic) |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
284 { |
102
7593b57dc1bf
switch to google log
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
285 LOG(INFO) << "I say hello"; |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
286 } |
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
287 |
107
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
288 TEST(Toolbox, ConvertFromLatin1) |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
289 { |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
290 // This is a Latin-1 test string |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
291 const unsigned char data[10] = { 0xe0, 0xe9, 0xea, 0xe7, 0x26, 0xc6, 0x61, 0x62, 0x63, 0x00 }; |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
292 |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
293 /*FILE* f = fopen("/tmp/tutu", "w"); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
294 fwrite(&data[0], 9, 1, f); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
295 fclose(f);*/ |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
296 |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
297 std::string s((char*) &data[0], 10); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
298 ASSERT_EQ("&abc", Toolbox::ConvertToAscii(s)); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
299 |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
300 // Open in Emacs, then save with UTF-8 encoding, then "hexdump -C" |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
301 std::string utf8 = Toolbox::ConvertToUtf8(s, "ISO-8859-1"); |
235 | 302 ASSERT_EQ(15u, utf8.size()); |
107
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
303 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[0])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
304 ASSERT_EQ(0xa0, static_cast<unsigned char>(utf8[1])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
305 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[2])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
306 ASSERT_EQ(0xa9, static_cast<unsigned char>(utf8[3])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
307 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[4])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
308 ASSERT_EQ(0xaa, static_cast<unsigned char>(utf8[5])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
309 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[6])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
310 ASSERT_EQ(0xa7, static_cast<unsigned char>(utf8[7])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
311 ASSERT_EQ(0x26, static_cast<unsigned char>(utf8[8])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
312 ASSERT_EQ(0xc3, static_cast<unsigned char>(utf8[9])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
313 ASSERT_EQ(0x86, static_cast<unsigned char>(utf8[10])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
314 ASSERT_EQ(0x61, static_cast<unsigned char>(utf8[11])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
315 ASSERT_EQ(0x62, static_cast<unsigned char>(utf8[12])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
316 ASSERT_EQ(0x63, static_cast<unsigned char>(utf8[13])); |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
317 ASSERT_EQ(0x00, static_cast<unsigned char>(utf8[14])); // Null-terminated string |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
318 } |
3b45473c0a73
replace boost::locale with iconv for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
102
diff
changeset
|
319 |
336 | 320 TEST(Toolbox, UrlDecode) |
321 { | |
322 std::string s; | |
323 | |
324 s = "Hello%20World"; | |
325 Toolbox::UrlDecode(s); | |
326 ASSERT_EQ("Hello World", s); | |
327 | |
337 | 328 s = "%21%23%24%26%27%28%29%2A%2B%2c%2f%3A%3b%3d%3f%40%5B%5D%90%ff"; |
336 | 329 Toolbox::UrlDecode(s); |
337 | 330 std::string ss = "!#$&'()*+,/:;=?@[]"; |
331 ss.push_back((char) 144); | |
332 ss.push_back((char) 255); | |
333 ASSERT_EQ(ss, s); | |
336 | 334 |
335 s = "(2000%2C00A4)+Other"; | |
336 Toolbox::UrlDecode(s); | |
337 ASSERT_EQ("(2000,00A4) Other", s); | |
338 } | |
339 | |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
340 |
429
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
341 #if defined(__linux) |
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
342 TEST(OrthancInitialization, AbsoluteDirectory) |
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
343 { |
430 | 344 ASSERT_EQ("/tmp/hello", InterpretRelativePath("/tmp", "hello")); |
345 ASSERT_EQ("/tmp", InterpretRelativePath("/tmp", "/tmp")); | |
429
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
346 } |
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
347 #endif |
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
348 |
09b3c6265a94
unit test for fedora 18 problem
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
402
diff
changeset
|
349 |
434
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
350 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
351 #include "../OrthancServer/ServerEnumerations.h" |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
352 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
353 TEST(EnumerationDictionary, Simple) |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
354 { |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
355 Toolbox::EnumerationDictionary<MetadataType> d; |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
356 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
357 ASSERT_THROW(d.Translate("ReceptionDate"), OrthancException); |
435
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
358 ASSERT_EQ(MetadataType_ModifiedFrom, d.Translate("5")); |
436
d51186bf7602
read access to metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
435
diff
changeset
|
359 ASSERT_EQ(256, d.Translate("256")); |
434
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
360 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
361 d.Add(MetadataType_Instance_ReceptionDate, "ReceptionDate"); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
362 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
363 ASSERT_EQ(MetadataType_Instance_ReceptionDate, d.Translate("ReceptionDate")); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
364 ASSERT_EQ(MetadataType_Instance_ReceptionDate, d.Translate("2")); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
365 ASSERT_EQ("ReceptionDate", d.Translate(MetadataType_Instance_ReceptionDate)); |
435
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
366 |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
367 ASSERT_THROW(d.Add(MetadataType_Instance_ReceptionDate, "Hello"), OrthancException); |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
368 ASSERT_THROW(d.Add(MetadataType_ModifiedFrom, "ReceptionDate"), OrthancException); // already used |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
369 ASSERT_THROW(d.Add(MetadataType_ModifiedFrom, "1024"), OrthancException); // cannot register numbers |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
370 d.Add(MetadataType_ModifiedFrom, "ModifiedFrom"); // ok |
434
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
371 } |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
372 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
373 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
374 TEST(EnumerationDictionary, ServerEnumerations) |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
375 { |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
376 ASSERT_STREQ("Patient", EnumerationToString(ResourceType_Patient)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
377 ASSERT_STREQ("Study", EnumerationToString(ResourceType_Study)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
378 ASSERT_STREQ("Series", EnumerationToString(ResourceType_Series)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
379 ASSERT_STREQ("Instance", EnumerationToString(ResourceType_Instance)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
380 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
381 ASSERT_STREQ("ModifiedSeries", EnumerationToString(ChangeType_ModifiedSeries)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
382 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
383 ASSERT_STREQ("Failure", EnumerationToString(StoreStatus_Failure)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
384 ASSERT_STREQ("Success", EnumerationToString(StoreStatus_Success)); |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
385 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
386 ASSERT_STREQ("CompletedSeries", EnumerationToString(ChangeType_CompletedSeries)); |
435
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
387 |
437 | 388 ASSERT_EQ("IndexInSeries", EnumerationToString(MetadataType_Instance_IndexInSeries)); |
389 ASSERT_EQ("LastUpdate", EnumerationToString(MetadataType_LastUpdate)); | |
435
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
390 |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
391 ASSERT_EQ(2047, StringToMetadata("2047")); |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
392 ASSERT_THROW(StringToMetadata("Ceci est un test"), OrthancException); |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
393 ASSERT_THROW(RegisterUserMetadata(128, ""), OrthancException); // too low (< 1024) |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
394 ASSERT_THROW(RegisterUserMetadata(128000, ""), OrthancException); // too high (> 65535) |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
395 RegisterUserMetadata(2047, "Ceci est un test"); |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
396 ASSERT_EQ(2047, StringToMetadata("2047")); |
28ba73274919
registration of user-defined metadata
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
434
diff
changeset
|
397 ASSERT_EQ(2047, StringToMetadata("Ceci est un test")); |
434
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
398 } |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
399 |
ccf3a0a43dac
EnumerationDictionary
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
430
diff
changeset
|
400 |
450 | 401 |
402 class DynamicInteger : public IDynamicObject | |
403 { | |
404 private: | |
405 int value_; | |
406 | |
407 public: | |
408 DynamicInteger(int value) : value_(value) | |
409 { | |
410 } | |
411 | |
412 int GetValue() const | |
413 { | |
414 return value_; | |
415 } | |
416 }; | |
417 | |
418 | |
419 TEST(SharedMessageQueue, Basic) | |
420 { | |
421 SharedMessageQueue q; | |
452 | 422 ASSERT_TRUE(q.WaitEmpty(0)); |
450 | 423 q.Enqueue(new DynamicInteger(10)); |
452 | 424 ASSERT_FALSE(q.WaitEmpty(1)); |
450 | 425 q.Enqueue(new DynamicInteger(20)); |
426 q.Enqueue(new DynamicInteger(30)); | |
427 q.Enqueue(new DynamicInteger(40)); | |
428 | |
429 std::auto_ptr<DynamicInteger> i; | |
452 | 430 i.reset(dynamic_cast<DynamicInteger*>(q.Dequeue(1))); ASSERT_EQ(10, i->GetValue()); |
431 i.reset(dynamic_cast<DynamicInteger*>(q.Dequeue(1))); ASSERT_EQ(20, i->GetValue()); | |
432 i.reset(dynamic_cast<DynamicInteger*>(q.Dequeue(1))); ASSERT_EQ(30, i->GetValue()); | |
433 ASSERT_FALSE(q.WaitEmpty(1)); | |
434 i.reset(dynamic_cast<DynamicInteger*>(q.Dequeue(1))); ASSERT_EQ(40, i->GetValue()); | |
435 ASSERT_TRUE(q.WaitEmpty(0)); | |
436 ASSERT_EQ(NULL, q.Dequeue(1)); | |
450 | 437 } |
438 | |
439 | |
440 TEST(SharedMessageQueue, Clean) | |
441 { | |
442 try | |
443 { | |
444 SharedMessageQueue q; | |
445 q.Enqueue(new DynamicInteger(10)); | |
446 q.Enqueue(new DynamicInteger(20)); | |
447 throw OrthancException("Nope"); | |
448 } | |
449 catch (OrthancException) | |
450 { | |
451 } | |
452 } | |
453 | |
454 | |
0 | 455 int main(int argc, char **argv) |
456 { | |
102
7593b57dc1bf
switch to google log
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
457 // Initialize Google's logging library. |
7593b57dc1bf
switch to google log
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
458 FLAGS_logtostderr = true; |
137
0e97abc7b950
fix of a bug in older versions of sqlite
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
107
diff
changeset
|
459 FLAGS_minloglevel = 0; |
159
c08fbad40ddd
less verbosity in unit tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
137
diff
changeset
|
460 |
c08fbad40ddd
less verbosity in unit tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
137
diff
changeset
|
461 // Go to trace-level verbosity |
c08fbad40ddd
less verbosity in unit tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
137
diff
changeset
|
462 //FLAGS_v = 1; |
c08fbad40ddd
less verbosity in unit tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
137
diff
changeset
|
463 |
453 | 464 Toolbox::DetectEndianness(); |
465 | |
102
7593b57dc1bf
switch to google log
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
101
diff
changeset
|
466 google::InitGoogleLogging("Orthanc"); |
100
27dc762e3dc8
getting rid of static dcmtk for debian
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
87
diff
changeset
|
467 |
63 | 468 OrthancInitialize(); |
0 | 469 ::testing::InitGoogleTest(&argc, argv); |
470 int result = RUN_ALL_TESTS(); | |
63 | 471 OrthancFinalize(); |
0 | 472 return result; |
473 } |