blob: fa4d08ebe422d29058b9d0b51e0196d7b103173f [file] [log] [blame]
.. _module-pw_third_party_googletest:
==========
GoogleTest
==========
The ``$dir_pw_third_party/googletest/`` module provides various helpers to
optionally use full upstream `GoogleTest/GoogleMock`__ with
:ref:`module-pw_unit_test`.
.. __: https://github.com/google/googletest
.. _module-pw_third_party_googletest-using_upstream:
----------------------------------------
Using upstream GoogleTest and GoogleMock
----------------------------------------
If you want to use the full upstream GoogleTest/GoogleMock, you must do the
following:
Add GoogleTest to your workspace with the following command.
.. code-block:: sh
git submodule add https://github.com/google/googletest third_party/googletest
Configure ``pw_unit_test`` to use upstream GoogleTest/GoogleMock.
.. tab-set::
.. tab-item:: GN
* Set the GN var ``dir_pw_third_party_googletest`` to the location of the
GoogleTest source. If you are using a different version of the upstream
GoogleTest, or a different target than ``//third_party/googletest``, set
``pw_unit_test_GOOGLETEST_BACKEND`` to point to your GoogleTest target
instead.
* Set the GN var ``pw_unit_test_MAIN`` to
``dir_pigweed + "/third_party/googletest:gmock_main"``.
* Set the GN var ``pw_unit_test_BACKEND`` to
``"//pw_unit_test:googletest"``.
Pigweed unit tests that do not work with upstream GoogleTest can be
disabled by setting ``enable_if`` to
``pw_unit_test_BACKEND == "$dir_pw_unit_test:light"``.
.. tab-item:: CMake
* Set the ``dir_pw_third_party_googletest`` to the location of the
GoogleTest source.
* Set the var
``pw_unit_test_MAIN`` to ``pw_third_party.googletest.gmock_main``.
* Set the var ``pw_unit_test_BACKEND`` to
``pw_unit_test.googletest``.
.. tab-item:: Bazel
Set the following :ref:`label flags <docs-build_system-bazel_flags>`,
either in your
:ref:`target config <docs-build_system-bazel_configuration>` or on
the command line:
* ``pw_unit_test_backend`` to
``@pigweed//pw_unit_test:googletest``.
* ``pw_unit_test_main`` to ``@com_google_googletest//:gtest_main``.
For example:
.. code-block:: sh
bazel test //... \
--@pigweed//pw_unit_test:backend=@pigweed//pw_unit_test:googletest \
--@pigweed//pw_unit_test:main=@com_google_googletest//:gtest_main
.. note::
Not all unit tests build properly with upstream GoogleTest yet. This is a
work in progress.