# HG changeset patch # User Sebastien Jodogne # Date 1440497387 -7200 # Node ID 4fa03fcbff5ea274e0d4e8813bef6fc2517e309a # Parent 525a2f57ec94c8cf6cb3304b9d1bcdd9639a6435# Parent 8fb14554b27ce6ec378baa6a875443129d8a8788 merge diff -r 525a2f57ec94 -r 4fa03fcbff5e Tests/Tests.py --- a/Tests/Tests.py Tue Aug 25 12:09:31 2015 +0200 +++ b/Tests/Tests.py Tue Aug 25 12:09:47 2015 +0200 @@ -1222,6 +1222,10 @@ png = GetImage(_REMOTE, '/instances/%s/preview' % i['ID']) self.assertEqual((5, 5), png.size) + j = DoGet(_REMOTE, i['Path']) + self.assertEqual('Instance', j['Type']) + self.assertEqual(j['ID'], i['ID']) + def test_pilates(self): # "SCU failed error when accessing orthanc with osirix" by @@ -2171,3 +2175,40 @@ self.assertEqual(ComputeMD5(b), ComputeMD5(pdf)) self.assertRaises(Exception, lambda: DoGet(_REMOTE, '/instances/%s/pdf' % brainixInstance)) + + + def test_create_series(self): + i = DoPost(_REMOTE, '/tools/create-dicom', + json.dumps({ + 'Tags' : { + 'SpecificCharacterSet' : 'ISO_IR 100', + 'PatientName' : 'Sébastien Jodogne', + 'Modality' : 'CT', + }, + 'Content' : [ + { + 'Content': '', # red dot in RGBA + 'Tags' : { 'ImageComments' : 'Tutu' } + }, + '', + ] + })) + + s = DoGet(_REMOTE, i['Path']) + self.assertEqual('Series', s['Type']) + self.assertEqual(s['ID'], i['ID']) + self.assertEqual(2, len(s['Instances'])) + self.assertEqual(2, s['ExpectedNumberOfInstances']) + self.assertEqual('Complete', s['Status']) + + a = DoGet(_REMOTE, '/instances/%s/tags?simplify' % s['Instances'][0]) + b = DoGet(_REMOTE, '/instances/%s/tags?simplify' % s['Instances'][1]) + self.assertTrue('ImageComments' in a or 'ImageComments' in b) + if 'ImageComments' in a: + self.assertEqual('Tutu', a['ImageComments']) + else: + self.assertEqual('Tutu', b['ImageComments']) + + patient = DoGet(_REMOTE, '/instances/%s/patient' % s['Instances'][0]) + self.assertEqual(patient['MainDicomTags']['PatientName'].encode('utf-8'), + 'Sébastien Jodogne')