CMake/Source/cmCTest.h

294 lines
7.8 KiB
C
Raw Normal View History

2001-08-23 15:12:19 +00:00
/*=========================================================================
Program: CMake - Cross-Platform Makefile Generator
2001-08-23 15:12:19 +00:00
Module: $RCSfile$
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
2001-08-23 15:12:19 +00:00
2002-01-21 20:30:43 +00:00
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
2001-08-23 15:12:19 +00:00
=========================================================================*/
2003-02-11 02:52:01 +00:00
#ifndef cmCTest_h
#define cmCTest_h
2001-08-23 15:12:19 +00:00
#include "cmStandardIncludes.h"
#include "cmListFileCache.h"
2004-09-07 16:54:15 +00:00
#include <time.h>
2002-05-22 13:47:41 +00:00
class cmake;
class cmMakefile;
2005-01-27 20:54:47 +00:00
class cmCTestGenericHandler;
class cmGeneratedFileStream;
2002-12-17 02:19:21 +00:00
class cmCTest
2001-08-23 15:12:19 +00:00
{
public:
typedef std::vector<cmStdString> tm_VectorOfStrings;
///! Process Command line arguments
int Run(std::vector<std::string>const&, std::string* output = 0);
/**
* Initialize and finalize testing
*/
int Initialize(const char* binary_dir);
void Finalize();
/**
* Process the tests. This is the main routine. The execution of the
* tests should look like this:
*
* ctest foo;
* foo.Initialize();
* // Set some things on foo
* foo.ProcessTests();
* foo.Finalize();
*/
int ProcessTests();
/*
* A utility function that returns the nightly time
*/
2004-09-07 16:52:09 +00:00
static struct tm* GetNightlyTime(std::string str,
bool verbose,
bool tomorrowtag);
/*
* Is the tomorrow tag set?
*/
bool GetTomorrowTag() { return m_TomorrowTag; };
/**
* Try to run tests of the project
*/
int TestDirectory(bool memcheck);
2003-01-07 04:13:15 +00:00
/**
* Do submit testing results
*/
int SubmitResults();
std::string GetSubmitResultsPrefix();
2004-09-09 12:41:05 +00:00
///! what is the configuraiton type, e.g. Debug, Release etc.
std::string GetConfigType();
2003-01-07 04:13:15 +00:00
/**
* Check if CTest file exists
*/
bool CTestFileExists(const std::string& filename);
bool AddIfExists(tm_VectorOfStrings& files, const char* file);
2003-01-07 04:13:15 +00:00
/**
* Set the cmake test
*/
bool SetTest(const char*, bool report = true);
2003-02-11 02:52:01 +00:00
/**
* Set the cmake test mode (experimental, nightly, continuous).
*/
void SetTestModel(int mode);
int GetTestModel() { return m_TestModel; };
2003-02-11 02:52:01 +00:00
std::string GetTestModelString();
static int GetTestModelFromString(const char* str);
2004-09-09 12:41:05 +00:00
static std::string CleanString(const std::string& str);
std::string GetDartConfiguration(const char *name);
2001-08-23 15:12:19 +00:00
/**
2004-09-06 16:46:35 +00:00
* constructor and destructor
2001-08-23 15:12:19 +00:00
*/
2002-12-17 02:19:21 +00:00
cmCTest();
2004-09-06 16:46:35 +00:00
~cmCTest();
//! Set the notes files to be created.
void SetNotesFiles(const char* notes);
static void PopulateCustomVector(cmMakefile* mf, const char* definition,
tm_VectorOfStrings& vec);
static void PopulateCustomInteger(cmMakefile* mf, const char* def, int& val);
2004-01-23 14:44:47 +00:00
///! Get the current time as string
std::string CurrentTime();
///! Open file in the output directory and set the stream
bool OpenOutputFile(const std::string& path,
const std::string& name,
cmGeneratedFileStream& stream,
bool compress = false);
///! Convert string to something that is XML safe
static std::string MakeXMLSafe(const std::string&);
///! Should we only show what we would do?
bool GetShowOnly();
//! Start CTest XML output file
void StartXML(std::ostream& ostr);
//! End CTest XML output file
void EndXML(std::ostream& ostr);
//! Run command specialized for make and configure. Returns process status
// and retVal is return value or exception.
int RunMakeCommand(const char* command, std::string* output,
int* retVal, const char* dir, bool verbose, int timeout,
std::ofstream& ofs);
/*
* return the current tag
*/
std::string GetCurrentTag();
2004-09-07 14:37:39 +00:00
//! Get the path to the build tree
std::string GetBinaryDir();
2004-09-09 12:41:05 +00:00
//! Get the short path to the file. This means if the file is in binary or
//source directory, it will become /.../relative/path/to/file
std::string GetShortPathToFile(const char* fname);
//! Get the path to CTest
const char* GetCTestExecutable() { return m_CTestSelf.c_str(); }
enum {
EXPERIMENTAL,
NIGHTLY,
CONTINUOUS
};
// provide some more detailed info on the return code for ctest
enum {
UPDATE_ERRORS = 0x01,
CONFIGURE_ERRORS = 0x02,
BUILD_ERRORS = 0x04,
TEST_ERRORS = 0x08,
MEMORY_ERRORS = 0x10,
COVERAGE_ERRORS = 0x20
};
///! Are we producing XML
bool GetProduceXML();
void SetProduceXML(bool v);
2004-09-09 12:41:05 +00:00
//! Run command specialized for tests. Returns process status and retVal is
// return value or exception.
int RunTest(std::vector<const char*> args, std::string* output, int *retVal,
std::ostream* logfile);
/**
* Execute handler and return its result. If the handler fails, it returns negative value.
*/
int ExecuteHandler(const char* handler);
/*
* Get the handler object
*/
cmCTestGenericHandler* GetHandler(const char* handler);
private:
std::string m_ConfigType;
bool m_Verbose;
bool m_ProduceXML;
bool m_ForceNewCTestProcess;
bool m_RunConfigurationScript;
int GenerateNotesFile(const char* files);
static std::string MakeURLSafe(const std::string&);
// these are helper classes
2005-01-27 20:54:47 +00:00
typedef std::map<cmStdString,cmCTestGenericHandler*> t_TestingHandlers;
t_TestingHandlers m_TestingHandlers;
2004-09-06 16:46:35 +00:00
bool m_ShowOnly;
enum {
2003-02-11 04:19:01 +00:00
FIRST_TEST = 0,
UPDATE_TEST = 1,
2003-03-19 21:35:02 +00:00
START_TEST = 2,
CONFIGURE_TEST = 3,
BUILD_TEST = 4,
TEST_TEST = 5,
COVERAGE_TEST = 6,
MEMCHECK_TEST = 7,
2003-03-19 21:35:02 +00:00
SUBMIT_TEST = 8,
NOTES_TEST = 9,
ALL_TEST = 10,
LAST_TEST = 11
};
2004-06-02 17:39:25 +00:00
//! Map of configuration properties
typedef std::map<cmStdString, cmStdString> tm_DartConfigurationMap;
std::string m_CTestConfigFile;
tm_DartConfigurationMap m_DartConfiguration;
int m_Tests[LAST_TEST];
std::string m_CurrentTag;
2004-03-14 17:28:37 +00:00
bool m_TomorrowTag;
2002-10-09 02:00:11 +00:00
2003-02-11 14:19:36 +00:00
int m_TestModel;
2003-02-11 02:52:01 +00:00
double m_TimeOut;
2003-08-04 02:36:17 +00:00
int m_CompatibilityMode;
// information for the --build-and-test options
std::string m_ExecutableDirectory;
std::string m_CMakeSelf;
std::string m_CTestSelf;
std::string m_SourceDir;
std::string m_BinaryDir;
std::string m_BuildRunDir;
std::string m_BuildGenerator;
std::string m_BuildMakeProgram;
std::string m_BuildProject;
std::string m_BuildTarget;
std::vector<std::string> m_BuildOptions;
std::string m_TestCommand;
std::vector<std::string> m_TestCommandArgs;
bool m_BuildTwoConfig;
bool m_BuildNoClean;
2004-01-13 16:22:47 +00:00
bool m_BuildNoCMake;
std::string m_NotesFiles;
int ReadCustomConfigurationFileTree(const char* dir);
bool m_InteractiveDebugMode;
2004-08-26 13:45:20 +00:00
bool m_ShortDateFormat;
bool m_CompressXMLFiles;
void BlockTestErrorDiagnostics();
//! Reread the configuration file
bool UpdateCTestConfiguration();
//! Create not from files.
int GenerateDartNotesOutput(std::ostream& os, const tm_VectorOfStrings& files);
///! Run CMake and build a test and then run it as a single test.
int RunCMakeAndTest(std::string* output);
int RunCMake(std::string* outstring, cmOStringStream &out,
std::string &cmakeOutString,
std::string &cwd, cmake *cm);
///! Find the running cmake
void FindRunningCMake(const char* arg0);
2001-08-23 15:12:19 +00:00
};
2003-02-11 02:52:01 +00:00
#endif