annotate Tests/Run.py @ 5:19eb87a45685

test_images
author Sebastien Jodogne <s.jodogne@gmail.com>
date Wed, 17 Jun 2015 10:42:24 +0200
parents 292a46fe374c
children 6d645b3011e1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
1 #!/usr/bin/python
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
3 # Orthanc - A Lightweight, RESTful DICOM Store
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
4 # Copyright (C) 2012-2015 Sebastien Jodogne, Medical Physics
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
5 # Department, University Hospital of Liege, Belgium
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
6 #
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
7 # This program is free software: you can redistribute it and/or
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
8 # modify it under the terms of the GNU General Public License as
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
9 # published by the Free Software Foundation, either version 3 of the
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
10 # License, or (at your option) any later version.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
11 #
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
12 # This program is distributed in the hope that it will be useful, but
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
15 # General Public License for more details.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
16 #
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
17 # You should have received a copy of the GNU General Public License
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
18 # along with this program. If not, see <http://www.gnu.org/licenses/>.
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
19
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
20
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
21 import re
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
22 import sys
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
23 import argparse
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
24 import subprocess
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
25 import unittest
3
2dbba2e6aa4b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 2
diff changeset
26 import pprint
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
27
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
28 from Tests import *
5
19eb87a45685 test_images
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 4
diff changeset
29 from Toolbox import DoGet
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
30
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
31
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
32 ##
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
33 ## Parse the command-line arguments
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
34 ##
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
35
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
36 parser = argparse.ArgumentParser(description = 'Run the integration tests on some instance of Orthanc.')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
37 parser.add_argument('--server',
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
38 default = GetDockerHostAddress(),
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
39 help = 'Address of the Orthanc server to test')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
40 parser.add_argument('--aet',
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
41 default = 'ORTHANC',
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
42 help = 'AET of the Orthanc instance to test')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
43 parser.add_argument('--dicom',
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
44 type = int,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
45 default = 4242,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
46 help = 'DICOM port of the Orthanc instance to test')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
47 parser.add_argument('--rest',
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
48 type = int,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
49 default = 8042,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
50 help = 'Port to the REST API')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
51 parser.add_argument('--username',
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
52 default = 'alice',
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
53 help = 'Username to the REST API')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
54 parser.add_argument('--password',
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
55 default = 'orthanctest',
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
56 help = 'Password to the REST API')
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
57 parser.add_argument('--force', help = 'Do not warn the user',
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
58 action = 'store_true')
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
59
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
60 args = parser.parse_args()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
61
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
62 if not args.force:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
63 print("""
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
64 WARNING: This test will remove all the content of your
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
65 Orthanc instance running on %s!
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
66
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
67 Are you sure ["yes" to go on]?""" % args.server)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
68
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
69 if sys.stdin.readline().strip() != 'yes':
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
70 print('Aborting...')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
71 exit(0)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
72
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
73
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
74
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
75 ##
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
76 ## Generate the configuration file for the anciliary instance of
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
77 ## Orthanc
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
78 ##
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
79
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
80 CONFIG = '/tmp/Configuration.json'
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
81 subprocess.check_call([ 'Orthanc', '--config=%s' % CONFIG ])
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
82
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
83 with open(CONFIG, 'r') as f:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
84 config = f.read()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
85
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
86 config = re.sub(r'("StorageDirectory"\s*:)\s*".*?"', r'\1 "/tmp/OrthancStorage"', config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
87 config = re.sub(r'("IndexDirectory"\s*:)\s*".*?"', r'\1 "/tmp/OrthancStorage"', config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
88 config = re.sub(r'("DicomAet"\s*:)\s*".*?"', r'\1 "ORTHANCTEST"', config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
89 config = re.sub(r'("RemoteAccessAllowed"\s*:)\s*false', r'\1 true', config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
90 config = re.sub(r'("AuthenticationEnabled"\s*:)\s*false', r'\1 true', config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
91 config = re.sub(r'("RegisteredUsers"\s*:)\s*{', r'\1 { "alice" : [ "orthanctest" ]', config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
92 config = re.sub(r'("DicomModalities"\s*:)\s*{', r'\1 { "orthanc" : [ "%s", "%s", "%s" ]' %
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
93 (args.aet, args.server, args.dicom), config)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
94
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
95 localOrthanc = ExternalCommandThread([
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
96 'Orthanc', CONFIG, #'--verbose'
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
97 ])
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
98
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
99
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
100 LOCAL = DefineOrthanc(aet = 'ORTHANCTEST')
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
101 REMOTE = DefineOrthanc(url = 'http://%s:%d/' % (args.server, args.rest),
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
102 username = args.username,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
103 password = args.password,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
104 aet = args.aet,
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
105 dicomPort = args.dicom)
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
106
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
107
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
108
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
109 print('Parameters of the instance of Orthanc to test:')
3
2dbba2e6aa4b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 2
diff changeset
110 pprint.pprint(REMOTE)
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
111 print('')
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
112
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
113
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
114 print('Waiting for the internal Orthanc to start...')
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
115 while True:
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
116 try:
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
117 DoGet(LOCAL, '/instances')
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
118 break
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
119 except:
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
120 time.sleep(0.1)
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
121
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
122
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
123 try:
3
2dbba2e6aa4b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 2
diff changeset
124 print('\nStarting the tests...')
2
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 1
diff changeset
125 SetOrthancParameters(LOCAL, REMOTE)
5
19eb87a45685 test_images
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 4
diff changeset
126 unittest.main(argv = [ sys.argv[0] ])
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
127
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
128 finally:
3
2dbba2e6aa4b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 2
diff changeset
129 print('\nDone')
2dbba2e6aa4b reorganization
Sebastien Jodogne <s.jodogne@gmail.com>
parents: 2
diff changeset
130
1
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
131 # The tests have stopped or "Ctrl-C" has been hit
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
132 try:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
133 localOrthanc.stop()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
134 except:
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
diff changeset
135 pass