gmock_cheat_sheet.md 7.19 KB
Newer Older
Abseil Team's avatar
Abseil Team committed
1
# gMock Cheat Sheet
2

Abseil Team's avatar
Abseil Team committed
3
## Defining a Mock Class
4

Abseil Team's avatar
Abseil Team committed
5
### Mocking a Normal Class {#MockClass}
6
7

Given
8

9
```cpp
10
11
12
13
14
15
16
17
18
class Foo {
  ...
  virtual ~Foo();
  virtual int GetSize() const = 0;
  virtual string Describe(const char* name) = 0;
  virtual string Describe(int type) = 0;
  virtual bool Process(Bar elem, int count) = 0;
};
```
19

20
(note that `~Foo()` **must** be virtual) we can define its mock as
21

22
```cpp
23
24
25
#include "gmock/gmock.h"

class MockFoo : public Foo {
26
27
28
29
30
  ...
  MOCK_METHOD(int, GetSize, (), (const, override));
  MOCK_METHOD(string, Describe, (const char* name), (override));
  MOCK_METHOD(string, Describe, (int type), (override));
  MOCK_METHOD(bool, Process, (Bar elem, int count), (override));
31
32
33
};
```

34
35
36
37
To create a "nice" mock, which ignores all uninteresting calls, a "naggy" mock,
which warns on all uninteresting calls, or a "strict" mock, which treats them as
failures:

38
```cpp
39
40
41
42
43
44
45
using ::testing::NiceMock;
using ::testing::NaggyMock;
using ::testing::StrictMock;

NiceMock<MockFoo> nice_foo;      // The type is a subclass of MockFoo.
NaggyMock<MockFoo> naggy_foo;    // The type is a subclass of MockFoo.
StrictMock<MockFoo> strict_foo;  // The type is a subclass of MockFoo.
46
47
```

Abseil Team's avatar
Abseil Team committed
48
{: .callout .note}
49
50
51
**Note:** A mock object is currently naggy by default. We may make it nice by
default in the future.

Abseil Team's avatar
Abseil Team committed
52
### Mocking a Class Template {#MockTemplate}
53
54

Class templates can be mocked just like any class.
55
56

To mock
57

58
```cpp
59
60
61
62
63
64
65
66
template <typename Elem>
class StackInterface {
  ...
  virtual ~StackInterface();
  virtual int GetSize() const = 0;
  virtual void Push(const Elem& x) = 0;
};
```
67
68
69
70

(note that all member functions that are mocked, including `~StackInterface()`
**must** be virtual).

71
```cpp
72
73
74
template <typename Elem>
class MockStack : public StackInterface<Elem> {
  ...
75
76
  MOCK_METHOD(int, GetSize, (), (const, override));
  MOCK_METHOD(void, Push, (const Elem& x), (override));
77
78
79
};
```

Abseil Team's avatar
Abseil Team committed
80
### Specifying Calling Conventions for Mock Functions
81
82
83
84

If your mock function doesn't use the default calling convention, you can
specify it by adding `Calltype(convention)` to `MOCK_METHOD`'s 4th parameter.
For example,
85

86
```cpp
87
88
89
  MOCK_METHOD(bool, Foo, (int n), (Calltype(STDMETHODCALLTYPE)));
  MOCK_METHOD(int, Bar, (double x, double y),
              (const, Calltype(STDMETHODCALLTYPE)));
90
```
91

92
93
where `STDMETHODCALLTYPE` is defined by `<objbase.h>` on Windows.

Abseil Team's avatar
Abseil Team committed
94
## Using Mocks in Tests {#UsingMocks}
95

96
97
98
99
100
101
102
103
104
105
106
107
108
109
The typical work flow is:

1.  Import the gMock names you need to use. All gMock symbols are in the
    `testing` namespace unless they are macros or otherwise noted.
2.  Create the mock objects.
3.  Optionally, set the default actions of the mock objects.
4.  Set your expectations on the mock objects (How will they be called? What
    will they do?).
5.  Exercise code that uses the mock objects; if necessary, check the result
    using googletest assertions.
6.  When a mock object is destructed, gMock automatically verifies that all
    expectations on it have been satisfied.

Here's an example:
110

111
112
```cpp
using ::testing::Return;                          // #1
113
114
115
116
117
118
119
120
121
122
123
124
125

TEST(BarTest, DoesThis) {
  MockFoo foo;                                    // #2

  ON_CALL(foo, GetSize())                         // #3
      .WillByDefault(Return(1));
  // ... other default actions ...

  EXPECT_CALL(foo, Describe(5))                   // #4
      .Times(3)
      .WillRepeatedly(Return("Category 5"));
  // ... other expectations ...

Abseil Team's avatar
Abseil Team committed
126
  EXPECT_EQ(MyProductionFunction(&foo), "good");  // #5
127
128
129
}                                                 // #6
```

Abseil Team's avatar
Abseil Team committed
130
## Setting Default Actions {#OnCall}
131

132
133
134
135
gMock has a **built-in default action** for any function that returns `void`,
`bool`, a numeric value, or a pointer. In C++11, it will additionally returns
the default-constructed value, if one exists for the given type.

