2025-09-16
- #529: Fixed
itertools._tee object has no attribute error-- nowduplicate_iterators=Truemust be passed tomocker.spyto duplicate iterators.
2025-09-04
- Python 3.8 (EOL) is no longer supported.
- #524: Added
spy_return_itertomocker.spy, which contains a duplicate of the return value of the spied method if it is anIterator.
- #503: Python 3.14 is now officially supported.
- #415:
MockTypeandAsyncMockTypecan be imported frompytest_mockfor type annotation purposes. - #420: Fixed a regression which would cause
mocker.patch.objectto not being properly cleared between tests.
- #417:
spynow hasspy_return_list, which is a list containing all the values returned by the spied function. pytest-mocknow requirespytest>=6.2.5.- #410: pytest-mock's
setup.pyfile is removed. If you relied on this file, e.g. to install pytest usingsetup.py install, please see Why you shouldn't invoke setup.py directly for alternatives.
- Added support for Python 3.12.
- Dropped support for EOL Python 3.7.
mocker.resetall()now also resets mocks created bymocker.create_autospec(#390).
(This release source code is identical to 3.11.0 except a small internal fix to deployment/CI)
- Fixed introspection for failed
assert_has_calls(#365). - Updated type annotations for
mocker.patchandmocker.spy(#364).
- Fixed introspection for failed
assert_has_calls(#365). - Updated type annotations for
mocker.patchandmocker.spy(#364).
- Added new
mocker.stop(m)method to stop specificmocker.patchormocker.spycalls (#319).
- Expose
NonCallableMagicMockvia themockerfixture (#318).
- Fixed
AsyncMocksupport for Python 3.7+ inmocker.async_stub(#302).
- Fixed regression caused by an explicit
mockdependency in the code (#298).
- Add
MockerFixture.async_mockmethod. Thanks @PerchunPak for the PR (#296).
- Python 3.10 now officially supported.
- Dropped support for Python 3.6.
- Fix
mocker.resetall()when usingmocker.spy()(#237). Thanks @blaxter for the report and @shadycuz for the PR.
- pytest-mock no longer supports Python 3.5.
- Correct type annotations for
mocker.patch.objectto also include the string form. Thanks @plannigan for the PR (#235). reset_allnow supportsreturn_valueandside_effectkeyword arguments. Thanks @alex-marty for the PR (#214).
- Use
inspect.getattr_staticinstead of resorting toobject.__getattribute__magic. This should better comply with objects which implement a custom descriptor protocol. Thanks @yesthesoup for the PR (#224).
- Now all patch functions will emit a warning instead of raising a
ValueErrorwhen used as a context-manager. Thanks @iforapsy for the PR (#221). - Additionally,
mocker.patch.context_manageris available when the user intends to mock a context manager (for examplethreading.Lockobject), which will not emit that warning.
Add mock.seal alias to the mocker fixture (#211). Thanks @coiax for the PR.
Fixed spying on exceptions not covered by the
Exceptionsuperclass (#215), likeKeyboardInterrupt-- PR #216 by @webknjaz.Before the fix, both
spy_returnandspy_exceptionwere always assigned toNonewhenever such an exception happened. And after this fix,spy_exceptionis set to a correct value of an exception that has actually happened.
Introduce
MockFixtureas an alias toMockerFixture.Before
3.3.0, the fixture class was namedMockFixture, but was renamed toMockerFixtureto better match themockerfixture. While not officially part of the API, it was later discovered that this broke the code of some users which already importedpytest_mock.MockFixturefor type annotations, so we decided to reintroduce the name as an alias.Note however that this is just a stop gap measure, and new code should use
MockerFixturefor type annotations.Improved typing for
MockerFixture.patch(#201). Thanks @srittau for the PR.
pytest-mocknow includes inline type annotations and exposes them to user programs. Themockerfixture returnspytest_mock.MockerFixture, which can be used to annotate your tests:from pytest_mock import MockerFixture def test_foo(mocker: MockerFixture) -> None: ...
The type annotations were developed against mypy version
0.782, the minimum version supported at the moment. If you run into an error that you believe to be incorrect, please open an issue.Many thanks to @staticdev for providing the initial patch (#199).
AsyncMock is now exposed in
mockerand supports provides assertion introspection similar toMockobjects.Added by @tirkarthi in #197.
- Fixed performance regression caused by the
ValueErrorraised whenmockeris used as context manager (#191).
New mocker fixtures added that allow using mocking functionality in other scopes:
class_mockermodule_mockerpackage_mockersession_mocker
- Python 2.7 and 3.4 are no longer supported. Users using
pip 9or later will install a compatible version automatically. mocker.spynow also works withasync deffunctions (#179). Thanks @frankie567 for the PR!
mocker.spyattributes for tracking returned values and raised exceptions of its spied functions are now calledspy_returnandspy_exception, instead of reusing the existingMagicMockattributesreturn_valueandside_effect.Version
1.13introduced a serious regression: after a spied function usingmocker.spyraises an exception, further calls to the spy will not call the spied function, always raising the first exception instead: assigning toside_effectcausesunittest.mockto behave this way (#175).The deprecated
mockalias to themockerfixture has finally been removed.
- The object returned by
mocker.spynow also tracks any side effect of the spied method/function.
- Fix error if
mocker.patchis used in code where the source file is not available, for example stale.pycfiles (#169).
- Now all patch functions also raise a
ValueErrorwhen used as a context-manager. Thanks @AlexGascon for the PR (#168).
- The pytest introspection follows message is no longer shown if there is no pytest introspection (#154). Thanks @The-Compiler for the report.
mockernow raises aValueErrorwhen used as a context-manager. Thanks @binarymason for the PR (#165).
- Fix
mocker.spyon Python 2 when used on non-function objects which implement__call__(#157). Thanks @pbasista for the report.
- The object returned by
mocker.spynow also tracks the return value of the spied method/function.
- Fix plugin when 'terminal' plugin is disabled
- Fix bug at the end of the test session when a call to
patch.stopallis done explicitly by user code. Thanks @craiga for the report (#137).
- Fix broken links and update README. Also the code is now formatted using black.
- Add support for the recently added
assert_calledmethod in Python 3.6 andmock-2.0. Thanks @rouge8 for the PR (#115).
- Add support for the recently added
assert_called_oncemethod in Python 3.6 andmock-2.0. Thanks @rouge8 for the PR (#113).
Incompatible change
pytest-mockno longer supports Python 2.6 and Python 3.3, following the lead ofpytestand other projects in the community. Thanks @hugovk for the PR (#96).
Packaging
Internal
- Some tests in
pytest-mock's suite are skipped if assertion rewriting is disabled (#102).
- Fix
UnicodeDecodeErrorduring assert introspection inassert_called_within Python 2. Thanks @AndreasHogstrom for the report (#91).
- Provide source package in
tar.gzformat and remove obsoleteMANIFEST.in.
- Fix
mocker.resetall()by ignoring mocker objects which don't have aresetallmethod, like for examplepatch.dict. Thanks @jdavisp3 for the PR (#88).
- The original assertions raised by the various
Mock.assert_*methods now appear in the failure message, in addition to the message obtained from pytest introspection. Thanks @quodlibetor for the initial patch (#79).
- New
mocker.mock_modulevariable points to the underlying mock module being used (unittest.mockormock). Thanks @blueyed for the request (#71).
- New configuration variable,
mock_use_standalone_module(defaults toFalse). This forces the plugin to importmockinstead ofunittest.mockon Python 3. This is useful to import a newer version than the one available in the Python distribution. - Previously the plugin would first try to import
mockand fallback tounittest.mockin case of anImportError, but this behavior has been removed because it could hide hard to debug import errors (#68). - Now
mock(Python 2) andunittest.mock(Python 3) are lazy-loaded to make it possible to implement the newmock_use_standlone_moduleconfiguration option. As a consequence of this the undocumentedpytest_mock.mock_modulevariable, which pointed to the actual mock module being used by the plugin, has been removed. - DEFAULT is now available from
the
mockerfixture.
- Add support for Python 3.6. Thanks @hackebrot for the report (#59).
mock.mock_openis now aliased asmocker.mock_openfor convenience. Thanks @pokidovea for the PR (#66).
- Try to import
mockfirst instead ofunittest.mock. This gives the user flexibility to install a newermockversion from PyPI instead of using the one available in the Python distribution. Thanks @wcooley for the PR (#54). mock.sentinelis now aliased asmocker.sentinelfor convenience. Thanks @kjwilcox for the PR (#56).
- From this version onward,
pytest-mockis licensed under the MIT license (#45). - Now the plugin also adds introspection information on differing call arguments when
calling helper methods such as
assert_called_once_with. The extra introspection information is similar to pytest's and can be disabled with themock_traceback_monkeypatchoption. Thanks @asfaltboy for the PR (#36). mocker.stub()now allows passing in the name for the constructedMockobject instead of having to set it using the internal_mock_nameattribute directly. This is useful for debugging as the name is used in the mock'sreprstring as well as related assertion failure messages. Thanks @jurko-gospodnetic for the PR (#40).- Monkey patching
mockmodule for friendlier tracebacks is automatically disabled with the--tb=nativeoption. The underlying mechanism used to suppress traceback entries frommockmodule does not work with that option anyway plus it generates confusing messages on Python 3.5 due to exception chaining (#44). Thanks @blueyed for the report. mock.callis now aliased asmocker.callfor convenience. Thanks @jhermann for the PR (#49).
- Fix AttributeError with
mocker.spywhen spying on inherited methods (#42). Thanks @blueyed for the PR.
- PropertyMock
is now accessible from
mocker. Thanks @satyrius for the PR (#32). - Fix regression using one of the
assert_*methods in patched functions which receive a parameter namedmethod. Thanks @sagarchalise for the report (#31).
- Fix regression in frozen tests due to
distutilsimport dependency. Thanks @The-Compiler for the report (#29). - Fix regression when using
pytest-mockwithpytest-2.7.X. Thanks @akscram for the report (#28).
pytest-mocknow monkeypatches themocklibrary to improve pytest output for failures of mock call assertions likeMock.assert_called_with(). Thanks to @Chronial for idea and PR (#26, #27)!
- New
mocker.resetallfunction, which callsreset_mock()in all mocked objects up to that point. Thanks to @mathrick for the PR!
pytest-mockis now also available as a wheel. Thanks @rouge8 for the PR!
Thanks to @fogo, mocker.spy can now prey upon staticmethods and classmethods. 😄
- Two new auxiliary methods,
spyandstub. SeeREADMEfor usage. (Thanks @fogo for complete PR!)
MockandMagicMockare now accessible from themockerfixture, many thanks to @marcwebbie for the complete PR!
mockerfixture now returns the same object (#8). Many thanks to @RonnyPfannschmidt for the PR!
- Small fix, no longer using wheel as an alternate package since it
conditionally depends on mock module based on Python version,
as Python >= 3.3 already includes
unittest.mock. Many thanks to @The-Compiler for letting me know and providing a PR with the fix!
- Small release that just uses
pytest_mockas the name of the plugin, instead ofpytest-mock: this makes it simple to depend on this plugin explicitly usingpytest_pluginsmodule variable mechanism.
Changed fixture name from
mockintomockerbecause it conflicted with the actual mock module, which made using it awkward when access to both the module and the fixture were required within a test.
- Fixed bug #2, where a patch would not be uninstalled correctly after patching the same object twice.
- Added
patch.dictsupport.
First release.