Mercurial > hg > orthanc-databases
annotate Framework/Plugins/IndexUnitTests.h @ 221:73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Tue, 30 Mar 2021 10:40:34 +0200 |
parents | c2e4a909de0e |
children | 94c9908e6aca |
rev | line source |
---|---|
0 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
193
3236894320d6
upgrade to year 2021
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
157
diff
changeset
|
5 * Copyright (C) 2017-2021 Osimis S.A., Belgium |
0 | 6 * |
7 * This program is free software: you can redistribute it and/or | |
8 * modify it under the terms of the GNU Affero General Public License | |
9 * as published by the Free Software Foundation, either version 3 of | |
10 * the License, or (at your option) any later version. | |
11 * | |
12 * This program is distributed in the hope that it will be useful, but | |
13 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
15 * Affero General Public License for more details. | |
16 * | |
17 * You should have received a copy of the GNU Affero General Public License | |
18 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
19 **/ | |
20 | |
21 | |
22 #pragma once | |
23 | |
28
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
27
diff
changeset
|
24 #include "../Common/ImplicitTransaction.h" |
213
c2e4a909de0e
added IndexBackend::Register() to be used in all the index plugins
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
209
diff
changeset
|
25 #include "DatabaseBackendAdapterV2.h" |
152 | 26 #include "GlobalProperties.h" |
28
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
27
diff
changeset
|
27 |
157
275e14f57f1e
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
152
diff
changeset
|
28 #include <Compatibility.h> // For std::unique_ptr<> |
275e14f57f1e
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
152
diff
changeset
|
29 |
0 | 30 #include <orthanc/OrthancCDatabasePlugin.h> |
31 | |
32 #include <gtest/gtest.h> | |
33 #include <list> | |
34 | |
35 | |
152 | 36 namespace Orthanc |
37 { | |
38 /** | |
39 * Mock enumeration inspired from the source code of Orthanc... only | |
40 * for use in the unit tests! | |
41 * https://hg.orthanc-server.com/orthanc/file/default/OrthancServer/Sources/ServerEnumerations.h | |
42 **/ | |
43 enum MetadataType | |
44 { | |
45 MetadataType_ModifiedFrom, | |
46 MetadataType_LastUpdate | |
47 }; | |
48 } | |
49 | |
50 | |
157
275e14f57f1e
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
152
diff
changeset
|
51 static std::unique_ptr<OrthancPluginAttachment> expectedAttachment; |
0 | 52 static std::list<OrthancPluginDicomTag> expectedDicomTags; |
157
275e14f57f1e
replacing deprecated std::auto_ptr by std::unique_ptr
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
152
diff
changeset
|
53 static std::unique_ptr<OrthancPluginExportedResource> expectedExported; |
0 | 54 |
55 static void CheckAttachment(const OrthancPluginAttachment& attachment) | |
56 { | |
57 ASSERT_STREQ(expectedAttachment->uuid, attachment.uuid); | |
58 ASSERT_EQ(expectedAttachment->contentType, attachment.contentType); | |
59 ASSERT_EQ(expectedAttachment->uncompressedSize, attachment.uncompressedSize); | |
60 ASSERT_STREQ(expectedAttachment->uncompressedHash, attachment.uncompressedHash); | |
61 ASSERT_EQ(expectedAttachment->compressionType, attachment.compressionType); | |
62 ASSERT_EQ(expectedAttachment->compressedSize, attachment.compressedSize); | |
63 ASSERT_STREQ(expectedAttachment->compressedHash, attachment.compressedHash); | |
64 } | |
65 | |
66 static void CheckExportedResource(const OrthancPluginExportedResource& exported) | |
67 { | |
68 ASSERT_EQ(expectedExported->seq, exported.seq); | |
69 ASSERT_EQ(expectedExported->resourceType, exported.resourceType); | |
70 ASSERT_STREQ(expectedExported->publicId, exported.publicId); | |
71 ASSERT_STREQ(expectedExported->modality, exported.modality); | |
72 ASSERT_STREQ(expectedExported->date, exported.date); | |
73 ASSERT_STREQ(expectedExported->patientId, exported.patientId); | |
74 ASSERT_STREQ(expectedExported->studyInstanceUid, exported.studyInstanceUid); | |
75 ASSERT_STREQ(expectedExported->seriesInstanceUid, exported.seriesInstanceUid); | |
76 ASSERT_STREQ(expectedExported->sopInstanceUid, exported.sopInstanceUid); | |
77 } | |
78 | |
79 static void CheckDicomTag(const OrthancPluginDicomTag& tag) | |
80 { | |
81 for (std::list<OrthancPluginDicomTag>::const_iterator | |
82 it = expectedDicomTags.begin(); it != expectedDicomTags.end(); ++it) | |
83 { | |
84 if (it->group == tag.group && | |
85 it->element == tag.element && | |
86 !strcmp(it->value, tag.value)) | |
87 { | |
88 // OK, match | |
89 return; | |
90 } | |
91 } | |
92 | |
93 ASSERT_TRUE(0); // Error | |
94 } | |
95 | |
96 | |
97 | |
98 static OrthancPluginErrorCode InvokeService(struct _OrthancPluginContext_t* context, | |
99 _OrthancPluginService service, | |
100 const void* params) | |
101 { | |
199 | 102 switch (service) |
0 | 103 { |
199 | 104 case _OrthancPluginService_DatabaseAnswer: |
0 | 105 { |
199 | 106 const _OrthancPluginDatabaseAnswer& answer = |
107 *reinterpret_cast<const _OrthancPluginDatabaseAnswer*>(params); | |
108 | |
109 switch (answer.type) | |
0 | 110 { |
199 | 111 case _OrthancPluginDatabaseAnswerType_Attachment: |
112 { | |
113 const OrthancPluginAttachment& attachment = | |
114 *reinterpret_cast<const OrthancPluginAttachment*>(answer.valueGeneric); | |
115 CheckAttachment(attachment); | |
116 break; | |
117 } | |
118 | |
119 case _OrthancPluginDatabaseAnswerType_ExportedResource: | |
120 { | |
121 const OrthancPluginExportedResource& attachment = | |
122 *reinterpret_cast<const OrthancPluginExportedResource*>(answer.valueGeneric); | |
123 CheckExportedResource(attachment); | |
124 break; | |
125 } | |
126 | |
127 case _OrthancPluginDatabaseAnswerType_DicomTag: | |
128 { | |
129 const OrthancPluginDicomTag& tag = | |
130 *reinterpret_cast<const OrthancPluginDicomTag*>(answer.valueGeneric); | |
131 CheckDicomTag(tag); | |
132 break; | |
133 } | |
134 | |
135 default: | |
136 printf("Unhandled message: %d\n", answer.type); | |
137 break; | |
0 | 138 } |
139 | |
199 | 140 return OrthancPluginErrorCode_Success; |
141 } | |
0 | 142 |
199 | 143 case _OrthancPluginService_GetExpectedDatabaseVersion: |
144 { | |
145 const _OrthancPluginReturnSingleValue& p = | |
146 *reinterpret_cast<const _OrthancPluginReturnSingleValue*>(params); | |
147 *(p.resultUint32) = ORTHANC_DATABASE_VERSION; | |
148 return OrthancPluginErrorCode_Success; | |
149 } | |
0 | 150 |
199 | 151 default: |
152 assert(0); | |
153 printf("Service not emulated: %d\n", service); | |
154 return OrthancPluginErrorCode_NotImplemented; | |
0 | 155 } |
156 } | |
157 | |
158 | |
159 TEST(IndexBackend, Basic) | |
160 { | |
161 using namespace OrthancDatabases; | |
162 | |
163 OrthancPluginContext context; | |
164 context.pluginsManager = NULL; | |
165 context.orthancVersion = "mainline"; | |
166 context.Free = ::free; | |
167 context.InvokeService = InvokeService; | |
168 | |
28
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
27
diff
changeset
|
169 ImplicitTransaction::SetErrorOnDoubleExecution(true); |
c0cb5d2cd696
checks depending on Orthanc version
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
27
diff
changeset
|
170 |
0 | 171 #if ORTHANC_ENABLE_POSTGRESQL == 1 |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
172 PostgreSQLIndex db(&context, globalParameters_); |
0 | 173 db.SetClearAll(true); |
174 #elif ORTHANC_ENABLE_MYSQL == 1 | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
175 MySQLIndex db(&context, globalParameters_); |
0 | 176 db.SetClearAll(true); |
177 #elif ORTHANC_ENABLE_SQLITE == 1 | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
178 SQLiteIndex db(&context); // Open in memory |
0 | 179 #else |
180 # error Unsupported database backend | |
181 #endif | |
182 | |
204 | 183 db.SetOutputFactory(new DatabaseBackendAdapterV2::Factory(&context, NULL)); |
0 | 184 db.Open(); |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
185 |
203
2089d4071408
moving classes out of OrthancPlugins namespace, to OrthancDatabases
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
201
diff
changeset
|
186 std::unique_ptr<IDatabaseBackendOutput> output(db.CreateOutput()); |
26 | 187 |
0 | 188 |
189 std::string s; | |
221
73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
213
diff
changeset
|
190 ASSERT_TRUE(db.LookupGlobalProperty(s, MISSING_SERVER_IDENTIFIER, Orthanc::GlobalProperty_DatabaseSchemaVersion)); |
0 | 191 ASSERT_EQ("6", s); |
192 | |
221
73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
213
diff
changeset
|
193 ASSERT_FALSE(db.LookupGlobalProperty(s, MISSING_SERVER_IDENTIFIER, Orthanc::GlobalProperty_AnonymizationSequence)); |
73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
213
diff
changeset
|
194 db.SetGlobalProperty(MISSING_SERVER_IDENTIFIER, Orthanc::GlobalProperty_AnonymizationSequence, "Hello"); |
73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
213
diff
changeset
|
195 ASSERT_TRUE(db.LookupGlobalProperty(s, MISSING_SERVER_IDENTIFIER, Orthanc::GlobalProperty_AnonymizationSequence)); |
0 | 196 ASSERT_EQ("Hello", s); |
221
73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
213
diff
changeset
|
197 db.SetGlobalProperty(MISSING_SERVER_IDENTIFIER, Orthanc::GlobalProperty_AnonymizationSequence, "HelloWorld"); |
73cc85f3d9c1
implementation of the "serverIdentifier" information for global properties
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
213
diff
changeset
|
198 ASSERT_TRUE(db.LookupGlobalProperty(s, MISSING_SERVER_IDENTIFIER, Orthanc::GlobalProperty_AnonymizationSequence)); |
0 | 199 ASSERT_EQ("HelloWorld", s); |
200 | |
201 int64_t a = db.CreateResource("study", OrthancPluginResourceType_Study); | |
202 ASSERT_TRUE(db.IsExistingResource(a)); | |
203 ASSERT_FALSE(db.IsExistingResource(a + 1)); | |
204 | |
205 int64_t b; | |
206 OrthancPluginResourceType t; | |
207 ASSERT_FALSE(db.LookupResource(b, t, "world")); | |
208 ASSERT_TRUE(db.LookupResource(b, t, "study")); | |
209 ASSERT_EQ(a, b); | |
210 ASSERT_EQ(OrthancPluginResourceType_Study, t); | |
211 | |
212 b = db.CreateResource("series", OrthancPluginResourceType_Series); | |
213 ASSERT_NE(a, b); | |
214 | |
215 ASSERT_EQ("study", db.GetPublicId(a)); | |
216 ASSERT_EQ("series", db.GetPublicId(b)); | |
217 ASSERT_EQ(OrthancPluginResourceType_Study, db.GetResourceType(a)); | |
218 ASSERT_EQ(OrthancPluginResourceType_Series, db.GetResourceType(b)); | |
219 | |
220 db.AttachChild(a, b); | |
221 | |
222 int64_t c; | |
223 ASSERT_FALSE(db.LookupParent(c, a)); | |
224 ASSERT_TRUE(db.LookupParent(c, b)); | |
225 ASSERT_EQ(a, c); | |
226 | |
227 c = db.CreateResource("series2", OrthancPluginResourceType_Series); | |
228 db.AttachChild(a, c); | |
229 | |
209 | 230 ASSERT_EQ(3u, db.GetAllResourcesCount()); |
231 ASSERT_EQ(0u, db.GetResourcesCount(OrthancPluginResourceType_Patient)); | |
232 ASSERT_EQ(1u, db.GetResourcesCount(OrthancPluginResourceType_Study)); | |
233 ASSERT_EQ(2u, db.GetResourcesCount(OrthancPluginResourceType_Series)); | |
0 | 234 |
235 ASSERT_FALSE(db.GetParentPublicId(s, a)); | |
236 ASSERT_TRUE(db.GetParentPublicId(s, b)); ASSERT_EQ("study", s); | |
237 ASSERT_TRUE(db.GetParentPublicId(s, c)); ASSERT_EQ("study", s); | |
238 | |
239 std::list<std::string> children; | |
240 db.GetChildren(children, a); | |
241 ASSERT_EQ(2u, children.size()); | |
242 db.GetChildren(children, b); | |
243 ASSERT_EQ(0u, children.size()); | |
244 db.GetChildren(children, c); | |
245 ASSERT_EQ(0u, children.size()); | |
246 | |
247 std::list<std::string> cp; | |
248 db.GetChildrenPublicId(cp, a); | |
249 ASSERT_EQ(2u, cp.size()); | |
250 ASSERT_TRUE(cp.front() == "series" || cp.front() == "series2"); | |
251 ASSERT_TRUE(cp.back() == "series" || cp.back() == "series2"); | |
252 ASSERT_NE(cp.front(), cp.back()); | |
253 | |
254 std::list<std::string> pub; | |
255 db.GetAllPublicIds(pub, OrthancPluginResourceType_Patient); | |
256 ASSERT_EQ(0u, pub.size()); | |
257 db.GetAllPublicIds(pub, OrthancPluginResourceType_Study); | |
258 ASSERT_EQ(1u, pub.size()); | |
259 ASSERT_EQ("study", pub.front()); | |
260 db.GetAllPublicIds(pub, OrthancPluginResourceType_Series); | |
261 ASSERT_EQ(2u, pub.size()); | |
262 ASSERT_TRUE(pub.front() == "series" || pub.front() == "series2"); | |
263 ASSERT_TRUE(pub.back() == "series" || pub.back() == "series2"); | |
264 ASSERT_NE(pub.front(), pub.back()); | |
265 | |
266 std::list<int64_t> ci; | |
267 db.GetChildrenInternalId(ci, a); | |
268 ASSERT_EQ(2u, ci.size()); | |
269 ASSERT_TRUE(ci.front() == b || ci.front() == c); | |
270 ASSERT_TRUE(ci.back() == b || ci.back() == c); | |
271 ASSERT_NE(ci.front(), ci.back()); | |
272 | |
273 db.SetMetadata(a, Orthanc::MetadataType_ModifiedFrom, "modified"); | |
274 db.SetMetadata(a, Orthanc::MetadataType_LastUpdate, "update2"); | |
275 ASSERT_FALSE(db.LookupMetadata(s, b, Orthanc::MetadataType_LastUpdate)); | |
276 ASSERT_TRUE(db.LookupMetadata(s, a, Orthanc::MetadataType_LastUpdate)); | |
277 ASSERT_EQ("update2", s); | |
278 db.SetMetadata(a, Orthanc::MetadataType_LastUpdate, "update"); | |
279 ASSERT_TRUE(db.LookupMetadata(s, a, Orthanc::MetadataType_LastUpdate)); | |
280 ASSERT_EQ("update", s); | |
281 | |
282 std::list<int32_t> md; | |
283 db.ListAvailableMetadata(md, a); | |
284 ASSERT_EQ(2u, md.size()); | |
285 ASSERT_TRUE(md.front() == Orthanc::MetadataType_ModifiedFrom || md.back() == Orthanc::MetadataType_ModifiedFrom); | |
286 ASSERT_TRUE(md.front() == Orthanc::MetadataType_LastUpdate || md.back() == Orthanc::MetadataType_LastUpdate); | |
287 std::string mdd; | |
288 ASSERT_TRUE(db.LookupMetadata(mdd, a, Orthanc::MetadataType_ModifiedFrom)); | |
289 ASSERT_EQ("modified", mdd); | |
290 ASSERT_TRUE(db.LookupMetadata(mdd, a, Orthanc::MetadataType_LastUpdate)); | |
291 ASSERT_EQ("update", mdd); | |
292 | |
293 db.ListAvailableMetadata(md, b); | |
294 ASSERT_EQ(0u, md.size()); | |
295 | |
296 db.DeleteMetadata(a, Orthanc::MetadataType_LastUpdate); | |
297 db.DeleteMetadata(b, Orthanc::MetadataType_LastUpdate); | |
298 ASSERT_FALSE(db.LookupMetadata(s, a, Orthanc::MetadataType_LastUpdate)); | |
299 | |
300 db.ListAvailableMetadata(md, a); | |
301 ASSERT_EQ(1u, md.size()); | |
302 ASSERT_EQ(Orthanc::MetadataType_ModifiedFrom, md.front()); | |
303 | |
304 ASSERT_EQ(0u, db.GetTotalCompressedSize()); | |
305 ASSERT_EQ(0u, db.GetTotalUncompressedSize()); | |
306 | |
307 | |
308 std::list<int32_t> fc; | |
309 | |
310 OrthancPluginAttachment a1; | |
311 a1.uuid = "uuid1"; | |
312 a1.contentType = Orthanc::FileContentType_Dicom; | |
313 a1.uncompressedSize = 42; | |
314 a1.uncompressedHash = "md5_1"; | |
315 a1.compressionType = Orthanc::CompressionType_None; | |
316 a1.compressedSize = 42; | |
317 a1.compressedHash = "md5_1"; | |
318 | |
319 OrthancPluginAttachment a2; | |
320 a2.uuid = "uuid2"; | |
321 a2.contentType = Orthanc::FileContentType_DicomAsJson; | |
322 a2.uncompressedSize = 4242; | |
323 a2.uncompressedHash = "md5_2"; | |
324 a2.compressionType = Orthanc::CompressionType_None; | |
325 a2.compressedSize = 4242; | |
326 a2.compressedHash = "md5_2"; | |
327 | |
328 db.AddAttachment(a, a1); | |
329 db.ListAvailableAttachments(fc, a); | |
330 ASSERT_EQ(1u, fc.size()); | |
331 ASSERT_EQ(Orthanc::FileContentType_Dicom, fc.front()); | |
332 db.AddAttachment(a, a2); | |
333 db.ListAvailableAttachments(fc, a); | |
334 ASSERT_EQ(2u, fc.size()); | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
335 ASSERT_FALSE(db.LookupAttachment(*output, b, Orthanc::FileContentType_Dicom)); |
0 | 336 |
337 ASSERT_EQ(4284u, db.GetTotalCompressedSize()); | |
338 ASSERT_EQ(4284u, db.GetTotalUncompressedSize()); | |
339 | |
340 expectedAttachment.reset(new OrthancPluginAttachment); | |
341 expectedAttachment->uuid = "uuid1"; | |
342 expectedAttachment->contentType = Orthanc::FileContentType_Dicom; | |
343 expectedAttachment->uncompressedSize = 42; | |
344 expectedAttachment->uncompressedHash = "md5_1"; | |
345 expectedAttachment->compressionType = Orthanc::CompressionType_None; | |
346 expectedAttachment->compressedSize = 42; | |
347 expectedAttachment->compressedHash = "md5_1"; | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
348 ASSERT_TRUE(db.LookupAttachment(*output, a, Orthanc::FileContentType_Dicom)); |
0 | 349 |
350 expectedAttachment.reset(new OrthancPluginAttachment); | |
351 expectedAttachment->uuid = "uuid2"; | |
352 expectedAttachment->contentType = Orthanc::FileContentType_DicomAsJson; | |
353 expectedAttachment->uncompressedSize = 4242; | |
354 expectedAttachment->uncompressedHash = "md5_2"; | |
355 expectedAttachment->compressionType = Orthanc::CompressionType_None; | |
356 expectedAttachment->compressedSize = 4242; | |
357 expectedAttachment->compressedHash = "md5_2"; | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
358 ASSERT_TRUE(db.LookupAttachment(*output, a, Orthanc::FileContentType_DicomAsJson)); |
0 | 359 |
360 db.ListAvailableAttachments(fc, b); | |
361 ASSERT_EQ(0u, fc.size()); | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
362 db.DeleteAttachment(*output, a, Orthanc::FileContentType_Dicom); |
0 | 363 db.ListAvailableAttachments(fc, a); |
364 ASSERT_EQ(1u, fc.size()); | |
365 ASSERT_EQ(Orthanc::FileContentType_DicomAsJson, fc.front()); | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
366 db.DeleteAttachment(*output, a, Orthanc::FileContentType_DicomAsJson); |
0 | 367 db.ListAvailableAttachments(fc, a); |
368 ASSERT_EQ(0u, fc.size()); | |
369 | |
370 | |
371 db.SetIdentifierTag(a, 0x0010, 0x0020, "patient"); | |
372 db.SetIdentifierTag(a, 0x0020, 0x000d, "study"); | |
373 | |
374 expectedDicomTags.clear(); | |
375 expectedDicomTags.push_back(OrthancPluginDicomTag()); | |
376 expectedDicomTags.push_back(OrthancPluginDicomTag()); | |
377 expectedDicomTags.front().group = 0x0010; | |
378 expectedDicomTags.front().element = 0x0020; | |
379 expectedDicomTags.front().value = "patient"; | |
380 expectedDicomTags.back().group = 0x0020; | |
381 expectedDicomTags.back().element = 0x000d; | |
382 expectedDicomTags.back().value = "study"; | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
383 db.GetMainDicomTags(*output, a); |
0 | 384 |
385 | |
386 db.LookupIdentifier(ci, OrthancPluginResourceType_Study, 0x0010, 0x0020, | |
387 OrthancPluginIdentifierConstraint_Equal, "patient"); | |
388 ASSERT_EQ(1u, ci.size()); | |
389 ASSERT_EQ(a, ci.front()); | |
390 db.LookupIdentifier(ci, OrthancPluginResourceType_Study, 0x0010, 0x0020, | |
391 OrthancPluginIdentifierConstraint_Equal, "study"); | |
392 ASSERT_EQ(0u, ci.size()); | |
393 | |
394 | |
395 OrthancPluginExportedResource exp; | |
396 exp.seq = -1; | |
397 exp.resourceType = OrthancPluginResourceType_Study; | |
398 exp.publicId = "id"; | |
399 exp.modality = "remote"; | |
400 exp.date = "date"; | |
401 exp.patientId = "patient"; | |
402 exp.studyInstanceUid = "study"; | |
403 exp.seriesInstanceUid = "series"; | |
404 exp.sopInstanceUid = "instance"; | |
405 db.LogExportedResource(exp); | |
406 | |
407 expectedExported.reset(new OrthancPluginExportedResource()); | |
408 *expectedExported = exp; | |
409 expectedExported->seq = 1; | |
410 | |
411 bool done; | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
412 db.GetExportedResources(*output, done, 0, 10); |
0 | 413 |
414 | |
415 db.GetAllPublicIds(pub, OrthancPluginResourceType_Patient); ASSERT_EQ(0u, pub.size()); | |
416 db.GetAllPublicIds(pub, OrthancPluginResourceType_Study); ASSERT_EQ(1u, pub.size()); | |
417 db.GetAllPublicIds(pub, OrthancPluginResourceType_Series); ASSERT_EQ(2u, pub.size()); | |
418 db.GetAllPublicIds(pub, OrthancPluginResourceType_Instance); ASSERT_EQ(0u, pub.size()); | |
209 | 419 ASSERT_EQ(3u, db.GetAllResourcesCount()); |
0 | 420 |
421 ASSERT_EQ(0u, db.GetUnprotectedPatientsCount()); // No patient was inserted | |
422 ASSERT_TRUE(db.IsExistingResource(c)); | |
27
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
423 |
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
424 { |
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
425 // A transaction is needed here for MySQL, as it was not possible |
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
426 // to implement recursive deletion of resources using pure SQL |
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
427 // statements |
207
d9ef3f16e6a2
wrapping transactions in API v3
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
204
diff
changeset
|
428 db.StartTransaction(TransactionType_ReadWrite); |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
429 db.DeleteResource(*output, c); |
27
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
430 db.CommitTransaction(); |
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
431 } |
173176f8cef2
jobs branch has disappeared in orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
26
diff
changeset
|
432 |
0 | 433 ASSERT_FALSE(db.IsExistingResource(c)); |
434 ASSERT_TRUE(db.IsExistingResource(a)); | |
435 ASSERT_TRUE(db.IsExistingResource(b)); | |
209 | 436 ASSERT_EQ(2u, db.GetAllResourcesCount()); |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
437 db.DeleteResource(*output, a); |
209 | 438 ASSERT_EQ(0u, db.GetAllResourcesCount()); |
0 | 439 ASSERT_FALSE(db.IsExistingResource(a)); |
440 ASSERT_FALSE(db.IsExistingResource(b)); | |
441 ASSERT_FALSE(db.IsExistingResource(c)); | |
442 | |
209 | 443 ASSERT_EQ(0u, db.GetAllResourcesCount()); |
0 | 444 ASSERT_EQ(0u, db.GetUnprotectedPatientsCount()); |
445 int64_t p1 = db.CreateResource("patient1", OrthancPluginResourceType_Patient); | |
446 int64_t p2 = db.CreateResource("patient2", OrthancPluginResourceType_Patient); | |
447 int64_t p3 = db.CreateResource("patient3", OrthancPluginResourceType_Patient); | |
448 ASSERT_EQ(3u, db.GetUnprotectedPatientsCount()); | |
449 int64_t r; | |
450 ASSERT_TRUE(db.SelectPatientToRecycle(r)); | |
451 ASSERT_EQ(p1, r); | |
452 ASSERT_TRUE(db.SelectPatientToRecycle(r, p1)); | |
453 ASSERT_EQ(p2, r); | |
454 ASSERT_FALSE(db.IsProtectedPatient(p1)); | |
455 db.SetProtectedPatient(p1, true); | |
456 ASSERT_TRUE(db.IsProtectedPatient(p1)); | |
457 ASSERT_TRUE(db.SelectPatientToRecycle(r)); | |
458 ASSERT_EQ(p2, r); | |
459 db.SetProtectedPatient(p1, false); | |
460 ASSERT_FALSE(db.IsProtectedPatient(p1)); | |
461 ASSERT_TRUE(db.SelectPatientToRecycle(r)); | |
462 ASSERT_EQ(p2, r); | |
201
42990b2dd51b
create IDatabaseBackendOutput only if needed
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
200
diff
changeset
|
463 db.DeleteResource(*output, p2); |
0 | 464 ASSERT_TRUE(db.SelectPatientToRecycle(r, p3)); |
465 ASSERT_EQ(p1, r); | |
466 } |