gmock_cheat_sheet.md 11.3 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
136
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.

To customize the default action for functions with return type *`T`*:
137

138
```cpp
139
140
141
142
143
using ::testing::DefaultValue;

// Sets the default value to be returned. T must be CopyConstructible.
DefaultValue<T>::Set(value);
// Sets a factory. Will be invoked on demand. T must be MoveConstructible.
144
//  T MakeT();
145
146
147
148
149
150
DefaultValue<T>::SetFactory(&MakeT);
// ... use the mocks ...
// Resets the default value.
DefaultValue<T>::Clear();
```

151
152
Example usage:

153
```cpp
154
155
156
157
158
159
160
161
162
163
164
  // 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
165
166
  EXPECT_NE(buzz1, nullptr);
  EXPECT_NE(buzz2, nullptr);
167
168
169
170
171
  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();
172
173
```

174
175
176
To customize the default action for a particular method of a specific mock
object, use `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
Abseil Team's avatar
Abseil Team committed
177
178
mock method is called). See [here](gmock_cook_book.md#UseOnCall) for a more
detailed discussion.
179

180
```cpp
181
182
183
ON_CALL(mock-object, method(matchers))
    .With(multi-argument-matcher)   ?
    .WillByDefault(action);
184
185
```

Abseil Team's avatar
Abseil Team committed
186
## Setting Expectations {#ExpectCall}
187

188
189
`EXPECT_CALL()` sets **expectations** on a mock method (How will it be called?
What will it do?):
190

191
```cpp
192
193
194
195
196
197
198
199
EXPECT_CALL(mock-object, method (matchers)?)
     .With(multi-argument-matcher)  ?
     .Times(cardinality)            ?
     .InSequence(sequences)         *
     .After(expectations)           *
     .WillOnce(action)              *
     .WillRepeatedly(action)        ?
     .RetiresOnSaturation();        ?
200
201
```

Abseil Team's avatar
Abseil Team committed
202
203
204
205
206
207
208
209
210
For each item above, `?` means it can be used at most once, while `*` means it
can be used any number of times.

In order to pass, `EXPECT_CALL` must be used before the calls are actually made.

The `(matchers)` is a comma-separated list of matchers that correspond to each
of the arguments of `method`, and sets the expectation only for calls of
`method` that matches all of the matchers.

211
212
If `(matchers)` is omitted, the expectation is the same as if the matchers were
set to anything matchers (for example, `(_, _, _, _)` for a four-arg method).
213

214
If `Times()` is omitted, the cardinality is assumed to be:
215

216
217
218
219
220
221
222
223
224
*   `Times(1)` when there is neither `WillOnce()` nor `WillRepeatedly()`;
*   `Times(n)` when there are `n` `WillOnce()`s but no `WillRepeatedly()`, where
    `n` >= 1; or
*   `Times(AtLeast(n))` when there are `n` `WillOnce()`s and a
    `WillRepeatedly()`, where `n` >= 0.

A method with no `EXPECT_CALL()` is free to be invoked *any number of times*,
and the default action will be taken each time.

Abseil Team's avatar
Abseil Team committed
225
## Matchers {#MatcherList}
226

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

Abseil Team's avatar
Abseil Team committed
229
## Actions {#ActionList}
230

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

Abseil Team's avatar
Abseil Team committed
233
## Cardinalities {#CardinalityList}
234

235
236
These are used in `Times()` to specify how many times a mock function will be
called:
237

238
|                   |                                                        |
239
240
241
242
| :---------------- | :----------------------------------------------------- |
| `AnyNumber()`     | The function can be called any number of times.        |
| `AtLeast(n)`      | The call is expected at least `n` times.               |
| `AtMost(n)`       | The call is expected at most `n` times.                |
Abseil Team's avatar
Abseil Team committed
243
244
| `Between(m, n)`   | The call is expected between `m` and `n` (inclusive) times. |
| `Exactly(n) or n` | The call is expected exactly `n` times. In particular, the call should never happen when `n` is 0. |
245

Abseil Team's avatar
Abseil Team committed
246
## Expectation Order
247

248
249
250
By default, the expectations can be matched in *any* order. If some or all
expectations must be matched in a given order, there are two ways to specify it.
They can be used either independently or together.
251

Abseil Team's avatar
Abseil Team committed
252
### The After Clause {#AfterClause}
253

254
```cpp
255
256
257
258
259
using ::testing::Expectation;
...
Expectation init_x = EXPECT_CALL(foo, InitX());
Expectation init_y = EXPECT_CALL(foo, InitY());
EXPECT_CALL(foo, Bar())
260
     .After(init_x, init_y);
