123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- # Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- # file Copyright.txt or https://cmake.org/licensing for details.
- #[=======================================================================[.rst:
- Dart
- ----
- Configure a project for testing with CTest or old Dart Tcl Client
- This file is the backwards-compatibility version of the CTest module.
- It supports using the old Dart 1 Tcl client for driving dashboard
- submissions as well as testing with CTest. This module should be
- included in the CMakeLists.txt file at the top of a project. Typical
- usage:
- ::
- include(Dart)
- if(BUILD_TESTING)
- # ... testing related CMake code ...
- endif()
- The BUILD_TESTING option is created by the Dart module to determine
- whether testing support should be enabled. The default is ON.
- #]=======================================================================]
- # This file configures a project to use the Dart testing/dashboard process.
- # It is broken into 3 sections.
- #
- # Section #1: Locate programs on the client and determine site and build name
- # Section #2: Configure or copy Tcl scripts from the source tree to build tree
- # Section #3: Custom targets for performing dashboard builds.
- #
- #
- option(BUILD_TESTING "Build the testing tree." ON)
- if(BUILD_TESTING)
- find_package(Dart QUIET)
- #
- # Section #1:
- #
- # CMake commands that will not vary from project to project. Locates programs
- # on the client and configure site name and build name.
- #
- set(RUN_FROM_DART 1)
- include(CTest)
- set(RUN_FROM_DART)
- find_program(COMPRESSIONCOMMAND NAMES gzip compress zip
- DOC "Path to program used to compress files for transfer to the dart server")
- find_program(GUNZIPCOMMAND gunzip DOC "Path to gunzip executable")
- find_program(JAVACOMMAND java DOC "Path to java command, used by the Dart server to create html.")
- option(DART_VERBOSE_BUILD "Show the actual output of the build, or if off show a . for each 1024 bytes."
- OFF)
- option(DART_BUILD_ERROR_REPORT_LIMIT "Limit of reported errors, -1 reports all." -1 )
- option(DART_BUILD_WARNING_REPORT_LIMIT "Limit of reported warnings, -1 reports all." -1 )
- set(VERBOSE_BUILD ${DART_VERBOSE_BUILD})
- set(BUILD_ERROR_REPORT_LIMIT ${DART_BUILD_ERROR_REPORT_LIMIT})
- set(BUILD_WARNING_REPORT_LIMIT ${DART_BUILD_WARNING_REPORT_LIMIT})
- set (DELIVER_CONTINUOUS_EMAIL "Off" CACHE BOOL "Should Dart server send email when build errors are found in Continuous builds?")
- mark_as_advanced(
- COMPRESSIONCOMMAND
- DART_BUILD_ERROR_REPORT_LIMIT
- DART_BUILD_WARNING_REPORT_LIMIT
- DART_TESTING_TIMEOUT
- DART_VERBOSE_BUILD
- DELIVER_CONTINUOUS_EMAIL
- GUNZIPCOMMAND
- JAVACOMMAND
- )
- set(HAVE_DART)
- if(EXISTS "${DART_ROOT}/Source/Client/Dart.conf.in")
- set(HAVE_DART 1)
- endif()
- #
- # Section #2:
- #
- # Make necessary directories and configure testing scripts
- #
- # find a tcl shell command
- if(HAVE_DART)
- find_package(Tclsh)
- endif()
- if (HAVE_DART)
- # make directories in the binary tree
- file(MAKE_DIRECTORY "${PROJECT_BINARY_DIR}/Testing/HTML/TestingResults/Dashboard"
- "${PROJECT_BINARY_DIR}/Testing/HTML/TestingResults/Sites/${SITE}/${BUILDNAME}")
- # configure files
- configure_file(
- "${DART_ROOT}/Source/Client/Dart.conf.in"
- "${PROJECT_BINARY_DIR}/DartConfiguration.tcl" )
- #
- # Section 3:
- #
- # Custom targets to perform dashboard builds and submissions.
- # These should NOT need to be modified from project to project.
- #
- # add testing targets
- set(DART_EXPERIMENTAL_NAME Experimental)
- if(DART_EXPERIMENTAL_USE_PROJECT_NAME)
- string(APPEND DART_EXPERIMENTAL_NAME "${PROJECT_NAME}")
- endif()
- endif ()
- set(RUN_FROM_CTEST_OR_DART 1)
- include(CTestTargets)
- set(RUN_FROM_CTEST_OR_DART)
- endif()
- #
- # End of Dart.cmake
- #
|