summaryrefslogtreecommitdiffstats
path: root/googlemock/README.md
blob: 183fdb81d9b6f17b5e57bd9bb6e86066d943a427 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# Googletest Mocking (gMock) Framework

### Overview

Google's framework for writing and using C++ mock classes. It can help you
derive better designs of your system and write better tests.

It is inspired by:

*   [jMock](http://www.jmock.org/),
*   [EasyMock](http://www.easymock.org/), and
*   [Hamcrest](http://code.google.com/p/hamcrest/),

and designed with C++'s specifics in mind.

gMock:

-   provides a declarative syntax for defining mocks,
-   can define partial (hybrid) mocks, which are a cross of real and mock
    objects,
-   handles functions of arbitrary types and overloaded functions,
-   comes with a rich set of matchers for validating function arguments,
-   uses an intuitive syntax for controlling the behavior of a mock,
-   does automatic verification of expectations (no record-and-replay needed),
-   allows arbitrary (partial) ordering constraints on function calls to be
    expressed,
-   lets a user extend it by defining new matchers and actions.
-   does not use exceptions, and
-   is easy to learn and use.

Details and examples can be found here:

*   [gMock for Dummies](docs/for_dummies.md)
*   [Legacy gMock FAQ](docs/gmock_faq.md)
*   [gMock Cookbook](docs/cook_book.md)
*   [gMock Cheat Sheet](docs/cheat_sheet.md)

Please note that code under scripts/generator/ is from the [cppclean
project](http://code.google.com/p/cppclean/) and under the Apache
License, which is different from Google Mock's license.

Google Mock is a part of
[Google Test C++ testing framework](http://github.com/google/googletest/) and a
subject to the same requirements.