ENH: add test which executes all FindXXX.cmake modules

Alex
This commit is contained in:
Alexander Neundorf 2008-06-16 14:03:03 -04:00
parent d1c1d8025f
commit 8ef9983db6
3 changed files with 34 additions and 0 deletions

View File

@ -40,6 +40,7 @@ IF(BUILD_TESTING)
# add a bunch of standard build-and-test style tests
ADD_TEST_MACRO(CommandLineTest CommandLineTest)
ADD_TEST_MACRO(FindPackageTest FindPackageTest)
ADD_TEST_MACRO(FindModulesExecuteAll FindModulesExecuteAll)
ADD_TEST_MACRO(StringFileTest StringFileTest)
ADD_TEST_MACRO(TryCompile TryCompile)
ADD_TEST_MACRO(TarTest TarTest)

View File

@ -0,0 +1,29 @@
# This file includes all FindXXX.cmake modules, so they are all executed.
# As it is it doesn't test a lot.
# It makes sure that the modules don't contain basic syntax errors.
# It also makes sure that modules don't fail with an error if something
# wasn't found but REQUIRED was not given.
#
# I guess more things could be added, like checking whether variables are
# defined after running the modules (e.g. FOO_FOUND etc.).
file(GLOB all_modules "${CMAKE_CURRENT_SOURCE_DIR}/../../Modules/Find*cmake")
foreach(module ${all_modules})
message(STATUS "module: ${module}")
include("${module}")
# get the "basename" of the package, so the existence of variables like
# FOO_FOUND could be tested later on, Alex
string(REGEX REPLACE ".+Find([^\\.]+)\\.cmake" "\\1" packageName "${module}")
string(TOUPPER "${packageName}" packageNameUpper)
# disabled for now, since too many modules break:
# if(NOT DEFINED ${packageNameUpper}_FOUND)
# message(SEND_ERROR "${packageNameUpper}_FOUND not defined !")
# endif(NOT DEFINED ${packageNameUpper}_FOUND)
endforeach(module ${all_modules})
add_executable(FindModulesExecuteAll main.c)

View File

@ -0,0 +1,4 @@
int main()
{
return 0;
}