|
|
# Quickstart: Building with Bazel
This tutorial aims to get you up and running with GoogleTest using the Bazel build system. If you're using GoogleTest for the first time or need a refresher, we recommend this tutorial as a starting point.
## Prerequisites
To complete this tutorial, you'll need:
* A compatible operating system (e.g. Linux, macOS, Windows). * A compatible C++ compiler that supports at least C++11. * [Bazel](https://bazel.build/), the preferred build system used by the GoogleTest team.
See [Supported Platforms](platforms.md) for more information about platforms compatible with GoogleTest.
If you don't already have Bazel installed, see the [Bazel installation guide](https://docs.bazel.build/versions/master/install.html).
{: .callout .note} Note: The terminal commands in this tutorial show a Unix shell prompt, but the commands work on the Windows command line as well.
## Set up a Bazel workspace
A [Bazel workspace](https://docs.bazel.build/versions/master/build-ref.html#workspace) is a directory on your filesystem that you use to manage source files for the software you want to build. Each workspace directory has a text file named `WORKSPACE` which may be empty, or may contain references to external dependencies required to build the outputs.
First, create a directory for your workspace:
``` $ mkdir my_workspace && cd my_workspace ```
Next, you’ll create the `WORKSPACE` file to specify dependencies. A common and recommended way to depend on GoogleTest is to use a [Bazel external dependency](https://docs.bazel.build/versions/master/external.html) via the [`http_archive` rule](https://docs.bazel.build/versions/master/repo/http.html#http_archive). To do this, in the root directory of your workspace (`my_workspace/`), create a file named `WORKSPACE` with the following contents:
``` load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive( name = "com_google_googletest", urls = ["https://github.com/google/googletest/archive/609281088cfefc76f9d0ce82e1ff6c30cc3591e5.zip"], strip_prefix = "googletest-609281088cfefc76f9d0ce82e1ff6c30cc3591e5", ) ```
The above configuration declares a dependency on GoogleTest which is downloaded as a ZIP archive from GitHub. In the above example, `609281088cfefc76f9d0ce82e1ff6c30cc3591e5` is the Git commit hash of the GoogleTest version to use; we recommend updating the hash often to point to the latest version.
Bazel also needs a dependency on the [`rules_cc` repository](https://github.com/bazelbuild/rules_cc) to build C++ code, so add the following to the `WORKSPACE` file:
``` http_archive( name = "rules_cc", urls = ["https://github.com/bazelbuild/rules_cc/archive/40548a2974f1aea06215272d9c2b47a14a24e556.zip"], strip_prefix = "rules_cc-40548a2974f1aea06215272d9c2b47a14a24e556", ) ```
Now you're ready to build C++ code that uses GoogleTest.
## Create and run a binary
With your Bazel workspace set up, you can now use GoogleTest code within your own project.
As an example, create a file named `hello_test.cc` in your `my_workspace` directory with the following contents:
```cpp #include <gtest/gtest.h>
// Demonstrate some basic assertions. TEST(HelloTest, BasicAssertions) { // Expect two strings not to be equal. EXPECT_STRNE("hello", "world"); // Expect equality. EXPECT_EQ(7 * 6, 42); } ```
GoogleTest provides [assertions](primer.md#assertions) that you use to test the behavior of your code. The above sample includes the main GoogleTest header file and demonstrates some basic assertions.
To build the code, create a file named `BUILD` in the same directory with the following contents:
``` load("@rules_cc//cc:defs.bzl", "cc_test")
cc_test( name = "hello_test", size = "small", srcs = ["hello_test.cc"], deps = ["@com_google_googletest//:gtest_main"], ) ```
This `cc_test` rule declares the C++ test binary you want to build, and links to GoogleTest (`//:gtest_main`) using the prefix you specified in the `WORKSPACE` file (`@com_google_googletest`). For more information about Bazel `BUILD` files, see the [Bazel C++ Tutorial](https://docs.bazel.build/versions/master/tutorial/cpp.html).
Now you can build and run your test:
<pre> <strong>my_workspace$ bazel test --test_output=all //:hello_test</strong> INFO: Analyzed target //:hello_test (26 packages loaded, 362 targets configured). INFO: Found 1 test target... INFO: From Testing //:hello_test: ==================== Test output for //:hello_test: Running main() from gmock_main.cc [==========] Running 1 test from 1 test suite. [----------] Global test environment set-up. [----------] 1 test from HelloTest [ RUN ] HelloTest.BasicAssertions [ OK ] HelloTest.BasicAssertions (0 ms) [----------] 1 test from HelloTest (0 ms total)
[----------] Global test environment tear-down [==========] 1 test from 1 test suite ran. (0 ms total) [ PASSED ] 1 test. ================================================================================ Target //:hello_test up-to-date: bazel-bin/hello_test INFO: Elapsed time: 4.190s, Critical Path: 3.05s INFO: 27 processes: 8 internal, 19 linux-sandbox. INFO: Build completed successfully, 27 total actions //:hello_test PASSED in 0.1s
INFO: Build completed successfully, 27 total actions </pre>
Congratulations! You've successfully built and run a test binary using GoogleTest.
## Next steps
* [Check out the Primer](primer.md) to start learning how to write simple tests. * [See the code samples](samples.md) for more examples showing how to use a variety of GoogleTest features.
|