Writing unit tests can be hard and sometimes good design has to be sacrificed for the sole purpose of testability. Often testability corresponds to good design, but this is not always the case. For example final classes and methods cannot be used, private methods sometimes need to be protected or unnecessarily moved to a collaborator, static methods should be avoided completely and so on simply because of the limitations of existing frameworks.
PowerMock is a framework that extends other mock libraries such as EasyMock with more powerful capabilities. PowerMock uses a custom classloader and bytecode manipulation to enable mocking of static methods, constructors, final classes and methods, private methods, removal of static initializers and more. By using a custom classloader no changes need to be done to the IDE or continuous integration servers which simplifies adoption. Developers familiar with the supported mock frameworks will find PowerMock easy to use, since the entire expectation API is the same, both for static methods and constructors. PowerMock aims to extend the existing API's with a small number of methods and annotations to enable the extra features. Currently PowerMock supports EasyMock and Mockito.
When writing unit tests it is often useful to bypass encapsulation and therefore PowerMock includes several features that simplifies reflection specifically useful for testing. This allows easy access to internal state, but also simplifies partial and private mocking.
Please note that PowerMock is mainly intended for people with expert knowledge in unit testing. Putting it in the hands of junior developers may cause more harm than good.
News
- 2017-09-16: PowerMock 1.7.3 has been released. The release includes bugfix for #849. See release notes for details.
- 2017-09-16: PowerMock 1.7.2 has been released. The first release with using Mockito Shipkit. See release notes for details.
- 2017-08-12: PowerMock 1.7.1 has been released with one, but significant change: the old API for verifying static mock has been deprecated and a new one has been added. Old API will be removed in version PowerMock 2.0 due to incompatibility with Mockito Public API.
Documentation
- Getting Started
- Downloads
- Motivation
- Javadoc
- Common
- EasyMock
- Mockito
- TestNG
- Delegate to another JUnit Runner
- Bootstrap using a JUnit Rule
- Bootstrap using a Java Agent
- OSGi
- Release Notes
- FAQ
Contributing to PowerMock
Please, read the guideline for a new contributor before start.
Support and discussion
Join the mailing-list here for questions, feedback and support.