Mercurial > hg > orthanc-tests
annotate Plugins/WebDav/Run.py @ 342:bf8369ea3ff1
more tests of webdav
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 15 Oct 2020 17:34:01 +0200 |
parents | 60775134a406 |
children | 203af01474b6 |
rev | line source |
---|---|
338
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
1 #!/usr/bin/python |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
2 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
3 # Orthanc - A Lightweight, RESTful DICOM Store |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
4 # Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
5 # Department, University Hospital of Liege, Belgium |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
6 # Copyright (C) 2017-2020 Osimis S.A., Belgium |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
7 # |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
8 # This program is free software: you can redistribute it and/or |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
9 # modify it under the terms of the GNU General Public License as |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
10 # published by the Free Software Foundation, either version 3 of the |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
11 # License, or (at your option) any later version. |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
12 # |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
13 # This program is distributed in the hope that it will be useful, but |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
14 # WITHOUT ANY WARRANTY; without even the implied warranty of |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
16 # General Public License for more details. |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
17 # |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
18 # You should have received a copy of the GNU General Public License |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
19 # along with this program. If not, see <http://www.gnu.org/licenses/>. |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
20 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
21 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
22 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
23 import argparse |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
24 import easywebdav |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
25 import io |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
26 import os |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
27 import pprint |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
28 import re |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
29 import sys |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
30 import unittest |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
31 |
339 | 32 # https://stackoverflow.com/a/49336105/881731 |
33 if ((3, 0) <= sys.version_info <= (3, 9)): | |
34 from urllib.parse import unquote | |
35 elif ((2, 0) <= sys.version_info <= (2, 9)): | |
36 from urlparse import unquote | |
37 | |
338
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
38 sys.path.append(os.path.join(os.path.dirname(__file__), '..', '..', 'Tests')) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
39 from Toolbox import * |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
40 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
41 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
42 ## |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
43 ## Parse the command-line arguments |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
44 ## |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
45 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
46 parser = argparse.ArgumentParser(description = 'Run the integration tests for the patient recycling behavior.') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
47 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
48 parser.add_argument('--server', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
49 default = 'localhost', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
50 help = 'Address of the Orthanc server to test') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
51 parser.add_argument('--rest', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
52 type = int, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
53 default = 8042, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
54 help = 'Port to the REST API') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
55 parser.add_argument('--username', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
56 default = 'alice', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
57 help = 'Username to the REST API') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
58 parser.add_argument('--password', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
59 default = 'orthanctest', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
60 help = 'Password to the REST API') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
61 parser.add_argument('--force', help = 'Do not warn the user', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
62 action = 'store_true') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
63 parser.add_argument('options', metavar = 'N', nargs = '*', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
64 help='Arguments to Python unittest') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
65 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
66 args = parser.parse_args() |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
67 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
68 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
69 ## |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
70 ## Configure the testing context |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
71 ## |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
72 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
73 if not args.force: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
74 print(""" |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
75 WARNING: This test will remove all the content of your |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
76 Orthanc instance running on %s! |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
77 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
78 Are you sure ["yes" to go on]?""" % args.server) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
79 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
80 if sys.stdin.readline().strip() != 'yes': |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
81 print('Aborting...') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
82 exit(0) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
83 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
84 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
85 ORTHANC = DefineOrthanc(server = args.server, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
86 username = args.username, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
87 password = args.password, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
88 restPort = args.rest) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
89 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
90 WEBDAV = easywebdav.connect(args.server, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
91 port = args.rest, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
92 username = args.username, |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
93 password = args.password) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
94 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
95 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
96 ## |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
97 ## The tests |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
98 ## |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
99 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
100 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
101 def ListFiles(path, recursive): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
102 result = [ ] |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
103 for i in WEBDAV.ls(path): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
104 if i.name == path: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
105 pass |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
106 elif i.contenttype == '': |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
107 if recursive: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
108 result += ListFiles(i.name + '/', True) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
109 else: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
110 result.append(i.name) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
111 return result |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
112 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
113 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
114 def GetFileInfo(path): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
115 for i in WEBDAV.ls(path[0 : path.rfind('/')]): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
116 if i.name == path: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
117 return i |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
118 raise Exception('Cannot find: %s' % path) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
119 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
120 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
121 def DownloadFile(path): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
122 with tempfile.NamedTemporaryFile(delete = False) as f: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
123 f.close() |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
124 WEBDAV.download(path, f.name) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
125 with open(f.name, 'rb') as g: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
126 result = g.read() |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
127 os.unlink(f.name) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
128 return result |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
129 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
130 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
131 class Orthanc(unittest.TestCase): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
132 def setUp(self): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
133 if (sys.version_info >= (3, 0)): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
134 # Remove annoying warnings about unclosed socket in Python 3 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
135 import warnings |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
136 warnings.simplefilter("ignore", ResourceWarning) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
137 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
138 DropOrthanc(ORTHANC) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
139 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
140 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
141 def test_root(self): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
142 self.assertEqual(6, len(WEBDAV.ls('/webdav/'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
143 for i in WEBDAV.ls('/webdav/'): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
144 self.assertTrue(i.name in [ |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
145 '/webdav/', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
146 '/webdav/by-dates', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
147 '/webdav/by-patients', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
148 '/webdav/by-studies', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
149 '/webdav/by-uids', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
150 '/webdav/uploads' |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
151 ]) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
152 self.assertEqual(0, i.size) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
153 self.assertEqual('', i.contenttype) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
154 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
155 patients = WEBDAV.ls('/webdav/by-patients/') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
156 self.assertEqual(1, len(patients)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
157 self.assertEqual(patients[0].name, '/webdav/by-patients/') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
158 self.assertEqual(0, patients[0].size) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
159 self.assertEqual('', patients[0].contenttype) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
160 |
342
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
161 self.assertRaises(Exception, lambda: WEBDAV.delete('/webdav/nope')) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
162 self.assertRaises(Exception, lambda: WEBDAV.delete('/webdav/by-uids')) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
163 |
338
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
164 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
165 def test_upload(self): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
166 self.assertEqual(0, len(ListFiles('/webdav/uploads/', True))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
167 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
168 uploads = WEBDAV.ls('/webdav/uploads/') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
169 for i in uploads: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
170 self.assertEqual(i.contenttype, '') # Only folders are allowed |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
171 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
172 self.assertEqual(0, len(DoGet(ORTHANC, '/studies'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
173 WEBDAV.upload(GetDatabasePath('DummyCT.dcm'), '/webdav/uploads/DummyCT.dcm') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
174 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
175 while len(ListFiles('/webdav/uploads/', True)) > 1: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
176 time.sleep(0.1) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
177 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
178 instances = DoGet(ORTHANC, '/instances?expand') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
179 self.assertEqual(1, len(instances)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
180 self.assertEqual('1.2.840.113619.2.176.2025.1499492.7040.1171286242.109', |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
181 instances[0]['MainDicomTags']['SOPInstanceUID']) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
182 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
183 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
184 def test_upload_folders(self): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
185 self.assertEqual(0, len(ListFiles('/webdav/uploads/', True))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
186 self.assertEqual(0, len(DoGet(ORTHANC, '/studies'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
187 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
188 try: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
189 WEBDAV.mkdir('/webdav/uploads/a') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
190 except: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
191 pass |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
192 try: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
193 WEBDAV.mkdir('/webdav/uploads/b') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
194 except: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
195 pass |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
196 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
197 WEBDAV.upload(GetDatabasePath('DummyCT.dcm'), '/webdav/uploads/a/DummyCT.dcm') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
198 WEBDAV.upload(GetDatabasePath('ColorTestMalaterre.dcm'), '/webdav/uploads/b/ColorTestMalaterre.dcm') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
199 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
200 while len(ListFiles('/webdav/uploads/', True)) > 1: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
201 time.sleep(0.1) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
202 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
203 self.assertEqual(2, len(DoGet(ORTHANC, '/instances'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
204 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
205 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
206 def test_by_uids(self): |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
207 self.assertEqual(1, len(WEBDAV.ls('/webdav/by-uids/'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
208 self.assertEqual(0, len(ListFiles('/webdav/by-uids/', True))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
209 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
210 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
211 i = UploadInstance(ORTHANC, 'DummyCT.dcm')['ID'] |
339 | 212 tags = DoGet(ORTHANC, '/instances/%s/tags?simplify' % i) |
213 studyUid = tags['StudyInstanceUID'] | |
214 seriesUid = tags['SeriesInstanceUID'] | |
215 sopUid = tags['SOPInstanceUID'] | |
338
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
216 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
217 self.assertEqual(0, len(ListFiles('/webdav/by-uids/', False))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
218 self.assertEqual(1, len(ListFiles('/webdav/by-uids/%s/' % studyUid, False))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
219 self.assertEqual(2, len(ListFiles('/webdav/by-uids/%s/%s/' % (studyUid, seriesUid), False))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
220 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
221 content = ListFiles('/webdav/by-uids/', True) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
222 self.assertEqual(3, len(content)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
223 self.assertTrue(('/webdav/by-uids/%s/study.json' % studyUid) in content) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
224 self.assertTrue(('/webdav/by-uids/%s/%s/series.json' % (studyUid, seriesUid)) in content) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
225 self.assertTrue(('/webdav/by-uids/%s/%s/%s.dcm' % (studyUid, seriesUid, sopUid)) in content) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
226 |
342
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
227 # Deleting the virtual files "study|series.json" has no |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
228 # effect, but is needed for recursive DELETE in some file explorers |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
229 WEBDAV.delete('/webdav/by-uids/%s/study.json' % studyUid) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
230 WEBDAV.delete('/webdav/by-uids/%s/%s/series.json' % (studyUid, seriesUid)) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
231 |
338
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
232 info = GetFileInfo('/webdav/by-uids/%s/study.json' % studyUid) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
233 self.assertEqual(info.contenttype, 'application/json') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
234 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
235 info = GetFileInfo('/webdav/by-uids/%s/%s/series.json' % (studyUid, seriesUid)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
236 self.assertEqual(info.contenttype, 'application/json') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
237 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
238 info = GetFileInfo('/webdav/by-uids/%s/%s/%s.dcm' % (studyUid, seriesUid, sopUid)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
239 self.assertEqual(info.contenttype, 'application/dicom') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
240 self.assertEqual(info.size, os.stat(GetDatabasePath('DummyCT.dcm')).st_size) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
241 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
242 a = DownloadFile('/webdav/by-uids/%s/%s/%s.dcm' % (studyUid, seriesUid, sopUid)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
243 self.assertEqual(len(a), info.size) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
244 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
245 with open(GetDatabasePath('DummyCT.dcm'), 'rb') as f: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
246 self.assertEqual(a, f.read()) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
247 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
248 self.assertEqual(studyUid, json.loads(DownloadFile('/webdav/by-uids/%s/study.json' % studyUid)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
249 ['MainDicomTags']['StudyInstanceUID']) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
250 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
251 self.assertEqual(seriesUid, json.loads(DownloadFile('/webdav/by-uids/%s/%s/series.json' % (studyUid, seriesUid))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
252 ['MainDicomTags']['SeriesInstanceUID']) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
253 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
254 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
255 WEBDAV.delete('/webdav/by-uids/%s/%s/%s.dcm' % (studyUid, seriesUid, sopUid)) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
256 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) |
339 | 257 self.assertEqual(0, len(ListFiles('/webdav/by-uids/', True))) |
258 | |
259 | |
260 def test_by_patients(self): | |
261 self.assertEqual(0, len(ListFiles('/webdav/by-dates/', True))) | |
262 self.assertEqual(0, len(ListFiles('/webdav/by-patients/', True))) | |
263 self.assertEqual(0, len(ListFiles('/webdav/by-studies/', True))) | |
264 self.assertEqual(0, len(ListFiles('/webdav/by-uids/', True))) | |
265 | |
266 self.assertEqual(1, len(WEBDAV.ls('/webdav/by-patients/'))) | |
267 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) | |
268 | |
269 i = UploadInstance(ORTHANC, 'DummyCT.dcm')['ID'] | |
270 tags = DoGet(ORTHANC, '/instances/%s/tags?simplify' % i) | |
271 patient = '%s - %s' % (tags['PatientID'], tags['PatientName']) | |
272 study = '%s - %s' % (tags['StudyDate'], tags['StudyDescription']) | |
273 series = '%s - %s' % (tags['Modality'], tags['SeriesDescription']) | |
274 self.assertEqual('ozp00SjY2xG - KNIX', patient) | |
275 self.assertEqual('20070101 - Knee (R)', study) | |
276 self.assertEqual('MR - AX. FSE PD', series) | |
277 | |
278 self.assertEqual(1, len(ListFiles('/webdav/by-dates/', True))) | |
279 self.assertEqual(1, len(ListFiles('/webdav/by-patients/', True))) | |
280 self.assertEqual(1, len(ListFiles('/webdav/by-studies/', True))) | |
281 self.assertEqual(3, len(ListFiles('/webdav/by-uids/', True))) | |
282 | |
283 self.assertEqual(0, len(ListFiles('/webdav/by-patients/', False))) | |
284 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-patients/'))) | |
285 self.assertEqual(0, len(ListFiles('/webdav/by-patients/%s' % patient, False))) | |
286 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-patients/%s' % patient))) | |
287 self.assertEqual(0, len(ListFiles('/webdav/by-patients/%s/%s' % (patient, study), False))) | |
288 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-patients/%s/%s' % (patient, study)))) | |
289 | |
290 folder = '/webdav/by-patients/%s/%s/%s' % (patient, study, series) | |
291 self.assertEqual(1, len(ListFiles(folder, False))) | |
292 self.assertEqual(2, len(WEBDAV.ls(folder))) | |
293 self.assertEqual('%s/%s.dcm' % (folder, i), unquote(ListFiles(folder, False) [0])) | |
294 | |
340
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
295 files = ListFiles('/webdav/by-patients/', True) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
296 self.assertEqual(1, len(files)) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
297 self.assertEqual('%s/%s.dcm' % (folder, i), unquote(files[0])) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
298 |
339 | 299 a = DownloadFile('%s/%s.dcm' % (folder, i)) |
300 with open(GetDatabasePath('DummyCT.dcm'), 'rb') as f: | |
301 self.assertEqual(a, f.read()) | |
302 | |
303 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) | |
304 WEBDAV.delete('%s/%s.dcm' % (folder, i)) | |
305 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) | |
306 | |
307 self.assertEqual(0, len(ListFiles('/webdav/by-dates/', True))) | |
308 self.assertEqual(0, len(ListFiles('/webdav/by-patients/', True))) | |
309 self.assertEqual(0, len(ListFiles('/webdav/by-studies/', True))) | |
310 self.assertEqual(0, len(ListFiles('/webdav/by-uids/', True))) | |
311 | |
312 | |
313 def test_by_studies(self): | |
314 self.assertEqual(0, len(ListFiles('/webdav/by-studies/', True))) | |
315 self.assertEqual(1, len(WEBDAV.ls('/webdav/by-patients/'))) | |
316 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) | |
317 | |
318 i = UploadInstance(ORTHANC, 'DummyCT.dcm')['ID'] | |
319 tags = DoGet(ORTHANC, '/instances/%s/tags?simplify' % i) | |
320 study = '%s - %s - %s' % (tags['PatientID'], tags['PatientName'], tags['StudyDescription']) | |
321 series = '%s - %s' % (tags['Modality'], tags['SeriesDescription']) | |
322 self.assertEqual('ozp00SjY2xG - KNIX - Knee (R)', study) | |
323 self.assertEqual('MR - AX. FSE PD', series) | |
324 | |
325 self.assertEqual(0, len(ListFiles('/webdav/by-studies/', False))) | |
326 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-studies/'))) | |
327 self.assertEqual(0, len(ListFiles('/webdav/by-studies/%s' % study, False))) | |
328 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-studies/%s' % study))) | |
329 | |
330 folder = '/webdav/by-studies/%s/%s' % (study, series) | |
331 self.assertEqual(1, len(ListFiles(folder, False))) | |
332 self.assertEqual(2, len(WEBDAV.ls(folder))) | |
333 self.assertEqual('%s/%s.dcm' % (folder, i), unquote(ListFiles(folder, False) [0])) | |
334 | |
340
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
335 files = ListFiles('/webdav/by-studies/', True) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
336 self.assertEqual(1, len(files)) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
337 self.assertEqual('%s/%s.dcm' % (folder, i), unquote(files[0])) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
338 |
339 | 339 a = DownloadFile('%s/%s.dcm' % (folder, i)) |
340 with open(GetDatabasePath('DummyCT.dcm'), 'rb') as f: | |
341 self.assertEqual(a, f.read()) | |
342 | |
343 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) | |
344 WEBDAV.delete('%s/%s.dcm' % (folder, i)) | |
345 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) | |
346 self.assertEqual(0, len(ListFiles('/webdav/by-studies/', True))) | |
347 | |
348 | |
340
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
349 def test_by_dates(self): |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
350 self.assertEqual(0, len(ListFiles('/webdav/by-dates/', True))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
351 self.assertEqual(1, len(WEBDAV.ls('/webdav/by-patients/'))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
352 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
353 |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
354 i = UploadInstance(ORTHANC, 'DummyCT.dcm')['ID'] |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
355 tags = DoGet(ORTHANC, '/instances/%s/tags?simplify' % i) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
356 year = tags['StudyDate'][0:4] |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
357 month = tags['StudyDate'][4:6] |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
358 study = '%s - %s - %s' % (tags['PatientID'], tags['PatientName'], tags['StudyDescription']) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
359 series = '%s - %s' % (tags['Modality'], tags['SeriesDescription']) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
360 self.assertEqual('ozp00SjY2xG - KNIX - Knee (R)', study) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
361 self.assertEqual('MR - AX. FSE PD', series) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
362 |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
363 self.assertEqual(0, len(ListFiles('/webdav/by-dates/', False))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
364 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-dates/'))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
365 self.assertEqual(0, len(ListFiles('/webdav/by-dates/%s' % year, False))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
366 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-dates/%s' % year))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
367 self.assertEqual(0, len(ListFiles('/webdav/by-dates/%s/%s-%s' % (year, year, month), False))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
368 self.assertEqual(2, len(WEBDAV.ls('/webdav/by-dates/%s/%s-%s' % (year, year, month)))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
369 |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
370 folder = '/webdav/by-dates/%s/%s-%s/%s/%s' % (year, year, month, study, series) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
371 self.assertEqual(1, len(ListFiles(folder, False))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
372 self.assertEqual(2, len(WEBDAV.ls(folder))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
373 self.assertEqual('%s/%s.dcm' % (folder, i), unquote(ListFiles(folder, False) [0])) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
374 |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
375 files = ListFiles('/webdav/by-dates/', True) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
376 self.assertEqual(1, len(files)) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
377 self.assertEqual('%s/%s.dcm' % (folder, i), unquote(files[0])) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
378 |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
379 a = DownloadFile('%s/%s.dcm' % (folder, i)) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
380 with open(GetDatabasePath('DummyCT.dcm'), 'rb') as f: |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
381 self.assertEqual(a, f.read()) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
382 |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
383 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
384 WEBDAV.delete('%s/%s.dcm' % (folder, i)) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
385 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) |
60775134a406
finalized webdav standalone tests
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
339
diff
changeset
|
386 self.assertEqual(0, len(ListFiles('/webdav/by-dates/', True))) |
339 | 387 |
342
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
388 |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
389 def test_delete_folder(self): |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
390 # These deletes should have no effect |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
391 UploadInstance(ORTHANC, 'DummyCT.dcm') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
392 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
393 WEBDAV.delete('/webdav/by-uids/1.2.840.113619.2.176.2025.1499492.7391.1171285944.390/study.json') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
394 WEBDAV.delete('/webdav/by-uids/1.2.840.113619.2.176.2025.1499492.7391.1171285944.390/1.2.840.113619.2.176.2025.1499492.7391.1171285944.394/series.json') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
395 WEBDAV.delete('/webdav/by-dates/2007/2007-02') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
396 WEBDAV.delete('/webdav/by-dates/2006') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
397 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
398 |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
399 for path in [ |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
400 '/webdav/by-uids/1.2.840.113619.2.176.2025.1499492.7391.1171285944.390/1.2.840.113619.2.176.2025.1499492.7391.1171285944.394/1.2.840.113619.2.176.2025.1499492.7040.1171286242.109.dcm', |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
401 '/webdav/by-patients/ozp00SjY2xG - KNIX/20070101 - Knee (R)/MR - AX. FSE PD/66a662ce-7430e543-bad44d47-0dc5a943-ec7a538d.dcm', |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
402 '/webdav/by-studies/ozp00SjY2xG - KNIX - Knee (R)/MR - AX. FSE PD/66a662ce-7430e543-bad44d47-0dc5a943-ec7a538d.dcm', |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
403 '/webdav/by-dates/2007/2007-01/ozp00SjY2xG - KNIX - Knee (R)/MR - AX. FSE PD/66a662ce-7430e543-bad44d47-0dc5a943-ec7a538d.dcm', |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
404 ]: |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
405 tokens = path.split('/') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
406 for i in range(4, len(tokens) + 1): |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
407 p = '/'.join(tokens[0:i]) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
408 UploadInstance(ORTHANC, 'DummyCT.dcm') |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
409 self.assertEqual(1, len(DoGet(ORTHANC, '/instances'))) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
410 WEBDAV.delete(p) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
411 self.assertEqual(0, len(DoGet(ORTHANC, '/instances'))) |
bf8369ea3ff1
more tests of webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
340
diff
changeset
|
412 |
339 | 413 |
338
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
414 try: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
415 print('\nStarting the tests...') |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
416 unittest.main(argv = [ sys.argv[0] ] + args.options) |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
417 |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
418 finally: |
edaeb57bf01f
creating tests for webdav
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff
changeset
|
419 print('\nDone') |