Mercurial > hg > orthanc-stone
annotate UnitTestsSources/SortedFramesCreateTest.py @ 1871:7053b8a0aaec
upgrade to year 2022
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Tue, 11 Jan 2022 11:18:48 +0100 |
parents | 3889ae96d2e9 |
children |
rev | line source |
---|---|
1477 | 1 #!/usr/bin/env python |
2 | |
1589
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
3 # Stone of Orthanc |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
4 # Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
5 # Department, University Hospital of Liege, Belgium |
1871
7053b8a0aaec
upgrade to year 2022
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1870
diff
changeset
|
6 # Copyright (C) 2017-2022 Osimis S.A., Belgium |
7053b8a0aaec
upgrade to year 2022
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1870
diff
changeset
|
7 # Copyright (C) 2021-2022 Sebastien Jodogne, ICTEAM UCLouvain, Belgium |
1589
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
8 # |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
9 # This program is free software: you can redistribute it and/or |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
10 # modify it under the terms of the GNU Affero General Public License |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
11 # as published by the Free Software Foundation, either version 3 of |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
12 # the License, or (at your option) any later version. |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
13 # |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
14 # This program is distributed in the hope that it will be useful, but |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
15 # WITHOUT ANY WARRANTY; without even the implied warranty of |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
16 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
17 # Affero General Public License for more details. |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
18 # |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
19 # You should have received a copy of the GNU Affero General Public License |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
20 # along with this program. If not, see <http://www.gnu.org/licenses/>. |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
21 |
8c5f9864545f
adding missing headers
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1587
diff
changeset
|
22 |
1477 | 23 import pprint |
24 import requests | |
25 import sys | |
26 | |
27 if len(sys.argv) != 2: | |
28 print('Usage: %s [Orthanc series ID]' % sys.argv[0]) | |
29 print('Example: %s 4d04593b-953ced51-87e93f11-ae4cf03c-25defdcd | xclip -selection c -t text/plain' % sys.argv[0]) | |
30 exit(-1) | |
31 | |
32 SERIES = sys.argv[1] | |
33 | |
34 r = requests.get('http://localhost:8042/series/%s/study' % SERIES) | |
35 r.raise_for_status() | |
36 print(' // From patient %s' % r.json() ['PatientMainDicomTags']['PatientName']) | |
37 | |
38 r = requests.get('http://localhost:8042/series/%s' % SERIES) | |
39 r.raise_for_status() | |
40 | |
41 first = True | |
42 | |
43 for instance in r.json() ['Instances']: | |
44 tags = requests.get('http://localhost:8042/instances/%s/tags?short' % instance) | |
45 tags.raise_for_status() | |
46 | |
47 if first: | |
48 print(''' | |
49 Orthanc::DicomMap tags; | |
50 tags.SetValue(Orthanc::DICOM_TAG_STUDY_INSTANCE_UID, "%s", false); | |
51 tags.SetValue(Orthanc::DICOM_TAG_SERIES_INSTANCE_UID, "%s", false); | |
52 OrthancStone::SortedFrames f; | |
53 ''' % (tags.json() ['0020,000d'], tags.json() ['0020,000e'])) | |
54 first = False | |
55 | |
56 print(' tags.SetValue(Orthanc::DICOM_TAG_SOP_INSTANCE_UID, "%s", false);' % instance) | |
57 | |
58 if '0020,0032' in tags.json(): | |
59 print(' tags.SetValue(Orthanc::DICOM_TAG_IMAGE_POSITION_PATIENT, "%s", false);' % | |
60 tags.json() ['0020,0032'].replace('\\', '\\\\')) | |
61 | |
62 if '0020,0037' in tags.json(): | |
63 print(' tags.SetValue(Orthanc::DICOM_TAG_IMAGE_ORIENTATION_PATIENT, "%s", false);' % | |
64 tags.json() ['0020,0037'].replace('\\', '\\\\')) | |
65 | |
66 if '0020,0013' in tags.json(): | |
67 print(' tags.SetValue(Orthanc::DICOM_TAG_INSTANCE_NUMBER, "%s", false);' % | |
68 tags.json() ['0020,0013'].replace('\\', '\\\\')) | |
69 | |
70 if '0054,1330' in tags.json(): | |
71 print(' tags.SetValue(Orthanc::DICOM_TAG_IMAGE_INDEX, "%s", false);' % | |
72 tags.json() ['0054,1330'].replace('\\', '\\\\')) | |
73 | |
74 print(' f.AddInstance(tags);') | |
75 | |
76 print(' f.Sort();') | |
77 | |
78 r = requests.get('http://localhost:8042/series/%s/ordered-slices' % SERIES) | |
79 r.raise_for_status() | |
80 slices = r.json() ['SlicesShort'] | |
81 | |
82 print(' ASSERT_EQ(%du, f.GetFramesCount());' % len(slices)) | |
83 | |
84 for i in range(len(slices)): | |
1644
4796fb60999e
removing methods from SortedFrames to simplify api
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
1589
diff
changeset
|
85 print(' ASSERT_EQ(f.GetInstanceOfFrame(%d).GetSopInstanceUid(), "%s");' % (i, slices[i][0])) |
1477 | 86 |