.. _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.