261
262
```

263
264
265
266
267
says that `Bar()` can be called only after both `InitX()` and `InitY()` have
been called.

If you don't know how many pre-requisites an expectation has when you write it,
you can use an `ExpectationSet` to collect them:
268

269
```cpp
270
271
272
273
274
275
276
using ::testing::ExpectationSet;
...
ExpectationSet all_inits;
for (int i = 0; i < element_count; i++) {
  all_inits += EXPECT_CALL(foo, InitElement(i));
}
EXPECT_CALL(foo, Bar())
277
     .After(all_inits);
278
279
```

280
281
282
283
284
says that `Bar()` can be called only after all elements have been initialized
(but we don't care about which elements get initialized before the others).

Modifying an `ExpectationSet` after using it in an `.After()` doesn't affect the
meaning of the `.After()`.
285

Abseil Team's avatar
Abseil Team committed
286
### Sequences {#UsingSequences}
287

288
When you have a long chain of sequential expectations, it's easier to specify
Abseil Team's avatar
Abseil Team committed
289
the order using **sequences**, which don't require you to give each expectation
290
291
in the chain a different name. *All expected calls* in the same sequence must
occur in the order they are specified.
292

293
```cpp
294
using ::testing::Return;
295
296
297
298
299
300
301
302
303
304
305
306
307
using ::testing::Sequence;
Sequence s1, s2;
...
EXPECT_CALL(foo, Reset())
    .InSequence(s1, s2)
    .WillOnce(Return(true));
EXPECT_CALL(foo, GetSize())
    .InSequence(s1)
    .WillOnce(Return(1));
EXPECT_CALL(foo, Describe(A<const char*>()))
    .InSequence(s2)
    .WillOnce(Return("dummy"));
```
308
309
310

says that `Reset()` must be called before *both* `GetSize()` *and* `Describe()`,
and the latter two can occur in any order.
311
312

To put many expectations in a sequence conveniently:
313

314
```cpp
315
316
using ::testing::InSequence;
{
317
  InSequence seq;
318
319
320
321
322
323
324
325

  EXPECT_CALL(...)...;
  EXPECT_CALL(...)...;
  ...
  EXPECT_CALL(...)...;
}
```

326
327
328
says that all expected calls in the scope of `seq` must occur in strict order.
The name `seq` is irrelevant.

Abseil Team's avatar
Abseil Team committed
329
## Verifying and Resetting a Mock
330
331
332

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

334
```cpp
335
336
337
using ::testing::Mock;
...
// Verifies and removes the expectations on mock_obj;
338
// returns true if and only if successful.
339
340
341
342
Mock::VerifyAndClearExpectations(&mock_obj);
...
// Verifies and removes the expectations on mock_obj;
// also removes the default actions set by ON_CALL();
343
// returns true if and only if successful.
344
345
346
Mock::VerifyAndClear(&mock_obj);
```

Abseil Team's avatar
Abseil Team committed
347
348
349
350
351
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.

352
353
354
You can also tell gMock that a mock object can be leaked and doesn't need to be
verified:

355
```cpp
356
357
358
Mock::AllowLeak(&mock_obj);
```

Abseil Team's avatar
Abseil Team committed
359
## Mock Classes
360
361

gMock defines a convenient mock class template
362

363
```cpp
364
365
class MockFunction<R(A1, ..., An)> {
 public:
366
  MOCK_METHOD(R, Call, (A1, ..., An));
367
368
};
```
369

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

Abseil Team's avatar
Abseil Team committed
373
## Flags
374

375
376
| Flag                           | Description                               |
| :----------------------------- | :---------------------------------------- |
Abseil Team's avatar
Abseil Team committed
377
378
| `--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. |