]> Creatis software - gdcm.git/blob - Testing/CMakeLists.txt
ENH: Add new test using dciodvfy from the dicom3tools package (David Clunie)
[gdcm.git] / Testing / CMakeLists.txt
1 # CMakeLists for Testing purpose
2 # Cxx file that need a file to run should be place aproprietly
3
4 SET(CXX_TEST_PATH ${EXECUTABLE_OUTPUT_PATH})
5
6 SET(GDCM_TESTS ${CXX_TEST_PATH}/gdcmTests)
7
8 # add test that does not require data:
9 # They usally return if no argument is given
10 SET(TEST_SOURCES
11   TestBug.cxx
12   TestHash.cxx
13   TestTS.cxx
14   TestVR.cxx
15   TestUtil.cxx
16   TestDicomString.cxx
17   TestDict.cxx
18   TestWriteSimple.cxx
19 )
20
21 # add tests that require data
22 IF (GDCM_DATA_ROOT)
23   SET(TEST_SOURCES ${TEST_SOURCES}     
24     TestReadWriteReadCompare.cxx     # includes generated gdcmDataImages.h 
25     PrintAllDocument.cxx             # includes generated gdcmDataImages.h
26     TestAllReadCompareDicom.cxx      # includes generated gdcmDataImages.h
27     TestAllEntryVerify.cxx           # includes generated gdcmDataImages.h
28     #TestChangeHeader.cxx
29     TestCopyDicom.cxx                # includes generated gdcmDataImages.h 
30     TestCopyRescaleDicom.cxx         # includes generated gdcmDataImages.h 
31     TestDicomDir.cxx                 # require DICOMDIR
32     BuildUpDicomDir.cxx              # writes a file named "NewDICOMDIR"
33     makeDicomDir.cxx                 # writes a file named "NewDICOMDIR"
34     TestDirList.cxx
35   )
36   # add test that require VTK:
37   IF(GDCM_VTK)
38     # Include the VTK library
39     INCLUDE(${VTK_USE_FILE})
40
41     INCLUDE_DIRECTORIES(
42       ${GDCM_SOURCE_DIR}/vtk/
43       )
44     SET(TEST_SOURCES ${TEST_SOURCES}
45       VTKTestRead.cxx
46       VTKTestReadSeq.cxx
47       VTKTestWrite.cxx
48       )
49   ENDIF(GDCM_VTK)
50 ENDIF (GDCM_DATA_ROOT)
51
52
53
54 # include stuff
55 INCLUDE_DIRECTORIES(
56   ${GDCM_SOURCE_DIR}/src/
57   ${GDCM_BINARY_DIR}/
58 )
59
60 CREATE_TEST_SOURCELIST(Tests gdcmTests.cxx ${TEST_SOURCES})
61 ADD_EXECUTABLE(gdcmTests ${Tests})
62 IF(GDCM_VTK)
63   TARGET_LINK_LIBRARIES(gdcmTests vtkgdcm vtkRendering)
64 ELSE(GDCM_VTK)
65   TARGET_LINK_LIBRARIES(gdcmTests gdcm)
66 ENDIF(GDCM_VTK)
67
68 SET (TestsToRun ${Tests})
69 REMOVE (TestsToRun gdcmTests.cxx)
70
71 # Loop over files and create executables
72 FOREACH(file ${TEST_SOURCES})
73   GET_FILENAME_COMPONENT(name ${file} NAME_WE)
74 #  IF (GDCM_DATA_ROOT)
75 #    ADD_TEST(${name} ${GDCM_TESTS} ${name}
76 #        -D ${GDCM_DATA_ROOT}
77 #        -T ${GDCM_BINARY_DIR}/Testing/Temporary
78 #        -V Baseline/gdcm/${name}.png)
79 #  ELSE (GDCM_DATA_ROOT)
80     ADD_TEST(${name} ${GDCM_TESTS} ${name})
81 #  ENDIF (GDCM_DATA_ROOT)
82 ENDFOREACH(file ${TEST_SOURCES})
83
84 #-----------------------------------------------------------------------------
85
86 # We need to test the reading of all dicom images in the gdcmData directory
87 # First parse this directory and extract all images
88
89 IF(${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 1.9)
90   FILE(GLOB GDCM_DATA_IMAGES_GLOB
91     "${GDCM_DATA_ROOT}/*.acr"
92     "${GDCM_DATA_ROOT}/*.dcm"
93     "${GDCM_DATA_ROOT}/*.nema"
94     "${GDCM_DATA_ROOT}/*.ima"
95     )
96   FILE(GLOB GDCM_DATA_SEQ_IMAGES_GLOB
97     "${GDCM_DATA_ROOT}/*FileSeq0.acr"
98     "${GDCM_DATA_ROOT}/*FileSeq0.dcm"
99     "${GDCM_DATA_ROOT}/*FileSeq0.nema"
100     "${GDCM_DATA_ROOT}/*FileSeq0.ima"
101     )
102 ELSE(${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 1.9)   
103   # Since there is a bug in cmake 1.8.3, I'll have to do two separate globs
104   FILE(GLOB GDCM_DATA_IMAGES_GLOB_ACR
105     "${GDCM_DATA_ROOT}/*.acr"
106     )
107   FILE(GLOB GDCM_DATA_IMAGES_GLOB_DCM
108     "${GDCM_DATA_ROOT}/*.dcm"
109     )
110   FILE(GLOB GDCM_DATA_IMAGES_GLOB_NEMA
111     "${GDCM_DATA_ROOT}/*.nema"
112     )
113   FILE(GLOB GDCM_DATA_IMAGES_GLOB_IMA
114     "${GDCM_DATA_ROOT}/*.ima"
115     )
116   SET(GDCM_DATA_IMAGES_GLOB 
117     ${GDCM_DATA_IMAGES_GLOB_DCM} ${GDCM_DATA_IMAGES_GLOB_ACR}
118     ${GDCM_DATA_IMAGES_GLOB_NEMA} ${GDCM_DATA_IMAGES_GLOB_IMA})
119
120   FILE(GLOB GDCM_DATA_SEQ_IMAGES_GLOB_ACR
121     "${GDCM_DATA_ROOT}/*FileSeq0.acr"
122     )
123   FILE(GLOB GDCM_DATA_SEQ_IMAGES_GLOB_DCM
124     "${GDCM_DATA_ROOT}/*FileSeq0.dcm"
125     )
126   FILE(GLOB GDCM_DATA_SEQ_IMAGES_GLOB_NEMA
127     "${GDCM_DATA_ROOT}/*FileSeq0.nema"
128     )
129   FILE(GLOB GDCM_DATA_SEQ_IMAGES_GLOB_IMA
130     "${GDCM_DATA_ROOT}/*FileSeq0.ima"
131     )
132   SET(GDCM_DATA_SEQ_IMAGES_GLOB 
133     ${GDCM_DATA_SEQ_IMAGES_GLOB_DCM} ${GDCM_DATA_SEQ_IMAGES_GLOB_ACR}
134     ${GDCM_DATA_SEQ_IMAGES_GLOB_NEMA} ${GDCM_DATA_SEQ_IMAGES_GLOB_IMA})
135 ENDIF(${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 1.9)   
136
137 # Black list of images known to break lots of readers (efilm, xmedcon ...):
138 SET(BLACK_LIST
139   # serial killer (also segfaults vtkgdcmViewer, but NOT PrintFile)
140   #"gdcm-JPEG-LossLessThoravision.dcm"
141
142   # Mathieu: temporarily remove as it kills my gnome session (but not kde)
143   # JPR: also breaks TestReadWriteReadCompare : Pixel differ (as expanded
144   #      in memory)  
145   #"KODAK-12-MONO1-Odd_Terminated_Sequence.dcm"
146   
147   # Multiframe Papyrus format image
148   # Just to remember this format exist, and is gdcm::Header compliant
149   # (NOT gdcm::File ...)
150   # any contribution is welcome
151   "PET-cardio-Multiframe-Papyrus.dcm" 
152   )
153
154
155 # Add a special test that requires dciodvfy from dicom3tools
156 INCLUDE(${GDCM_SOURCE_DIR}/FindDicom3Tools.cmake)
157
158 # This is a GLOB expression, change it into a list separated with a comma and \n
159 SET(GDCM_DATA_IMAGES)
160 FOREACH(filename ${GDCM_DATA_IMAGES_GLOB})
161   GET_FILENAME_COMPONENT(filename_temp ${filename} NAME)
162   IF(DCIODVFY_FOUND)
163     ADD_TEST("Clunie-${filename_temp}" "${DCIODVFY_EXECUTABLE}" "${filename}")
164   ENDIF(DCIODVFY_FOUND)
165   STRING(REGEX MATCH ${filename_temp} bad_dicom ${BLACK_LIST})
166   IF(NOT bad_dicom)
167     SET(GDCM_DATA_IMAGES "${GDCM_DATA_IMAGES}\n\"${filename_temp}\",")
168   ENDIF(NOT bad_dicom)
169 ENDFOREACH(filename)
170
171 SET(GDCM_DATA_SEQ_IMAGES)
172 FOREACH(filename ${GDCM_DATA_SEQ_IMAGES_GLOB})
173   GET_FILENAME_COMPONENT(filename_temp ${filename} NAME)
174   STRING(REGEX MATCH ${filename_temp} bad_dicom ${BLACK_LIST})
175   IF(NOT bad_dicom)
176     STRING(REGEX REPLACE "(.*)FileSeq0(.*)" "\\1FileSeq%d\\2" filename_temp2 ${filename_temp})
177
178     SET(GDCM_DATA_SEQ_IMAGES "${GDCM_DATA_SEQ_IMAGES}\n\"${filename_temp2}\",")
179   ENDIF(NOT bad_dicom)
180 ENDFOREACH(filename)
181
182 # Populate GDCM_DATA_IMAGES:
183 FILE(WRITE "${GDCM_BINARY_DIR}/gdcmDataImages.h"
184   "const char * const gdcmDataImages[] = { ${GDCM_DATA_IMAGES}\n0 };\n" 
185   )
186
187 # Populate GDCM_DATA_SEQ_IMAGES:
188 FILE(WRITE "${GDCM_BINARY_DIR}/gdcmDataSeqImages.h"
189   "const char * const gdcmDataSeqImages[] = { ${GDCM_DATA_SEQ_IMAGES}\n0 };\n" 
190   )