git clone https://github.com/google/googletest.git -b release-1.11.0
cd googletest
mkdir build
cd build
cmake ..
make
make install
a.hpp
a.cpp
main_test.cpp
main.cpp
CMakeFiles.txt
Run using ctest
or ./unit_test
- Assertions - statements that check whether a condition is true. Assertion’s result can be success, nonfatal failure, or fatal failure. If a fatal failure occurs, it aborts the current function; otherwise the program continues normally.
- A test suite contains one or many tests. You should group your tests into test suites that reflect the structure of the tested code. When multiple tests in a test suite need to share common objects and subroutines, you can put them into a test fixture class.
- A test program can contain multiple test suites.
EXPECT_*
versions generate nonfatal failures, which don’t abort the current function.ASSERT_*
versions generate fatal failures when they fail, and abort the current function.ASSERT_*
may cause a space leak as it returns from the current function immediately, possibly skipping clean-up code. Hence, you may get a heap checker error in addition to assertion errors.- Providing custom failure message :
ASSERT_EQ(x.size(), y.size()) << "Vectors x and y are of unequal length";
TEST()
- These are ordinary C++ functions that don’t return a value.
TEST(TestSuiteName, TestName)
{
... test body ...
}
Note : TestSuiteName
and TestName
names must be valid C++ identifiers, and they should not contain any underscores (_
)
If you find yourself writing two or more tests that operate on similar data, you can use a test fixture. This allows you to reuse the same configuration of objects for several different tests.
To create a fixture:
- Derive a class from
::testing::Test
. Start its body withprotected:
, as we’ll want to access fixture members from sub-classes. - Inside the class, declare any objects you plan to use.
- If necessary, write a default constructor or
SetUp()
function to prepare the objects for each test. Useoverride
in C++11 to make sure you spelled it correctly. - If necessary, write a destructor or
TearDown()
function to release any resources you allocated inSetUp()
. To learn when you should use the constructor/destructor and when you should useSetUp()/TearDown()
, read the FAQ. - If needed, define subroutines for your tests to share.
TEST_F(TestFixtureName, TestName)
{
... test body ...
}
Note : First define a test fixture class before using it in a TEST_F()
, or you’ll get the compiler error “virtual outside class declaration
”.
For each test defined with TEST_F()
, googletest will create a fresh test fixture at runtime, immediately initialize it via SetUp()
, run the test, clean up by calling TearDown()
, and then delete the test fixture.
googletest does not reuse the same test fixture for multiple tests.
template <typename E> // E is the element type.
class Queue {
public:
Queue();
void Enqueue(const E& element);
E* Dequeue(); // Returns NULL if the queue is empty.
size_t size() const;
...
};
class QueueTest : public ::testing::Test {
protected:
void SetUp() override
{
q1_.Enqueue(1);
q2_.Enqueue(2);
q2_.Enqueue(3);
}
// void TearDown() override {}
Queue<int> q0_;
Queue<int> q1_;
Queue<int> q2_;
};
TEST_F(QueueTest, IsEmptyInitially)
{
EXPECT_EQ(q0_.size(), 0);
}
TEST_F(QueueTest, DequeueWorks)
{
int* n = q0_.Dequeue();
EXPECT_EQ(n, nullptr);
n = q1_.Dequeue();
ASSERT_NE(n, nullptr);
EXPECT_EQ(*n, 1);
EXPECT_EQ(q1_.size(), 0);
delete n;
n = q2_.Dequeue();
ASSERT_NE(n, nullptr);
EXPECT_EQ(*n, 2);
EXPECT_EQ(q2_.size(), 1);
delete n;
}
Note :
- You must not ignore the return value of
RUN_ALL_TESTS()
, or you will get a compiler error. - You should call
RUN_ALL_TESTS()
only once. Calling it more than once conflicts with some advanced googletest features
When you write a prototype or test, often it’s not feasible or wise to rely on real objects entirely. A mock object implements the same interface as a real object (so it can be used as one), but lets you specify at run time how it will be used and what it should do (which methods will be called? in which order? how many times? with what arguments? what will they return? etc).
// gmock_test.cpp
#include "a.hpp"
#include "gmock/gmock.h"
#include "gtest/gtest.h"
class FooBarMock : public FooBar
{
public:
MOCK_METHOD(char, getByte, (char *));
MOCK_METHOD(void, writeByte, (const std::string &));
MOCK_METHOD(std::string, readByte, ());
};
using ::testing::AtLeast;
TEST(FooBarMock, CanReadFile)
{
FooBarMock foo;
EXPECT_CALL(foo, readByte()).Times(AtLeast(1));
foo.writeByte("Hello, world!");
foo.readByte();
}
Note : gMock requires expectations to be set before the mock functions are called, otherwise the behavior is undefined.
class FakeFooBar : public FooBar
{
public:
std::string readByte() override
{
return "Child hello!";
}
};
class MockFooBar : public FooBar
{
private:
FakeFooBar fake_;
public:
MOCK_METHOD(char, getByte, (char *), (override));
MOCK_METHOD(void, writeByte, (const std::string &), (override));
MOCK_METHOD(std::string, readByte, (), (override));
void DelegateToFake()
{
ON_CALL(*this, readByte).WillByDefault([this]()
{ return fake_.readByte(); });
}
};
TEST(FakeFooBar, CanFake)
{
std::shared_ptr<MockFooBar> foo(new MockFooBar);
foo->DelegateToFake();
EXPECT_CALL(*foo, readByte()).Times(AtLeast(1));
EXPECT_CALL(*foo, writeByte).Times(AtLeast(1));
EXPECT_CALL(*foo, getByte).Times(AtLeast(1));
ReaderWriter rw(foo.get());
rw.operation();
foo->writeByte("Hello, world!");
EXPECT_EQ("Child hello!", foo->readByte());
}
Note : A call to DelegateToFake()
is necessary to enable the delegation to fake functions