X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=Testing%2FCMakeLists.txt;h=2cdda5f9ee93e5d02e32ad175b5445411acd0b81;hb=db2866d9060d263e634708702d8a6a020ac6407c;hp=2c5cf7e025aa15eedfa4abc3e04ff226c8c5333e;hpb=eb46f178c8cd7efca6bc149bcd95c41a4a3704f2;p=gdcm.git diff --git a/Testing/CMakeLists.txt b/Testing/CMakeLists.txt index 2c5cf7e0..2cdda5f9 100644 --- a/Testing/CMakeLists.txt +++ b/Testing/CMakeLists.txt @@ -1,45 +1,99 @@ -#For later : rewrite this things for more consistencies, such as a 'FOREACH' +# CMakeLists for Testing purpose +# Cxx file that need a file to run should be place aproprietly -#TODO: -#http://www.cmake.org/pipermail/cmake/2001-November/002491.html -#So that dll is copied to each subdir where needed +SET(CXX_TEST_PATH ${EXECUTABLE_OUTPUT_PATH}) -LINK_LIBRARIES(gdcm) +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 + 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}/ ) -SET(PrintHeader_SOURCES - PrintHeader.cxx -) -ADD_EXECUTABLE(PrintHeader ${PrintHeader_SOURCES}) +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(testWrite_SOURCES - testWrite.cxx -) -ADD_EXECUTABLE(testWrite ${testWrite_SOURCES}) +SET (TestsToRun ${Tests}) +REMOVE (TestsToRun gdcmTests.cxx) -SET(testChangeEntete_SOURCES - testChangeEntete.cxx -) -ADD_EXECUTABLE(testChangeEntete ${testChangeEntete_SOURCES}) +# Loop over files and create executables +FOREACH(file ${TEST_SOURCES}) + GET_FILENAME_COMPONENT(name ${file} NAME_WE) +# 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}) -SET(hashtest_SOURCES - hashtest.cxx -) -ADD_EXECUTABLE(hashtest ${hashtest_SOURCES}) +#----------------------------------------------------------------------------- -SET(bug1_SOURCES - bug1.cxx -) -ADD_EXECUTABLE(bug1 ${bug1_SOURCES}) +# We need to test the reading of all dicom images in the gdcmData directory +# First parse this directory and extract all images -SET(pourFindTaggs_SOURCES - pourFindTaggs.cxx -) -ADD_EXECUTABLE(pourFindTaggs ${pourFindTaggs_SOURCES}) +# For now only *.dcm will be picked up, since there is a bug in cmake 1.8.3 +# and I don't know how to work around +FILE(GLOB GDCM_DATA_IMAGES_GLOB + "${GDCM_DATA_ROOT}/*.dcm" +# "${GDCM_DATA_ROOT}/*.acr" + ) -SET(dcm2acr_SOURCES - dcm2acr.cxx -) -ADD_EXECUTABLE(dcm2acr ${dcm2acr_SOURCES}) +# 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}) + SET(GDCM_DATA_IMAGES "${GDCM_DATA_IMAGES}\n\"${filename}\",") +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 + )