Abseil Team's avatar
Abseil Team committed
136
137
To customize the default action for functions with return type `T`, use
[`DefaultValue<T>`](reference/mocking.md#DefaultValue). For example:
138

139
```cpp
140
141
142
143
144
145
146
147
148
149
150
  // Sets the default action for return type std::unique_ptr<Buzz> to
  // creating a new Buzz every time.
  DefaultValue<std::unique_ptr<Buzz>>::SetFactory(
      [] { return MakeUnique<Buzz>(AccessLevel::kInternal); });

  // When this fires, the default action of MakeBuzz() will run, which
  // will return a new Buzz object.
  EXPECT_CALL(mock_buzzer_, MakeBuzz("hello")).Times(AnyNumber());

  auto buzz1 = mock_buzzer_.MakeBuzz("hello");
  auto buzz2 = mock_buzzer_.MakeBuzz("hello");
Abseil Team's avatar
Abseil Team committed
151
152
  EXPECT_NE(buzz1, nullptr);
  EXPECT_NE(buzz2, nullptr);
153
154
155
156
157
  EXPECT_NE(buzz1, buzz2);

  // Resets the default action for return type std::unique_ptr<Buzz>,
  // to avoid interfere with other tests.
  DefaultValue<std::unique_ptr<Buzz>>::Clear();
158
159
```

160
To customize the default action for a particular method of a specific mock
Abseil Team's avatar
Abseil Team committed
161
162
163
164
165
object, use [`ON_CALL`](reference/mocking.md#ON_CALL). `ON_CALL` has a similar
syntax to `EXPECT_CALL`, but it is used for setting default behaviors when you
do not require that the mock method is called. See
[Knowing When to Expect](gmock_cook_book.md#UseOnCall) for a more detailed
discussion.
166

Abseil Team's avatar
Abseil Team committed
167
## Setting Expectations {#ExpectCall}
168

Abseil Team's avatar
Abseil Team committed
169
See [`EXPECT_CALL`](reference/mocking.md#EXPECT_CALL) in the Mocking Reference.
170

Abseil Team's avatar
Abseil Team committed
171
## Matchers {#MatcherList}
172

Abseil Team's avatar
Abseil Team committed
173
See the [Matchers Reference](reference/matchers.md).
174

Abseil Team's avatar
Abseil Team committed
175
## Actions {#ActionList}
176

Abseil Team's avatar
Abseil Team committed
177
See the [Actions Reference](reference/actions.md).
178

Abseil Team's avatar
Abseil Team committed
179
## Cardinalities {#CardinalityList}
180

Abseil Team's avatar
Abseil Team committed
181
182
See the [`Times` clause](reference/mocking.md#EXPECT_CALL.Times) of
`EXPECT_CALL` in the Mocking Reference.
183

Abseil Team's avatar
Abseil Team committed
184
## Expectation Order
185

Abseil Team's avatar
Abseil Team committed
186
187
188
189
190
By default, expectations can be matched in *any* order. If some or all
expectations must be matched in a given order, you can use the
[`After` clause](reference/mocking.md#EXPECT_CALL.After) or
[`InSequence` clause](reference/mocking.md#EXPECT_CALL.InSequence) of
`EXPECT_CALL`, or use an [`InSequence` object](reference/mocking.md#InSequence).
191

Abseil Team's avatar
Abseil Team committed
192
## Verifying and Resetting a Mock
193
194
195

gMock will verify the expectations on a mock object when it is destructed, or
you can do it earlier:
196

197
```cpp
198
199
200
using ::testing::Mock;
...
// Verifies and removes the expectations on mock_obj;
201
// returns true if and only if successful.
202
203
204
205
Mock::VerifyAndClearExpectations(&mock_obj);
...
// Verifies and removes the expectations on mock_obj;
// also removes the default actions set by ON_CALL();
206
// returns true if and only if successful.
207
208
209
Mock::VerifyAndClear(&mock_obj);
```

Abseil Team's avatar
Abseil Team committed
210
211
212
213
214
Do not set new expectations after verifying and clearing a mock after its use.
Setting expectations after code that exercises the mock has undefined behavior.
See [Using Mocks in Tests](gmock_for_dummies.md#using-mocks-in-tests) for more
information.

215
216
217
You can also tell gMock that a mock object can be leaked and doesn't need to be
verified:

218
```cpp
219
220
221
Mock::AllowLeak(&mock_obj);
```

Abseil Team's avatar
Abseil Team committed
222
## Mock Classes
223
224

gMock defines a convenient mock class template
225

226
```cpp
227
228
class MockFunction<R(A1, ..., An)> {
 public:
229
  MOCK_METHOD(R, Call, (A1, ..., An));
230
231
};
```
232

Abseil Team's avatar
Abseil Team committed
233
234
See this [recipe](gmock_cook_book.md#using-check-points) for one application of
it.
235

Abseil Team's avatar
Abseil Team committed
236
## Flags
237

238
239
| Flag                           | Description                               |
| :----------------------------- | :---------------------------------------- |
Abseil Team's avatar
Abseil Team committed
240
241
| `--gmock_catch_leaked_mocks=0` | Don't report leaked mock objects as failures. |
| `--gmock_verbose=LEVEL` | Sets the default verbosity level (`info`, `warning`, or `error`) of Google Mock messages. |