gmock_cheat_sheet.md 17.5 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
231
232

**Actions** specify what a mock function should do when invoked.

Abseil Team's avatar
Abseil Team committed
233
### Returning a Value
234

Abseil Team's avatar
Abseil Team committed
235
236
237
238
239
240
241
242
243
244
245
|                                   |                                               |
| :-------------------------------- | :-------------------------------------------- |
| `Return()`                        | Return from a `void` mock function.           |
| `Return(value)`                   | Return `value`. If the type of `value` is     different to the mock function's return type, `value` is converted to the latter type <i>at the time the expectation is set</i>, not when the action is executed. |
| `ReturnArg<N>()`                  | Return the `N`-th (0-based) argument.         |
| `ReturnNew<T>(a1, ..., ak)`       | Return `new T(a1, ..., ak)`; a different      object is created each time. |
| `ReturnNull()`                    | Return a null pointer.                        |
| `ReturnPointee(ptr)`              | Return the value pointed to by `ptr`.         |
| `ReturnRef(variable)`             | Return a reference to `variable`.             |
| `ReturnRefOfCopy(value)`          | Return a reference to a copy of `value`; the  copy lives as long as the action. |
| `ReturnRoundRobin({a1, ..., ak})` | Each call will return the next `ai` in the list, starting at the beginning when the end of the list is reached. |
246

Abseil Team's avatar
Abseil Team committed
247
### Side Effects
248

249
|                                    |                                         |
250
| :--------------------------------- | :-------------------------------------- |
Abseil Team's avatar
Abseil Team committed
251
252
253
254
| `Assign(&variable, value)` | Assign `value` to variable. |
| `DeleteArg<N>()` | Delete the `N`-th (0-based) argument, which must be a pointer. |
| `SaveArg<N>(pointer)` | Save the `N`-th (0-based) argument to `*pointer`. |
| `SaveArgPointee<N>(pointer)` | Save the value pointed to by the `N`-th (0-based) argument to `*pointer`. |
Abseil Team's avatar
Abseil Team committed
255
| `SetArgReferee<N>(value)` | Assign `value` to the variable referenced by the `N`-th (0-based) argument. |
Abseil Team's avatar
Abseil Team committed
256
257
258
259
260
| `SetArgPointee<N>(value)` | Assign `value` to the variable pointed by the `N`-th (0-based) argument. |
| `SetArgumentPointee<N>(value)` | Same as `SetArgPointee<N>(value)`. Deprecated. Will be removed in v1.7.0. |
| `SetArrayArgument<N>(first, last)` | Copies the elements in source range [`first`, `last`) to the array pointed to by the `N`-th (0-based) argument, which can be either a pointer or an iterator. The action does not take ownership of the elements in the source range. |
| `SetErrnoAndReturn(error, value)` | Set `errno` to `error` and return `value`. |
| `Throw(exception)` | Throws the given exception, which can be any copyable value. Available since v1.1.0. |
261

Abseil Team's avatar
Abseil Team committed
262
### Using a Function, Functor, or Lambda as an Action
263
264

In the following, by "callable" we mean a free function, `std::function`,
Abseil Team's avatar
Abseil Team committed
265
functor, or lambda.
266

267
|                                     |                                        |
268
| :---------------------------------- | :------------------------------------- |
Abseil Team's avatar
Abseil Team committed
269
270
271
272
273
274
| `f` | Invoke f with the arguments passed to the mock function, where f is a callable. |
| `Invoke(f)` | Invoke `f` with the arguments passed to the mock function, where `f` can be a global/static function or a functor. |
| `Invoke(object_pointer, &class::method)` | Invoke the method on the object with the arguments passed to the mock function. |
| `InvokeWithoutArgs(f)` | Invoke `f`, which can be a global/static function or a functor. `f` must take no arguments. |
| `InvokeWithoutArgs(object_pointer, &class::method)` | Invoke the method on the object, which takes no arguments. |
| `InvokeArgument<N>(arg1, arg2, ..., argk)` | Invoke the mock function's `N`-th (0-based) argument, which must be a function or a functor, with the `k` arguments. |
275
276
277
278
279
280

The return value of the invoked function is used as the return value of the
action.

When defining a callable to be used with `Invoke*()`, you can declare any unused
parameters as `Unused`:
281

282
```cpp
283
284
285
286
using ::testing::Invoke;
double Distance(Unused, double x, double y) { return sqrt(x*x + y*y); }
...
EXPECT_CALL(mock, Foo("Hi", _, _)).WillOnce(Invoke(Distance));
287
288
```

289
290
291
`Invoke(callback)` and `InvokeWithoutArgs(callback)` take ownership of
`callback`, which must be permanent. The type of `callback` must be a base
callback type instead of a derived one, e.g.
292

293
294
295
```cpp
  BlockingClosure* done = new BlockingClosure;
  ... Invoke(done) ...;  // This won't compile!
296

297
298
299
  Closure* done2 = new BlockingClosure;
  ... Invoke(done2) ...;  // This works.
```
300

301
In `InvokeArgument<N>(...)`, if an argument needs to be passed by reference,
ofats's avatar
ofats committed
302
wrap it inside `std::ref()`. For example,
303

