diff options
author | Sebastien Barre <sebastien.barre@kitware.com> | 2002-01-19 00:21:43 (GMT) |
---|---|---|
committer | Sebastien Barre <sebastien.barre@kitware.com> | 2002-01-19 00:21:43 (GMT) |
commit | b6bdbc54fc5f02aa166323855e67b7c7f61fb56e (patch) | |
tree | 8fe09182485c9b6c2a3d367ccbb3b6cec4928d97 /Tests/Complex/Executable | |
parent | 747457abb647910742c5e13529894950d3c9ada4 (diff) | |
download | CMake-b6bdbc54fc5f02aa166323855e67b7c7f61fb56e.zip CMake-b6bdbc54fc5f02aa166323855e67b7c7f61fb56e.tar.gz CMake-b6bdbc54fc5f02aa166323855e67b7c7f61fb56e.tar.bz2 |
ENH: Increase test + coverage
Diffstat (limited to 'Tests/Complex/Executable')
-rw-r--r-- | Tests/Complex/Executable/CMakeLists.txt | 16 | ||||
-rw-r--r-- | Tests/Complex/Executable/complex.cxx | 97 |
2 files changed, 94 insertions, 19 deletions
diff --git a/Tests/Complex/Executable/CMakeLists.txt b/Tests/Complex/Executable/CMakeLists.txt index f0df86f..4bd1620 100644 --- a/Tests/Complex/Executable/CMakeLists.txt +++ b/Tests/Complex/Executable/CMakeLists.txt @@ -1,4 +1,20 @@ ADD_EXECUTABLE(complex complex) + TARGET_LINK_LIBRARIES(complex CMakeTestLibrary) TARGET_LINK_LIBRARIES(complex CMakeTestLibraryShared) +FIND_LIBRARY(CMAKE_LIB + CMakeLib + ${Complex_BINARY_DIR}/../../Source + ${Complex_BINARY_DIR}/../../Source/Debug + ${Complex_BINARY_DIR}/../../Source/Release + ${Complex_BINARY_DIR}/../../Source/MinSizeRel + ${Complex_BINARY_DIR}/../../Source/RelWithDebInfo) + +TARGET_LINK_LIBRARIES(complex ${CMAKE_LIB}) +LINK_LIBRARIES(${CMAKE_LIB}) + +# More coverage + +INSTALL_TARGETS(/tmp complex) +INSTALL_PROGRAMS(/tmp complex) diff --git a/Tests/Complex/Executable/complex.cxx b/Tests/Complex/Executable/complex.cxx index 5740dfc..b2f5162 100644 --- a/Tests/Complex/Executable/complex.cxx +++ b/Tests/Complex/Executable/complex.cxx @@ -3,16 +3,7 @@ #include "file2.h" #include "sharedFile.h" #include "cmStandardIncludes.h" -#include <sys/stat.h> -#include <stdio.h> - -#if defined(_MSC_VER) || defined(__BORLANDC__) -#define _unlink unlink -#else -#include <sys/types.h> -#include <fcntl.h> -#include <unistd.h> -#endif +#include "cmSystemTools.h" int passed = 0; int failed = 0; @@ -31,14 +22,13 @@ void Passed(const char* Message, const char* m2="") void TestAndRemoveFile(const char* filename) { - struct stat fs; - if (stat(filename, &fs) != 0) + if (!cmSystemTools::FileExists(filename)) { Failed("Could not find file: ", filename); } else { - if (unlink(filename) != 0) + if (!cmSystemTools::RemoveFile(filename)) { Failed("Unable to remove file. It does not imply that this test failed, but it *will* be corrupted thereafter if this file is not removed: ", filename); } @@ -49,6 +39,26 @@ void TestAndRemoveFile(const char* filename) } } +void TestDir(const char* filename) +{ + if (!cmSystemTools::FileExists(filename)) + { + Failed("Could not find dir: ", filename); + } + else + { + if (!cmSystemTools::FileIsDirectory(filename)) + { + Failed("Unable to check if file is a directory: ", filename); + } + else + { + Passed("Find dir: ", filename); + } + } +} + + int main() { if(sharedFunction() != 1) @@ -234,17 +244,66 @@ int main() } #endif - // A post-build custom-command has been attached to the lib. +#ifndef CACHE_TEST_VAR1 + Failed("the LOAD_CACHE or CONFIGURE_FILE command is broken, " + "CACHE_TEST_VAR1 is not defined."); +#else + if(strcmp(CACHE_TEST_VAR1, "foo") != 0) + { + Failed("the FOREACH, SET or CONFIGURE_FILE command is broken, " + "CACHE_TEST_VAR1 == ", CACHE_TEST_VAR1); + } + else + { + Passed("CACHE_TEST_VAR1 == ", CACHE_TEST_VAR1); + } +#endif + +#ifndef CACHE_TEST_VAR2 + Failed("the LOAD_CACHE or CONFIGURE_FILE command is broken, " + "CACHE_TEST_VAR2 is not defined."); +#else + if(strcmp(CACHE_TEST_VAR2, "bar") != 0) + { + Failed("the FOREACH, SET or CONFIGURE_FILE command is broken, " + "CACHE_TEST_VAR2 == ", CACHE_TEST_VAR2); + } + else + { + Passed("CACHE_TEST_VAR2 == ", CACHE_TEST_VAR2); + } +#endif + +#ifndef CACHE_TEST_VAR3 + Failed("the LOAD_CACHE or CONFIGURE_FILE command is broken, " + "CACHE_TEST_VAR3 is not defined."); +#else + if(strcmp(CACHE_TEST_VAR3, "1") != 0) + { + Failed("the FOREACH, SET or CONFIGURE_FILE command is broken, " + "CACHE_TEST_VAR3 == ", CACHE_TEST_VAR3); + } + else + { + Passed("CACHE_TEST_VAR3 == ", CACHE_TEST_VAR3); + } +#endif + + // A post-build custom-command has been attached to the lib (see Library/). // It run ${CREATE_FILE_EXE} which will create the file - // ${Complex_BINARY_DIR}/postbuild.txt. + // ${Complex_BINARY_DIR}/Library/postbuild.txt. - TestAndRemoveFile(BINARY_DIR "/postbuild.txt"); + TestAndRemoveFile(BINARY_DIR "/Library/postbuild.txt"); - // A custom target has been created. + // A custom target has been created (see Library/). // It run ${CREATE_FILE_EXE} which will create the file - // ${Complex_BINARY_DIR}/custom_target1.txt. + // ${Complex_BINARY_DIR}/Library/custom_target1.txt. + + TestAndRemoveFile(BINARY_DIR "/Library/custom_target1.txt"); + + // A directory has been created. - TestAndRemoveFile(BINARY_DIR "/custom_target1.txt"); + TestDir(BINARY_DIR "/make_dir"); std::cout << "Passed: " << passed << "\n"; if(failed) |