2019-07-16 14:38:15 -04:00
|
|
|
# Googletest Mocking (gMock) Framework
|
2010-04-14 16:26:57 +00:00
|
|
|
|
2019-07-16 14:38:15 -04:00
|
|
|
### Overview
|
2008-12-10 05:08:54 +00:00
|
|
|
|
2019-07-16 14:38:15 -04:00
|
|
|
Google's framework for writing and using C++ mock classes. It can help you
|
|
|
|
derive better designs of your system and write better tests.
|
2015-08-30 12:36:37 -04:00
|
|
|
|
|
|
|
It is inspired by:
|
|
|
|
|
2020-05-05 17:07:05 -04:00
|
|
|
* [jMock](http://www.jmock.org/)
|
|
|
|
* [EasyMock](http://www.easymock.org/)
|
2020-05-01 12:24:32 +05:30
|
|
|
* [Hamcrest](http://code.google.com/p/hamcrest/)
|
2015-08-30 12:36:37 -04:00
|
|
|
|
2020-05-05 17:07:05 -04:00
|
|
|
It is designed with C++'s specifics in mind.
|
2015-08-30 12:36:37 -04:00
|
|
|
|
2019-07-16 14:38:15 -04:00
|
|
|
gMock:
|
|
|
|
|
2020-05-05 17:07:05 -04:00
|
|
|
- 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.
|
|
|
|
- Is easy to learn and use.
|
2019-07-16 14:38:15 -04:00
|
|
|
|
2019-07-30 10:17:22 +03:00
|
|
|
Details and examples can be found here:
|
|
|
|
|
2021-01-15 15:50:04 -05:00
|
|
|
* [gMock for Dummies](../docs/gmock_for_dummies.md)
|
|
|
|
* [Legacy gMock FAQ](../docs/gmock_faq.md)
|
|
|
|
* [gMock Cookbook](../docs/gmock_cook_book.md)
|
|
|
|
* [gMock Cheat Sheet](../docs/gmock_cheat_sheet.md)
|
2019-07-30 10:17:22 +03:00
|
|
|
|
2020-11-02 22:26:39 -05:00
|
|
|
Please note that code under scripts/generator/ is from the
|
|
|
|
[cppclean project](http://code.google.com/p/cppclean/) and under the Apache
|
2020-09-16 01:33:41 +09:00
|
|
|
License, which is different from GoogleMock's license.
|
2019-07-16 14:38:15 -04:00
|
|
|
|
2020-09-16 01:33:41 +09:00
|
|
|
GoogleMock is a part of
|
|
|
|
[GoogleTest C++ testing framework](http://github.com/google/googletest/) and a
|
2019-07-16 14:38:15 -04:00
|
|
|
subject to the same requirements.
|