Package org.mockito.internal.junit
Class JUnitRule
java.lang.Object
org.mockito.internal.junit.JUnitRule
- All Implemented Interfaces:
MethodRule
,MockitoRule
Internal implementation.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionapply
(Statement base, FrameworkMethod method, Object target) silent()
Rule will not report stubbing warnings during test execution.strictness
(Strictness strictness) The strictness, especially "strict stubs" (Strictness.STRICT_STUBS
) helps debugging and keeping tests clean.
-
Constructor Details
-
JUnitRule
- Parameters:
strictness
- how strict mocking / stubbing is concerned
-
-
Method Details
-
apply
- Specified by:
apply
in interfaceMethodRule
-
silent
Description copied from interface:MockitoRule
Rule will not report stubbing warnings during test execution. By default, stubbing warnings are printed to Standard output to help debugging. Equivalent of configuringMockitoRule.strictness(Strictness)
withStrictness.LENIENT
.Please give us feedback about the stubbing warnings of JUnit rules by commenting on GitHub issue 769. It's a new feature of Mockito 2.1.0. It aims to help debugging tests. We want to make sure the feature is useful. We would really like to know why do you wish to silence the warnings! See also
MockitoHint
.Example:
public class ExampleTest { @Rule public MockitoRule rule = MockitoJUnit.rule().silent(); }
- Specified by:
silent
in interfaceMockitoRule
-
strictness
Description copied from interface:MockitoRule
The strictness, especially "strict stubs" (Strictness.STRICT_STUBS
) helps debugging and keeping tests clean. It's a new feature introduced in Mockito 2.3. Other levels of strictness - "warn" - (Strictness.WARN
) and "lenient" (MockitoRule.silent()
) strictness were already present in Mockito 2.1.0. Version 2.3.0 introduces "strict stubs" (Strictness.STRICT_STUBS
).
See Javadoc forpublic class ExampleTest { @Rule public MockitoRule rule = MockitoJUnit.rule().strictness(Strictness.STRICT_STUBS); }
Strictness
to learn how strictness influences the behavior of the JUnit rule. SeeStrictness.STRICT_STUBS
to learn why is it recommended to use "strict stubbing".It is possible to tweak the strictness per test method. Why would you need it? See the use cases in Javadoc for
PotentialStubbingProblem
class. In order to tweak strictness per stubbing seeMockito.lenient()
, per mock seeMockSettings.lenient()
.
"Strict stubs" are planned to be the default for Mockito v3 We are very eager to hear feedback about "strict stubbing" feature, let us know by commenting on GitHub issue 769. Strict stubbing is an attempt to improve testability and productivity with Mockito. Tell us what you think!public class ExampleTest { @Rule public MockitoRule rule = MockitoJUnit.rule().strictness(Strictness.STRICT_STUBS); @Test public void exampleTest() { //Change the strictness level only for this test method //Useful for edge cases (see Javadoc for PotentialStubbingProblem class) mockito.strictness(Strictness.LENIENT); //remaining test code } }
- Specified by:
strictness
in interfaceMockitoRule
-