X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=Testing%2FCMakeLists.txt;h=b4e41de2c26c55ad41fba94a9453dad992d47fb2;hb=55ef2ceb72dedf6dccfadf8b06e52b3b4cf81f70;hp=aff9d67aaf65cbac9c5a86500a9987fec10f9562;hpb=b0745f542bc5ff8332c1f8445e7181279d12aefe;p=gdcm.git diff --git a/Testing/CMakeLists.txt b/Testing/CMakeLists.txt index aff9d67a..b4e41de2 100644 --- a/Testing/CMakeLists.txt +++ b/Testing/CMakeLists.txt @@ -1,40 +1,114 @@ -# TODO: -# http://www.cmake.org/pipermail/cmake/2001-November/002491.html -# So that dll is copied to each subdir where needed +# CMakeLists for Testing purpose +# Cxx file that need a file to run should be place aproprietly -INCLUDE (${CMAKE_ROOT}/Modules/CheckIncludeFile.cmake) -CHECK_INCLUDE_FILE("stdint.h" CMAKE_HAVE_STDINT_H) - -IF(NOT CMAKE_HAVE_STDINT_H) - SET(GDCM_TEST_COMPILE_FLAGS "-DHAVE_NO_STDINT_H") -ENDIF(NOT CMAKE_HAVE_STDINT_H) +SET(CXX_TEST_PATH ${EXECUTABLE_OUTPUT_PATH}) +SET(GDCM_TESTS ${CXX_TEST_PATH}/gdcmTests) +# add test that does not require data: +# They usally return if no argument is given SET(TEST_SOURCES - PrintHeader.cxx - testWrite.cxx - testChangeEntete.cxx - hashtest.cxx - bug1.cxx - pourFindTaggs.cxx + PrintBug.cxx dcm2acr.cxx + hashtest.cxx + testWrite.cxx ) +# add tests that require data +IF (GDCM_DATA_ROOT) + SET(TEST_SOURCES ${TEST_SOURCES} + PrintHeader.cxx #require test.acr + PrintDicomDir.cxx + pourFindTaggs.cxx + testChangeEntete.cxx + testDicomDir.cxx #require DICOMDIR + BuildUpDicomDir.cxx + TestReadWrite.cxx + makeDicomDir.cxx + ) + # add test that require VTK: + IF(GDCM_VTK) + INCLUDE_DIRECTORIES( + ${GDCM_SOURCE_DIR}/vtk/ + ) + SET(TEST_SOURCES ${TEST_SOURCES} + ShowDicom.cxx + ) + ENDIF(GDCM_VTK) +ENDIF (GDCM_DATA_ROOT) + + + # include stuff INCLUDE_DIRECTORIES( ${GDCM_SOURCE_DIR}/src/ + ${GDCM_BINARY_DIR}/ ) +CREATE_TEST_SOURCELIST(Tests gdcmTests.cxx ${TEST_SOURCES}) +ADD_EXECUTABLE(gdcmTests ${Tests}) +IF(GDCM_VTK) + TARGET_LINK_LIBRARIES(gdcmTests vtkgdcm vtkRendering) +ELSE(GDCM_VTK) + TARGET_LINK_LIBRARIES(gdcmTests gdcm) +ENDIF(GDCM_VTK) + +SET (TestsToRun ${Tests}) +REMOVE (TestsToRun gdcmTests.cxx) + # Loop over files and create executables FOREACH(file ${TEST_SOURCES}) - #Doh ! I need to specify each time the compile flags ! - IF(GDCM_TEST_COMPILE_FLAGS) - SET_SOURCE_FILES_PROPERTIES(${file} - PROPERTIES - COMPILE_FLAGS ${GDCM_TEST_COMPILE_FLAGS} - ) - ENDIF(GDCM_TEST_COMPILE_FLAGS) GET_FILENAME_COMPONENT(name ${file} NAME_WE) - ADD_EXECUTABLE(${name} ${file}) - TARGET_LINK_LIBRARIES(${name} gdcm) +# IF (GDCM_DATA_ROOT) +# ADD_TEST(${name} ${CXX_TEST_PATH}/gdcmTests ${name} +# -D ${GDCM_DATA_ROOT} +# -T ${GDCM_BINARY_DIR}/Testing/Temporary +# -V Baseline/gdcm/${name}.png) +# ELSE (GDCM_DATA_ROOT) + ADD_TEST(${name} ${GDCM_TESTS} ${name}) +# ENDIF (GDCM_DATA_ROOT) ENDFOREACH(file ${TEST_SOURCES}) + +#----------------------------------------------------------------------------- + +# We need to test the reading of all dicom images in the gdcmData directory +# First parse this directory and extract all images + +# Since there is a bug in cmake 1.8.3, I'll have to do two separate globs +FILE(GLOB GDCM_DATA_IMAGES_GLOB_ACR + "${GDCM_DATA_ROOT}/*.acr" + ) + +FILE(GLOB GDCM_DATA_IMAGES_GLOB_DCM + "${GDCM_DATA_ROOT}/*.dcm" + ) + +# Black list of images know to break lots of readers (efilm, xmedcon ...): +SET(BLACK_LIST + "gdcm-JPEG-LossLessThoravision.dcm" + ) + +SET(GDCM_DATA_IMAGES_GLOB ${GDCM_DATA_IMAGES_GLOB_DCM} ${GDCM_DATA_IMAGES_GLOB_ACR}) + +# This is a GLOB expression, change it into a list separated with a comma and \n +SET(GDCM_DATA_IMAGES) +FOREACH(filename ${GDCM_DATA_IMAGES_GLOB}) + GET_FILENAME_COMPONENT(filename_temp ${filename} NAME) + #MESSAGE(STATUS ${filename_temp}) + STRING(COMPARE EQUAL ${BLACK_LIST} ${filename_temp} bad_dicom) + #MESSAGE(STATUS ${bad_dicom}) + IF(NOT bad_dicom) + SET(GDCM_DATA_IMAGES "${GDCM_DATA_IMAGES}\n\"${filename}\",") + ENDIF(NOT bad_dicom) +ENDFOREACH(filename) + +# Populate GDCM_DATA_IMAGES: +FILE(WRITE "${GDCM_BINARY_DIR}/gdcmDataImages.h.in" + "const char * const gdcmDataImages[] = { @GDCM_DATA_IMAGES@ \n 0 };" + ) + +# Generate the header file: +CONFIGURE_FILE( + ${GDCM_BINARY_DIR}/gdcmDataImages.h.in + ${GDCM_BINARY_DIR}/gdcmDataImages.h + )