# 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 | |
# | |