FindGTest¶
Finds GoogleTest, the Google C++ testing and mocking framework:
find_package(GTest [...])
The GoogleTest framework also includes GoogleMock, a library for writing and using C++ mock classes. On some systems, GoogleMock may be distributed as a separate package.
When both debug and release (optimized) variants of the GoogleTest and GoogleMock libraries are available, this module selects the appropriate variants based on the current Build Configuration.
Added in version 3.20: If GoogleTest is built and installed using its CMake-based build system, it
provides a package configuration file
(GTestConfig.cmake) that can be used with find_package() in
Config mode. By default, this module now searches for that
configuration file and, if found, returns the results without further
action. If the upstream configuration file is not found, this module falls
back to Module mode and searches standard locations.
Imported Targets¶
This module provides the following Imported Targets:
GTest::gtestAdded in version 3.20.
Target encapsulating the usage requirements of the GoogleTest
gtestlibrary, available if GoogleTest is found. Thegtestlibrary provides the core GoogleTest testing framework functionality.GTest::gtest_mainAdded in version 3.20.
Target encapsulating the usage requirements of the GoogleTest
gtest_mainlibrary, available if GoogleTest is found. Thegtest_mainlibrary provides amain()function, allowing tests to be run without defining one manually.Only link to
GTest::gtest_mainif GoogleTest should supply themain()function for the executable. If the project is supplying its ownmain()implementation, link only toGTest::gtest.GTest::gmockAdded in version 3.23.
Target encapsulating the usage requirements of the GoogleMock
gmocklibrary, available if GoogleTest and its Mock library are found. Thegmocklibrary provides facilities for writing and using mock classes in C++.GTest::gmock_mainAdded in version 3.23.
Target encapsulating the usage requirements of the GoogleMock
gmock_mainlibrary, available if GoogleTest andgmock_mainare found. Thegmock_mainlibrary provides amain()function, allowing GoogleMock tests to be run without defining one manually.Only link to
GTest::gmock_mainif GoogleTest should supply themain()function for the executable. If project is supplying its ownmain()implementation, link only toGTest::gmock.
Result Variables¶
This module defines the following variables:
GTest_FOUNDAdded in version 3.3.
Boolean indicating whether GoogleTest was found.
Hints¶
This module accepts the following variables before calling
find_package(GTest):
GTEST_ROOTThe root directory of the GoogleTest installation (may also be set as an environment variable). This variable is used only when GoogleTest is found in Module mode.
GTEST_MSVC_SEARCHWhen compiling with MSVC, this variable controls which GoogleTest build variant to search for, based on the runtime library linkage model. This variable is used only when GoogleTest is found in Module mode and accepts one of the following values:
MD(Default) Searches for shared library variants of GoogleTest that are built to link against the dynamic C runtime. These libraries are typically compiled with the MSVC runtime flags
/MDor/MDd(for Release or Debug, respectively).MTSearches for static library variants of GoogleTest that are built to link against the static C runtime. These libraries are typically compiled with the MSVC runtime flags
/MTor/MTd.
Deprecated Items¶
Deprecated Variables¶
The following variables are provided for backward compatibility:
GTEST_INCLUDE_DIRSDeprecated since version 4.1: Use the
GTest::gtestimported target instead, which exposes the required include directories through itsINTERFACE_INCLUDE_DIRECTORIEStarget property.Result variable that provides include directories containing headers needed to use GoogleTest. This variable is only guaranteed to be available when GoogleTest is found in Module mode.
GTEST_LIBRARIESDeprecated since version 4.1: Use the
GTest::gtestimported target instead.Result variable providing libraries needed to link against to use the GoogleTest
gtestlibrary. Note that projects are also responsible for linking with an appropriate thread library in addition to the libraries specified by this variable.GTEST_MAIN_LIBRARIESDeprecated since version 4.1: Use the
GTest::gtest_mainimported target instead.Result variable providing libraries needed to link against to use the GoogleTest
gtest_mainlibrary.GTEST_BOTH_LIBRARIESDeprecated since version 4.1: Use the
GTest::gtestandGTest::gtest_mainimported targets instead.Result variable providing both
gtestandgtest_mainlibraries combined.GTEST_FOUNDDeprecated since version 4.2: Use
GTest_FOUND, which has the same value.Boolean indicating whether GoogleTest was found.
Deprecated Imported Targets¶
For backward compatibility, this module also provides the following imported targets (available since CMake 3.5):
GTest::GTestDeprecated since version 3.20: Use the
GTest::gtestimported target instead.Imported target linking the
GTest::gtestlibrary.GTest::MainDeprecated since version 3.20: Use the
GTest::gtest_mainimported target instead.Imported target linking the
GTest::gtest_mainlibrary.
Examples¶
Examples: Finding GoogleTest¶
Finding GoogleTest:
find_package(GoogleTest)
Or, finding GoogleTest and making it required (if not found, processing stops with an error message):
find_package(GoogleTest REQUIRED)
Examples: Using Imported Targets¶
In the following example, the GTest::gtest imported target is linked to
a project target, which enables using the core GoogleTest testing framework:
find_package(GTest REQUIRED)
target_link_libraries(foo PRIVATE GTest::gtest)
In the next example, the GTest::gtest_main imported target is also linked
to the executable, and a test is registered. The GTest::gtest_main library
provides a main() function, so there is no need to write one manually.
The GTest::gtest library is still linked because the test code directly
uses things provided by GTest::gtest, and good practice is to link directly
to libraries used directly.
enable_testing()
find_package(GTest REQUIRED)
add_executable(foo foo.cc)
target_link_libraries(foo PRIVATE GTest::gtest GTest::gtest_main)
add_test(NAME AllTestsInFoo COMMAND foo)
Deeper Integration With CTest¶
This module is commonly used with the GoogleTest module, which
provides gtest_discover_tests() and gtest_add_tests()
commands to help integrate GoogleTest infrastructure with CTest:
find_package(GTest)
target_link_libraries(example PRIVATE GTest::gtest GTest::gtest_main)
include(GoogleTest)
gtest_discover_tests(example)
# ...
Changed in version 3.9: Previous CMake versions defined the gtest_add_tests() command in
this module.