304
305
306
```cpp
using ::testing::InvokeArgument;
...
ofats's avatar
ofats committed
307
InvokeArgument<2>(5, string("Hi"), std::ref(foo))
308
```
309

310
311
312
calls the mock function's #2 argument, passing to it `5` and `string("Hi")` by
value, and `foo` by reference.

Abseil Team's avatar
Abseil Team committed
313
### Default Action
314
315
316

| Matcher       | Description                                            |
| :------------ | :----------------------------------------------------- |
Abseil Team's avatar
Abseil Team committed
317
| `DoDefault()` | Do the default action (specified by `ON_CALL()` or the built-in one). |
318

Abseil Team's avatar
Abseil Team committed
319
{: .callout .note}
320
321
322
**Note:** due to technical reasons, `DoDefault()` cannot be used inside a
composite action - trying to do so will result in a run-time error.

Abseil Team's avatar
Abseil Team committed
323
### Composite Actions
324
325

|                                |                                             |
326
| :----------------------------- | :------------------------------------------ |
Abseil Team's avatar
Abseil Team committed
327
| `DoAll(a1, a2, ..., an)`       | Do all actions `a1` to `an` and return the result of `an` in each invocation. The first `n - 1` sub-actions must return void and will receive a  readonly view of the arguments. |
Abseil Team's avatar
Abseil Team committed
328
329
330
331
| `IgnoreResult(a)`              | Perform action `a` and ignore its result. `a` must not return void. |
| `WithArg<N>(a)`                | Pass the `N`-th (0-based) argument of the mock function to action `a` and perform it. |
| `WithArgs<N1, N2, ..., Nk>(a)` | Pass the selected (0-based) arguments of the mock function to action `a` and perform it. |
| `WithoutArgs(a)`               | Perform action `a` without any arguments. |
332

Abseil Team's avatar
Abseil Team committed
333
### Defining Actions
334
335

|                                    |                                         |
336
| :--------------------------------- | :-------------------------------------- |
Abseil Team's avatar
Abseil Team committed
337
338
339
| `ACTION(Sum) { return arg0 + arg1; }` | Defines an action `Sum()` to return the sum of the mock function's argument #0 and #1. |
| `ACTION_P(Plus, n) { return arg0 + n; }` | Defines an action `Plus(n)` to return the sum of the mock function's argument #0 and `n`. |
| `ACTION_Pk(Foo, p1, ..., pk) { statements; }` | Defines a parameterized action `Foo(p1, ..., pk)` to execute the given `statements`. |
340
341
342

The `ACTION*` macros cannot be used inside a function or class.

Abseil Team's avatar
Abseil Team committed
343
## Cardinalities {#CardinalityList}
344

345
346
These are used in `Times()` to specify how many times a mock function will be
called:
347

348
|                   |                                                        |
349
350
351
352
| :---------------- | :----------------------------------------------------- |
| `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
353
354
| `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. |
355

Abseil Team's avatar
Abseil Team committed
356
## Expectation Order
357

358
359
360
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.
361

Abseil Team's avatar
Abseil Team committed
362
### The After Clause {#AfterClause}
363

364
```cpp
365
366
367
368
369
using ::testing::Expectation;
...
Expectation init_x = EXPECT_CALL(foo, InitX());
Expectation init_y = EXPECT_CALL(foo, InitY());
EXPECT_CALL(foo, Bar())
370
     .After(init_x, init_y);
371
372
```

373
374
375
376
377
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:
378

379
```cpp
380
381
382
383
384
385
386
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())
387
     .After(all_inits);
388
389
```

390
391
392
393
394
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()`.
395

Abseil Team's avatar
Abseil Team committed
396
### Sequences {#UsingSequences}
397

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

403
```cpp
404
using ::testing::Return;
405
406
407
408
409
410
411
412
413
414
415
416
417
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"));
```
418
419
420

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

To put many expectations in a sequence conveniently:
423

424
```cpp
425
426
using ::testing::InSequence;
{
427
  InSequence seq;
428
429
430
431
432
433
434
435

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

436
437
438
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
439
## Verifying and Resetting a Mock
440
441
442

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

444
```cpp
445
446
447
using ::testing::Mock;
...
// Verifies and removes the expectations on mock_obj;
448
// returns true if and only if successful.
449
450
451
452
Mock::VerifyAndClearExpectations(&mock_obj);
...
// Verifies and removes the expectations on mock_obj;
// also removes the default actions set by ON_CALL();
453
// returns true if and only if successful.
454
455
456
Mock::VerifyAndClear(&mock_obj);
```

457
458
459
You can also tell gMock that a mock object can be leaked and doesn't need to be
verified:

460
```cpp
461
462
463
Mock::AllowLeak(&mock_obj);
```

Abseil Team's avatar
Abseil Team committed
464
## Mock Classes
465
466

gMock defines a convenient mock class template
467

468
```cpp
469
470
class MockFunction<R(A1, ..., An)> {
 public:
471
  MOCK_METHOD(R, Call, (A1, ..., An));
472
473
};
```
474

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

Abseil Team's avatar
Abseil Team committed
478
## Flags
479

480
481
| Flag                           | Description                               |
| :----------------------------- | :---------------------------------------- |
Abseil Team's avatar
Abseil Team committed
482
483
| `--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. |