mirror of
https://github.com/Kitware/CMake.git
synced 2025-05-08 22:37:04 +08:00

- Updated and synced module documentation according to other similar find modules. - Added a separate examples section. - Commands are listed using the `command` directives. - Updated documentation for the `SquishTestScript.cmake` file. This is not actually a module but a test script that `FindSquish` uses and also isn't technically deprecated as it is still used. Documentation changed a bit to explain it is an internal script that shouldn't be used in the project directly.
388 lines
12 KiB
CMake
388 lines
12 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
FindSquish
|
|
----------
|
|
|
|
Finds Squish, a cross-platform automated GUI testing framework for applications
|
|
built on various GUI technologies. Squish supports testing of both native and
|
|
cross-platform toolkits, such as Qt, Java, and Tk.
|
|
|
|
Result Variables
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
This module defines the following variables:
|
|
|
|
``Squish_FOUND``
|
|
Boolean indicating whether the (requested version of) Squish is found. For
|
|
backward compatibility, the ``SQUISH_FOUND`` variable is also set to the same
|
|
value.
|
|
|
|
``SQUISH_VERSION``
|
|
The full version of the Squish found.
|
|
|
|
``SQUISH_VERSION_MAJOR``
|
|
The major version of the Squish found.
|
|
|
|
``SQUISH_VERSION_MINOR``
|
|
The minor version of the Squish found.
|
|
|
|
``SQUISH_VERSION_PATCH``
|
|
The patch version of the Squish found.
|
|
|
|
``SQUISH_INSTALL_DIR_FOUND``
|
|
Boolean indicating whether the Squish installation directory is found.
|
|
|
|
``SQUISH_SERVER_EXECUTABLE_FOUND``
|
|
Boolean indicating whether the Squish server executable is found.
|
|
|
|
``SQUISH_CLIENT_EXECUTABLE_FOUND``
|
|
Boolean indicating whether the Squish client executable is found.
|
|
|
|
Cache Variables
|
|
^^^^^^^^^^^^^^^
|
|
|
|
The following cache variables may also be set:
|
|
|
|
``SQUISH_INSTALL_DIR``
|
|
The Squish installation directory containing ``bin``, ``lib``, etc.
|
|
|
|
``SQUISH_SERVER_EXECUTABLE``
|
|
The path to the ``squishserver`` executable.
|
|
|
|
``SQUISH_CLIENT_EXECUTABLE``
|
|
The path to the ``squishrunner`` executable.
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following commands, if Squish is found:
|
|
|
|
.. command:: squish_add_test
|
|
|
|
Adds a Squish test to the project:
|
|
|
|
.. code-block:: cmake
|
|
|
|
squish_add_test(
|
|
<name>
|
|
AUT <target>
|
|
SUITE <suite-name>
|
|
TEST <squish-test-case-name>
|
|
[PRE_COMMAND <command>]
|
|
[POST_COMMAND <command>]
|
|
[SETTINGSGROUP <group>]
|
|
)
|
|
|
|
This command is built on top of the :command:`add_test` command and adds a
|
|
Squish test called ``<name>`` to the CMake project. It supports Squish
|
|
versions 4 and newer.
|
|
|
|
During the CMake testing phase, the Squish server is started, the test is
|
|
executed on the client, and the server is stopped once the test completes. If
|
|
any of these steps fail (including if the test itself fails), a fatal error is
|
|
raised indicating the test did not pass.
|
|
|
|
The arguments are:
|
|
|
|
``<name>``
|
|
The name of the test. This is passed as the first argument to the
|
|
:command:`add_test` command.
|
|
|
|
``AUT <target>``
|
|
The name of the CMake target to be used as the AUT (Application Under Test),
|
|
i.e., the executable that will be tested.
|
|
|
|
``SUITE <suite-name>``
|
|
Either the full path to the Squish test suite or just the suite name (i.e.,
|
|
the last directory name of the suite). In the latter case, the
|
|
``CMakeLists.txt`` invoking ``squish_add_test()`` must reside in the parent
|
|
directory of the suite.
|
|
|
|
``TEST <squish-test-case-name>``
|
|
The name of the Squish test, corresponding to the subdirectory of the test
|
|
within the suite directory.
|
|
|
|
``PRE_COMMAND <command>``
|
|
An optional command to execute before starting the Squish test. Pass it as
|
|
a string. This may be a single command, or a :ref:`semicolon-separated list
|
|
<CMake Language Lists>` of command and arguments.
|
|
|
|
``POST_COMMAND <command>``
|
|
An optional command to execute after the Squish test has completed. Pass it
|
|
as a string. This may be a single command, or a :ref:`semicolon-separated
|
|
list <CMake Language Lists>` of command and arguments.
|
|
|
|
``SETTINGSGROUP <group>``
|
|
.. deprecated:: 3.18
|
|
This argument is now ignored. It was previously used to specify a
|
|
settings group name for executing the test instead of the default value
|
|
``CTest_<username>``.
|
|
|
|
.. versionchanged:: 3.18
|
|
In previous CMake versions, this command was named ``squish_v4_add_test()``.
|
|
|
|
.. command:: squish_v3_add_test
|
|
|
|
Adds a Squish test to the project, when using Squish version 3.x:
|
|
|
|
.. code-block:: cmake
|
|
|
|
squish_v3_add_test(
|
|
<test-name>
|
|
<application-under-test>
|
|
<squish-test-case-name>
|
|
<environment-variables>
|
|
<test-wrapper>
|
|
)
|
|
|
|
.. note::
|
|
This command is for Squish version 3, which is not maintained anymore. Use
|
|
a newer Squish version, and ``squish_add_test()`` command.
|
|
|
|
The arguments are:
|
|
|
|
``<name>``
|
|
The name of the test.
|
|
|
|
``<application-under-test>``
|
|
The path to the executable used as the AUT (Application Under Test), i.e.,
|
|
the executable that will be tested.
|
|
|
|
``<squish-test-case-name>``
|
|
The name of the Squish test, corresponding to the subdirectory of the test
|
|
within the suite directory.
|
|
|
|
``<environment-variables>``
|
|
A semicolon-separated list of environment variables and their values
|
|
(VAR=VALUE).
|
|
|
|
``<test-wrapper>``
|
|
A string of one or more (semicolon-separated list) test wrappers needed by
|
|
the test case.
|
|
|
|
Examples
|
|
^^^^^^^^
|
|
|
|
Finding Squish and specifying a minimum required version:
|
|
|
|
.. code-block:: cmake
|
|
|
|
find_package(Squish 6.5)
|
|
|
|
Adding a Squish test:
|
|
|
|
.. code-block:: cmake
|
|
|
|
enable_testing()
|
|
|
|
find_package(Squish 6.5)
|
|
if(Squish_FOUND)
|
|
squish_add_test(
|
|
projectTestName
|
|
AUT projectApp
|
|
SUITE ${CMAKE_CURRENT_SOURCE_DIR}/tests/projectSuite
|
|
TEST someSquishTest
|
|
)
|
|
endif()
|
|
|
|
Example, how to use the ``squish_v3_add_test()`` command:
|
|
|
|
.. code-block:: cmake
|
|
|
|
enable_testing()
|
|
|
|
find_package(Squish 3.0)
|
|
if(Squish_FOUND)
|
|
squish_v3_add_test(
|
|
projectTestName
|
|
$<TARGET_FILE:projectApp>
|
|
someSquishTest
|
|
"FOO=1;BAR=2"
|
|
testWrapper
|
|
)
|
|
endif()
|
|
#]=======================================================================]
|
|
|
|
set(SQUISH_INSTALL_DIR_STRING "Directory containing the bin, doc, and lib directories for Squish; this should be the root of the installation directory.")
|
|
set(SQUISH_SERVER_EXECUTABLE_STRING "The squishserver executable program.")
|
|
set(SQUISH_CLIENT_EXECUTABLE_STRING "The squishclient executable program.")
|
|
|
|
# Search only if the location is not already known.
|
|
if(NOT SQUISH_INSTALL_DIR)
|
|
# Get the system search path as a list.
|
|
file(TO_CMAKE_PATH "$ENV{PATH}" SQUISH_INSTALL_DIR_SEARCH2)
|
|
|
|
# Construct a set of paths relative to the system search path.
|
|
set(SQUISH_INSTALL_DIR_SEARCH "")
|
|
foreach(dir ${SQUISH_INSTALL_DIR_SEARCH2})
|
|
set(SQUISH_INSTALL_DIR_SEARCH ${SQUISH_INSTALL_DIR_SEARCH} "${dir}/../lib/fltk")
|
|
endforeach()
|
|
string(REPLACE "//" "/" SQUISH_INSTALL_DIR_SEARCH "${SQUISH_INSTALL_DIR_SEARCH}")
|
|
|
|
# Look for an installation
|
|
find_path(SQUISH_INSTALL_DIR
|
|
NAMES bin/squishrunner bin/squishrunner.exe
|
|
HINTS
|
|
# Look for an environment variable SQUISH_INSTALL_DIR.
|
|
ENV SQUISH_INSTALL_DIR
|
|
|
|
# Look in places relative to the system executable search path.
|
|
${SQUISH_INSTALL_DIR_SEARCH}
|
|
|
|
DOC "The ${SQUISH_INSTALL_DIR_STRING}"
|
|
)
|
|
endif()
|
|
|
|
# search for the executables
|
|
if(SQUISH_INSTALL_DIR)
|
|
set(SQUISH_INSTALL_DIR_FOUND 1)
|
|
|
|
# find the client program
|
|
if(NOT SQUISH_CLIENT_EXECUTABLE)
|
|
find_program(SQUISH_CLIENT_EXECUTABLE ${SQUISH_INSTALL_DIR}/bin/squishrunner${CMAKE_EXECUTABLE_SUFFIX} DOC "The ${SQUISH_CLIENT_EXECUTABLE_STRING}")
|
|
endif()
|
|
|
|
# find the server program
|
|
if(NOT SQUISH_SERVER_EXECUTABLE)
|
|
find_program(SQUISH_SERVER_EXECUTABLE ${SQUISH_INSTALL_DIR}/bin/squishserver${CMAKE_EXECUTABLE_SUFFIX} DOC "The ${SQUISH_SERVER_EXECUTABLE_STRING}")
|
|
endif()
|
|
|
|
else()
|
|
set(SQUISH_INSTALL_DIR_FOUND 0)
|
|
endif()
|
|
|
|
|
|
set(SQUISH_VERSION)
|
|
set(SQUISH_VERSION_MAJOR)
|
|
set(SQUISH_VERSION_MINOR)
|
|
set(SQUISH_VERSION_PATCH)
|
|
|
|
# record if executables are set
|
|
if(SQUISH_CLIENT_EXECUTABLE)
|
|
set(SQUISH_CLIENT_EXECUTABLE_FOUND 1)
|
|
execute_process(COMMAND "${SQUISH_CLIENT_EXECUTABLE}" --version
|
|
OUTPUT_VARIABLE _squishVersionOutput
|
|
ERROR_QUIET )
|
|
if("${_squishVersionOutput}" MATCHES "([0-9]+)\\.([0-9]+)\\.([0-9]+)")
|
|
set(SQUISH_VERSION_MAJOR "${CMAKE_MATCH_1}")
|
|
set(SQUISH_VERSION_MINOR "${CMAKE_MATCH_2}")
|
|
set(SQUISH_VERSION_PATCH "${CMAKE_MATCH_3}")
|
|
set(SQUISH_VERSION "${SQUISH_VERSION_MAJOR}.${SQUISH_VERSION_MINOR}.${SQUISH_VERSION_PATCH}" )
|
|
endif()
|
|
else()
|
|
set(SQUISH_CLIENT_EXECUTABLE_FOUND 0)
|
|
endif()
|
|
|
|
if(SQUISH_SERVER_EXECUTABLE)
|
|
set(SQUISH_SERVER_EXECUTABLE_FOUND 1)
|
|
else()
|
|
set(SQUISH_SERVER_EXECUTABLE_FOUND 0)
|
|
endif()
|
|
|
|
# record if Squish was found
|
|
include(FindPackageHandleStandardArgs)
|
|
find_package_handle_standard_args(Squish REQUIRED_VARS SQUISH_INSTALL_DIR SQUISH_CLIENT_EXECUTABLE SQUISH_SERVER_EXECUTABLE
|
|
VERSION_VAR SQUISH_VERSION )
|
|
|
|
|
|
set(_SQUISH_MODULE_DIR "${CMAKE_CURRENT_LIST_DIR}")
|
|
|
|
macro(squish_v3_add_test testName testAUT testCase envVars testWrapper)
|
|
if("${SQUISH_VERSION_MAJOR}" STRGREATER "3")
|
|
message(STATUS "Using squish_v3_add_test(), but SQUISH_VERSION_MAJOR is ${SQUISH_VERSION_MAJOR}.\nThis may not work.")
|
|
endif()
|
|
|
|
# There's no target used for this command, so we don't need to do anything
|
|
# here for CMP0178.
|
|
add_test(${testName}
|
|
${CMAKE_COMMAND} -V -VV
|
|
"-Dsquish_version:STRING=3"
|
|
"-Dsquish_aut:STRING=${testAUT}"
|
|
"-Dsquish_server_executable:STRING=${SQUISH_SERVER_EXECUTABLE}"
|
|
"-Dsquish_client_executable:STRING=${SQUISH_CLIENT_EXECUTABLE}"
|
|
"-Dsquish_libqtdir:STRING=${QT_LIBRARY_DIR}"
|
|
"-Dsquish_test_case:STRING=${testCase}"
|
|
"-Dsquish_env_vars:STRING=${envVars}"
|
|
"-Dsquish_wrapper:STRING=${testWrapper}"
|
|
"-Dsquish_module_dir:STRING=${_SQUISH_MODULE_DIR}"
|
|
-P "${_SQUISH_MODULE_DIR}/SquishTestScript.cmake"
|
|
)
|
|
set_tests_properties(${testName}
|
|
PROPERTIES FAIL_REGULAR_EXPRESSION "FAILED;ERROR;FATAL"
|
|
)
|
|
endmacro()
|
|
|
|
|
|
function(squish_v4_add_test testName)
|
|
if(NOT "${SQUISH_VERSION_MAJOR}" STRGREATER "3")
|
|
message(STATUS "Using squish_add_test(), but SQUISH_VERSION_MAJOR is ${SQUISH_VERSION_MAJOR}.\nThis may not work.")
|
|
endif()
|
|
|
|
set(oneValueArgs AUT SUITE TEST SETTINGSGROUP PRE_COMMAND POST_COMMAND)
|
|
|
|
cmake_parse_arguments(_SQUISH "" "${oneValueArgs}" "" ${ARGN} )
|
|
|
|
if(_SQUISH_UNPARSED_ARGUMENTS)
|
|
message(FATAL_ERROR "Unknown keywords given to SQUISH_ADD_TEST(): \"${_SQUISH_UNPARSED_ARGUMENTS}\"")
|
|
endif()
|
|
|
|
if(NOT _SQUISH_AUT)
|
|
message(FATAL_ERROR "Required argument AUT not given for SQUISH_ADD_TEST()")
|
|
endif()
|
|
|
|
if(NOT _SQUISH_SUITE)
|
|
message(FATAL_ERROR "Required argument SUITE not given for SQUISH_ADD_TEST()")
|
|
endif()
|
|
|
|
if(NOT _SQUISH_TEST)
|
|
message(FATAL_ERROR "Required argument TEST not given for SQUISH_ADD_TEST()")
|
|
endif()
|
|
|
|
get_filename_component(absTestSuite "${_SQUISH_SUITE}" ABSOLUTE)
|
|
if(NOT EXISTS "${absTestSuite}")
|
|
message(FATAL_ERROR "Could not find squish test suite ${_SQUISH_SUITE} (checked ${absTestSuite})")
|
|
endif()
|
|
|
|
set(absTestCase "${absTestSuite}/${_SQUISH_TEST}")
|
|
if(NOT EXISTS "${absTestCase}")
|
|
message(FATAL_ERROR "Could not find squish testcase ${_SQUISH_TEST} (checked ${absTestCase})")
|
|
endif()
|
|
|
|
if(_SQUISH_SETTINGSGROUP)
|
|
message("SETTINGSGROUP is deprecated and will be ignored.")
|
|
endif()
|
|
|
|
# There's no target used for this command, so we don't need to do anything
|
|
# here for CMP0178.
|
|
add_test(NAME ${testName}
|
|
COMMAND ${CMAKE_COMMAND} -V -VV
|
|
"-Dsquish_version:STRING=4"
|
|
"-Dsquish_aut:STRING=$<TARGET_FILE_BASE_NAME:${_SQUISH_AUT}>"
|
|
"-Dsquish_aut_dir:STRING=$<TARGET_FILE_DIR:${_SQUISH_AUT}>"
|
|
"-Dsquish_server_executable:STRING=${SQUISH_SERVER_EXECUTABLE}"
|
|
"-Dsquish_client_executable:STRING=${SQUISH_CLIENT_EXECUTABLE}"
|
|
"-Dsquish_libqtdir:STRING=${QT_LIBRARY_DIR}"
|
|
"-Dsquish_test_suite:STRING=${absTestSuite}"
|
|
"-Dsquish_test_case:STRING=${_SQUISH_TEST}"
|
|
"-Dsquish_env_vars:STRING=${envVars}"
|
|
"-Dsquish_wrapper:STRING=${testWrapper}"
|
|
"-Dsquish_module_dir:STRING=${_SQUISH_MODULE_DIR}"
|
|
"-Dsquish_pre_command:STRING=${_SQUISH_PRE_COMMAND}"
|
|
"-Dsquish_post_command:STRING=${_SQUISH_POST_COMMAND}"
|
|
-P "${_SQUISH_MODULE_DIR}/SquishTestScript.cmake"
|
|
)
|
|
set_tests_properties(${testName}
|
|
PROPERTIES FAIL_REGULAR_EXPRESSION "FAIL;FAILED;ERROR;FATAL"
|
|
)
|
|
endfunction()
|
|
|
|
macro(squish_add_test)
|
|
if("${SQUISH_VERSION_MAJOR}" STRGREATER "3")
|
|
squish_v4_add_test(${ARGV})
|
|
else()
|
|
squish_v3_add_test(${ARGV})
|
|
endif()
|
|
endmacro()
|