1
0

cmAddTestCommand.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. /*=========================================================================
  2. Program: CMake - Cross-Platform Makefile Generator
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
  8. See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
  9. This software is distributed WITHOUT ANY WARRANTY; without even
  10. the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  11. PURPOSE. See the above copyright notices for more information.
  12. =========================================================================*/
  13. #ifndef cmAddTestCommand_h
  14. #define cmAddTestCommand_h
  15. #include "cmCommand.h"
  16. /** \class cmAddTestCommand
  17. * \brief Add a test to the lists of tests to run.
  18. *
  19. * cmAddTestCommand adds a test to the list of tests to run .
  20. */
  21. class cmAddTestCommand : public cmCommand
  22. {
  23. public:
  24. /**
  25. * This is a virtual constructor for the command.
  26. */
  27. virtual cmCommand* Clone()
  28. {
  29. return new cmAddTestCommand;
  30. }
  31. /**
  32. * This is called when the command is first encountered in
  33. * the CMakeLists.txt file.
  34. */
  35. virtual bool InitialPass(std::vector<std::string> const& args,
  36. cmExecutionStatus &status);
  37. /**
  38. * The name of the command as specified in CMakeList.txt.
  39. */
  40. virtual const char* GetName() { return "add_test";}
  41. /**
  42. * Succinct documentation.
  43. */
  44. virtual const char* GetTerseDocumentation()
  45. {
  46. return "Add a test to the project with the specified arguments.";
  47. }
  48. /**
  49. * More documentation.
  50. */
  51. virtual const char* GetFullDocumentation()
  52. {
  53. return
  54. " add_test(testname Exename arg1 arg2 ...)\n"
  55. "If the ENABLE_TESTING command has been run, this command adds a "
  56. "test target to the current directory. If ENABLE_TESTING has not "
  57. "been run, this command does nothing. "
  58. "The tests are run by the testing subsystem by executing Exename "
  59. "with the specified arguments. Exename can be either an executable "
  60. "built by this project or an arbitrary executable on the "
  61. "system (like tclsh). The test will be run with the current working "
  62. "directory set to the CMakeList.txt files corresponding directory "
  63. "in the binary tree."
  64. "\n"
  65. " add_test(NAME <name> [CONFIGURATIONS [Debug|Release|...]]\n"
  66. " COMMAND <command> [arg1 [arg2 ...]])\n"
  67. "If COMMAND specifies an executable target (created by "
  68. "add_executable) it will automatically be replaced by the location "
  69. "of the executable created at build time. "
  70. "If a CONFIGURATIONS option is given then the test will be executed "
  71. "only when testing under one of the named configurations."
  72. "\n"
  73. "Arguments after COMMAND may use \"generator expressions\" with the "
  74. "syntax \"$<...>\". "
  75. "These expressions are evaluted during build system generation and "
  76. "produce information specific to each generated build configuration. "
  77. "Valid expressions are:\n"
  78. " $<CONFIGURATION> = configuration name\n"
  79. " $<TARGET_FILE:tgt> = main file (.exe, .so.1.2, .a)\n"
  80. " $<TARGET_LINKER_FILE:tgt> = file used to link (.a, .lib, .so)\n"
  81. " $<TARGET_SONAME_FILE:tgt> = file with soname (.so.3)\n"
  82. "where \"tgt\" is the name of a target. "
  83. "Target file expressions produce a full path, but _DIR and _NAME "
  84. "versions can produce the directory and file name components:\n"
  85. " $<TARGET_FILE_DIR:tgt>/$<TARGET_FILE_NAME:tgt>\n"
  86. " $<TARGET_LINKER_FILE_DIR:tgt>/$<TARGET_LINKER_FILE_NAME:tgt>\n"
  87. " $<TARGET_SONAME_FILE_DIR:tgt>/$<TARGET_SONAME_FILE_NAME:tgt>\n"
  88. "Example usage:\n"
  89. " add_test(NAME mytest\n"
  90. " COMMAND testDriver --config $<CONFIGURATION>\n"
  91. " --exe $<TARGET_FILE:myexe>)\n"
  92. "This creates a test \"mytest\" whose command runs a testDriver "
  93. "tool passing the configuration name and the full path to the "
  94. "executable file produced by target \"myexe\"."
  95. ;
  96. }
  97. cmTypeMacro(cmAddTestCommand, cmCommand);
  98. private:
  99. bool HandleNameMode(std::vector<std::string> const& args);
  100. };
  101. #endif