CMake/Tests/Complex/Executable/complex.cxx

138 lines
3.1 KiB
C++

#include "cmTestConfigure.h"
#include "ExtraSources/file1.h"
#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
int passed = 0;
int failed = 0;
void Failed(const char* Message, const char* m2= "")
{
std::cerr << "Failed: " << Message << m2 << "\n";
failed++;
}
void Passed(const char* Message, const char* m2="")
{
std::cout << "Passed: " << Message << m2 << "\n";
passed++;
}
int main()
{
if(sharedFunction() != 1)
{
Failed("Call to sharedFunction from shared library failed.");
}
else
{
Passed("Call to sharedFunction from shared library worked.");
}
if(file1() != 1)
{
Failed("Call to file1 function from library failed.");
}
else
{
Passed("Call to file1 function returned 1.");
}
if(file2() != 1)
{
Failed("Call to file2 function from library failed.");
}
else
{
Passed("Call to file2 function returned 1.");
}
#ifndef CMAKE_IS_FUN
Failed("CMake is not fun, so it is broken and should be fixed.");
#else
Passed("CMAKE_IS_FUN is defined.");
#endif
#ifdef SHOULD_NOT_BE_DEFINED
Failed("IF or SET is broken, SHOULD_NOT_BE_DEFINED is defined.");
#else
Passed("SHOULD_NOT_BE_DEFINED is not defined.");
#endif
#ifndef SHOULD_BE_DEFINED
Failed("IF or SET is broken, SHOULD_BE_DEFINED is not defined.\n");
#else
Passed("SHOULD_BE_DEFINED is defined.");
#endif
#ifndef ONE_VAR
Failed("cmakedefine is broken, ONE_VAR is not defined.");
#else
Passed("ONE_VAR is defined.");
#endif
#ifdef ZERO_VAR
Failed("cmakedefine is broken, ZERO_VAR is defined.");
#else
Passed("ZERO_VAR is not defined.");
#endif
#ifndef STRING_VAR
Failed("configureFile is broken, STRING_VAR is not defined.");
#else
if(strcmp(STRING_VAR, "CMake is great") != 0)
{
Failed("CMake is not great, so the SET command,"
"or the configurefile comand is broken. STRING_VAR== ",
STRING_VAR);
}
else
{
Passed("STRING_VAR == ", STRING_VAR);
}
#endif
// Attach a post-build custom-command to the lib.
// It run ${CREATE_FILE_EXE} which will create the file
// ${Complex_BINARY_DIR}/postbuild.txt.
// The 'complex' executable will then test if this file exists,
// and remove it.
struct stat fs;
if (stat(BINARY_DIR "/postbuild.txt", &fs) != 0)
{
Failed("Could not find " BINARY_DIR "/postbuild.txt (created as a post-build custom command for the shared lib).");
}
else
{
if (unlink(BINARY_DIR "/postbuild.txt") != 0)
{
Failed("Unable to remove " BINARY_DIR "/postbuild.txt (does not imply that this test failed, but it *will* be corrupted thereafter if this file is not removed).");
}
else
{
Passed("Find and remove " BINARY_DIR "/postbuild.txt (created as a post-build custom command for the shared lib).");
}
}
std::cout << "Passed: " << passed << "\n";
if(failed)
{
std::cout << "Failed: " << failed << "\n";
return failed;
}
return 0;
}