1. Project Clover database mar. avr. 16 2024 08:19:06 CEST
  2. Package org.devacfr.testing.jupiter

File MockitoTestCase.java

 

Coverage histogram

../../../../img/srcFileCovDistChart1.png
86% of files have more coverage

Code metrics

0
29
30
1
897
109
30
1,03
0,97
30
1

Classes

Class
Line #
Actions
MockitoTestCase 45 29 0% 30 54
0.0847457658,5%
 

Contributing tests

This file is covered by 10 tests. .

Source view

1    /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements. See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership. The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License. You may obtain a copy of the License at
9    *
10    * http://www.apache.org/licenses/LICENSE-2.0
11    *
12    * Unless required by applicable law or agreed to in writing,
13    * software distributed under the License is distributed on an
14    * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15    * KIND, either express or implied. See the License for the
16    * specific language governing permissions and limitations
17    * under the License.
18    */
19    package org.devacfr.testing.jupiter;
20   
21    import org.junit.jupiter.api.extension.ExtendWith;
22    import org.mockito.ArgumentCaptor;
23    import org.mockito.ArgumentMatcher;
24    import org.mockito.ArgumentMatchers;
25    import org.mockito.InOrder;
26    import org.mockito.Mock;
27    import org.mockito.MockSettings;
28    import org.mockito.Mockito;
29    import org.mockito.junit.jupiter.MockitoExtension;
30    import org.mockito.stubbing.Answer;
31    import org.mockito.stubbing.OngoingStubbing;
32    import org.mockito.stubbing.Stubber;
33    import org.mockito.verification.VerificationMode;
34    import org.mockito.verification.VerificationWithTimeout;
35   
36    /**
37    * <p>
38    * This class allow to migrate form JUnit 3.x syntax to JUnit 4.
39    * </p>
40    * it is also Mock facility.
41    *
42    * @author Christophe Friederich
43    */
44    @ExtendWith(MockitoExtension.class)
 
45    public abstract class MockitoTestCase extends TestCase {
46   
47    /**
48    *
49    */
 
50  23 toggle public MockitoTestCase() {
51    }
52   
53    /**
54    * any object or null.
55    * <p>
56    * Shorter alias to {@link Matchers#anyObject()}
57    * <p>
58    * See examples in javadoc for {@link Matchers} class
59    *
60    * @return <code>null</code>.
61    */
 
62  0 toggle @SuppressWarnings("unchecked")
63    protected static <T> T any() {
64  0 return (T) ArgumentMatchers.any();
65    }
66   
67    /**
68    * Object argument that is equal to the given value.
69    * <p>
70    * See examples in javadoc for {@link Matchers} class
71    *
72    * @param value
73    * the given value.
74    * @return <code>null</code>.
75    */
 
76  0 toggle protected static <T> T eq(final T cl) {
77  0 return ArgumentMatchers.eq(cl);
78    }
79   
80    /**
81    * any object or null.
82    * <p>
83    * Shorter alias to {@link Matchers#anyObject()}
84    * <p>
85    * See examples in javadoc for {@link Matchers} class
86    *
87    * @return <code>null</code>.
88    */
 
89  77 toggle protected static <T> T any(final Class<T> cl) {
90  77 return ArgumentMatchers.any(cl);
91    }
92   
93    /**
94    * Creates mock object of given class or interface.
95    * <p>
96    * See examples in javadoc for {@link Mockito} class
97    *
98    * @param classToMock
99    * class or interface to mock
100    * @return mock object
101    */
 
102  0 toggle protected static <T> T mock(final Class<T> classToMock) {
103  0 return Mockito.mock(classToMock);
104    }
105   
106    /**
107    * Specifies mock name. Naming mocks can be helpful for debugging - the name is used in all verification errors.
108    * <p>
109    * Beware that naming mocks is not a solution for complex code which uses too many mocks or collaborators. <b>If you
110    * have too many mocks then refactor the code</b> so that it's easy to test/debug without necessity of naming mocks.
111    * <p>
112    * <b>If you use &#064;Mock annotation then you've got naming mocks for free!</b> &#064;Mock uses field name as mock
113    * name. {@link Mock Read more.}
114    * <p>
115    * See examples in javadoc for {@link Mockito} class
116    *
117    * @param classToMock
118    * class or interface to mock
119    * @param name
120    * of the mock
121    * @return mock object
122    */
 
123  0 toggle protected static <T> T mock(final Class<T> classToMock, final String name) {
124  0 return Mockito.mock(classToMock, name);
125    }
126   
127    /**
128    * Creates mock with a specified strategy for its answers to interactions. It's quite advanced feature and typically
129    * you don't need it to write decent tests. However it can be helpful when working with legacy systems.
130    * <p>
131    * It is the default answer so it will be used <b>only when you don't</b> stub the method call.
132    *
133    * <pre>
134    *
135    * Foo mock = mock(Foo.class, RETURNS_SMART_NULLS);
136    *
137    * Foo mockTwo = mock(Foo.class, new YourOwnAnswer());
138    * </pre>
139    * <p>
140    * See examples in javadoc for {@link Mockito} class
141    * </p>
142    *
143    * @param classToMock
144    * class or interface to mock
145    * @param defaultAnswer
146    * default answer for unstubbed methods
147    * @return mock object
148    */
 
149  0 toggle protected static <T> T mock(final Class<T> classToMock, final Answer<?> defaultAnswer) {
150  0 return Mockito.mock(classToMock, defaultAnswer);
151    }
152   
153    /**
154    * Creates a mock with some non-standard settings.
155    * <p>
156    * The number of configuration points for a mock grows so we need a fluent way to introduce new configuration
157    * without adding more and more overloaded Mockito.mock() methods. Hence {@link MockSettings}.
158    *
159    * <pre>
160    * Listener mock = mock(Listener.class, withSettings()
161    * .name("firstListner").defaultBehavior(RETURNS_SMART_NULLS));
162    * );
163    * </pre>
164    *
165    * <b>Use it carefully and occasionally</b>. What might be reason your test needs non-standard mocks? Is the code
166    * under test so complicated that it requires non-standard mocks? Wouldn't you prefer to refactor the code under
167    * test so it is testable in a simple way?
168    * <p>
169    * See also {@link Mockito#withSettings()}
170    * <p>
171    * See examples in javadoc for {@link Mockito} class
172    *
173    * @param classToMock
174    * class or interface to mock
175    * @param mockSettings
176    * additional mock settings
177    * @return mock object
178    */
 
179  0 toggle protected static <T> T mock(final Class<T> classToMock, final MockSettings mockSettings) {
180  0 return Mockito.mock(classToMock, mockSettings);
181    }
182   
183    /**
184    * Creates a spy of the real object. The spy calls <b>real</b> methods unless they are stubbed.
185    * <p>
186    * Real spies should be used <b>carefully and occasionally</b>, for example when dealing with legacy code.
187    * <p>
188    * As usual you are going to read <b>the partial mock warning</b>: Object oriented programming is more less tackling
189    * complexity by dividing the complexity into separate, specific, SRPy objects. How does partial mock fit into this
190    * paradigm? Well, it just doesn't... Partial mock usually means that the complexity has been moved to a different
191    * method on the same object. In most cases, this is not the way you want to design your application.
192    * <p>
193    * However, there are rare cases when partial mocks come handy: dealing with code you cannot change easily (3rd
194    * party interfaces, interim refactoring of legacy code etc.) However, I wouldn't use partial mocks for new,
195    * test-driven & well-designed code.
196    * <p>
197    * Example:
198    *
199    * <pre>
200    * List list = new LinkedList();
201    * List spy = spy(list);
202    *
203    * // optionally, you can stub out some methods:
204    * when(spy.size()).thenReturn(100);
205    *
206    * // using the spy calls &lt;b&gt;real&lt;/b&gt; methods
207    * spy.add(&quot;one&quot;);
208    * spy.add(&quot;two&quot;);
209    *
210    * // prints &quot;one&quot; - the first element of a list
211    * System.out.println(spy.get(0));
212    *
213    * // size() method was stubbed - 100 is printed
214    * System.out.println(spy.size());
215    *
216    * // optionally, you can verify
217    * verify(spy).add(&quot;one&quot;);
218    * verify(spy).add(&quot;two&quot;);
219    * </pre>
220    *
221    * <h4>Important gotcha on spying real objects!</h4> 1. Sometimes it's impossible to use
222    * {@link Mockito#when(Object)} for stubbing spies. Example:
223    *
224    * <pre>
225    * List list = new LinkedList();
226    * List spy = spy(list);
227    *
228    * // Impossible: real method is called so spy.get(0) throws IndexOutOfBoundsException (the list is yet empty)
229    * when(spy.get(0)).thenReturn(&quot;foo&quot;);
230    *
231    * // You have to use doReturn() for stubbing
232    * doReturn(&quot;foo&quot;).when(spy).get(0);
233    * </pre>
234    *
235    * 2. Watch out for final methods. Mockito doesn't mock final methods so the bottom line is: when you spy on real
236    * objects + you try to stub a final method = trouble. What will happen is the real method will be called *on mock*
237    * but *not on the real instance* you passed to the spy() method. Typically you may get a NullPointerException
238    * because mock instances don't have fields initiated.
239    * <p>
240    * See examples in javadoc for {@link Mockito} class
241    *
242    * @param object
243    * to spy on
244    * @return a spy of the real object
245    */
 
246  0 toggle protected static <T> T spy(final T object) {
247  0 return Mockito.spy(object);
248    }
249   
250    /**
251    * Enables stubbing methods. Use it when you want the mock to return particular value when particular method is
252    * called.
253    * <p>
254    * Simply put: "<b>When</b> the x method is called <b>then</b> return y".
255    * <p>
256    * <b>when() is a successor of deprecated {@link Mockito#stub(Object)}</b>
257    * <p>
258    * Examples:
259    *
260    * <pre>
261    * <b>when</b>(mock.someMethod()).<b>thenReturn</b>(10);
262    *
263    * //you can use flexible argument matchers, e.g:
264    * when(mock.someMethod(<b>anyString()</b>)).thenReturn(10);
265    *
266    * //setting exception to be thrown:
267    * when(mock.someMethod("some arg")).thenThrow(new RuntimeException());
268    *
269    * //you can set different behavior for consecutive method calls.
270    * //Last stubbing (e.g: thenReturn("foo")) determines the behavior of further consecutive calls.
271    * when(mock.someMethod("some arg"))
272    * .thenThrow(new RuntimeException())
273    * .thenReturn("foo");
274    *
275    * //Alternative, shorter version for consecutive stubbing:
276    * when(mock.someMethod("some arg"))
277    * .thenReturn("one", "two");
278    * //is the same as:
279    * when(mock.someMethod("some arg"))
280    * .thenReturn("one")
281    * .thenReturn("two");
282    *
283    * //shorter version for consecutive method calls throwing exceptions:
284    * when(mock.someMethod("some arg"))
285    * .thenThrow(new RuntimeException(), new NullPointerException();
286    * </pre>
287    *
288    * For stubbing void methods with throwables see: {@link Mockito#doThrow(Throwable)}
289    * <p>
290    * Stubbing can be overridden: for example common stubbing can go to fixture setup but the test methods can override
291    * it. Please note that overridding stubbing is a potential code smell that points out too much stubbing.
292    * <p>
293    * Once stubbed, the method will always return stubbed value regardless of how many times it is called.
294    * <p>
295    * Last stubbing is more important - when you stubbed the same method with the same arguments many times.
296    * <p>
297    * Although it is possible to verify a stubbed invocation, usually <b>it's just redundant</b>. Let's say you've
298    * stubbed foo.bar(). If your code cares what foo.bar() returns then something else breaks(often before even
299    * verify() gets executed). If your code doesn't care what get(0) returns then it should not be stubbed. Not
300    * convinced? See <a href="http://monkeyisland.pl/2008/04/26/asking-and-telling">here</a>.
301    * <p>
302    * See examples in javadoc for {@link Mockito} class
303    *
304    * @param methodCall
305    * method to be stubbed
306    */
 
307  63 toggle protected static <T> OngoingStubbing<T> when(final T methodCall) {
308  63 return Mockito.when(methodCall);
309    }
310   
311    /**
312    * Verifies certain behavior <b>happened once</b>
313    * <p>
314    * Alias to <code>verify(mock, times(1))</code> E.g:
315    *
316    * <pre>
317    * verify(mock).someMethod(&quot;some arg&quot;);
318    * </pre>
319    *
320    * Above is equivalent to:
321    *
322    * <pre>
323    * verify(mock, times(1)).someMethod(&quot;some arg&quot;);
324    * </pre>
325    * <p>
326    * Arguments passed are compared using equals() method. Read about {@link ArgumentCaptor} or {@link ArgumentMatcher}
327    * to find out other ways of matching / asserting arguments passed.
328    * <p>
329    * Although it is possible to verify a stubbed invocation, usually <b>it's just redundant</b>. Let's say you've
330    * stubbed foo.bar(). If your code cares what foo.bar() returns then something else breaks(often before even
331    * verify() gets executed). If your code doesn't care what get(0) returns then it should not be stubbed. Not
332    * convinced? See <a href="http://monkeyisland.pl/2008/04/26/asking-and-telling">here</a>.
333    * <p>
334    * See examples in javadoc for {@link Mockito} class
335    *
336    * @param mock
337    * to be verified
338    * @return mock object itself
339    */
 
340  0 toggle protected static <T> T verify(final T mock) {
341  0 return Mockito.verify(mock);
342    }
343   
344    /**
345    * Verifies certain behavior happened at least once / exact number of times / never. E.g:
346    *
347    * <pre>
348    * verify(mock, times(5)).someMethod("was called five times");
349    *
350    * verify(mock, atLeast(2)).someMethod("was called at least two times");
351    *
352    * //you can use flexible argument matchers, e.g:
353    * verify(mock, atLeastOnce()).someMethod(<b>anyString()</b>);
354    * </pre>
355    *
356    * <b>times(1) is the default</b> and can be omitted
357    * <p>
358    * Arguments passed are compared using equals() method. Read about {@link ArgumentCaptor} or {@link ArgumentMatcher}
359    * to find out other ways of matching / asserting arguments passed.
360    * <p>
361    *
362    * @param mock
363    * to be verified
364    * @param mode
365    * times(x), atLeastOnce() or never()
366    * @return mock object itself
367    */
 
368  0 toggle protected static <T> T verify(final T mock, final VerificationMode mode) {
369  0 return Mockito.verify(mock, mode);
370    }
371   
372    /**
373    * Smart Mockito users hardly use this feature because they know it could be a sign of poor tests. Normally, you
374    * don't need to reset your mocks, just create new mocks for each test method.
375    * <p>
376    * Instead of reset() please consider writing simple, small and focused test methods over lengthy, over-specified
377    * tests. <b>First potential code smell is reset() in the middle of the test method.</b> This probably means you're
378    * testing too much. Follow the whisper of your test methods: "Please keep us small & focused on single behavior".
379    * There are several threads about it on mockito mailing list.
380    * <p>
381    * The only reason we added reset() method is to make it possible to work with container-injected mocks. See issue
382    * 55 (<a href="http://code.google.com/p/mockito/issues/detail?id=55">here</a>) or FAQ (
383    * <a href="http://code.google.com/p/mockito/wiki/FAQ">here</a>).
384    * <p>
385    * <b>Don't harm yourself.</b> reset() in the middle of the test method is a code smell (you're probably testing too
386    * much).
387    *
388    * <pre>
389    * List mock = mock(List.class);
390    * when(mock.size()).thenReturn(10);
391    * mock.add(1);
392    *
393    * reset(mock);
394    * // at this point the mock forgot any interactions &amp; stubbing
395    * </pre>
396    *
397    * @param <T>
398    * @param mocks
399    * to be reset
400    */
 
401  0 toggle @SuppressWarnings("unchecked")
402    protected static <T> void reset(final T... mocks) {
403  0 Mockito.reset(mocks);
404    }
405   
406    /**
407    * Checks if any of given mocks has any unverified interaction.
408    * <p>
409    * You can use this method after you verified your mocks - to make sure that nothing else was invoked on your mocks.
410    * <p>
411    * See also {@link Mockito#never()} - it is more explicit and communicates the intent well.
412    * <p>
413    * Stubbed invocations (if called) are also treated as interactions.
414    * <p>
415    * A word of <b>warning</b>: Some users who did a lot of classic, expect-run-verify mocking tend to use
416    * verifyNoMoreInteractions() very often, even in every test method. verifyNoMoreInteractions() is not recommended
417    * to use in every test method. verifyNoMoreInteractions() is a handy assertion from the interaction testing
418    * toolkit. Use it only when it's relevant. Abusing it leads to overspecified, less maintainable tests. You can find
419    * further reading <a href="http://monkeyisland.pl/2008/07/12/should-i-worry-about-the-unexpected/">here</a>.
420    * <p>
421    * This method will also detect unverified invocations that occurred before the test method, for example: in
422    * setUp(), &#064;Before method or in constructor. Consider writing nice code that makes interactions only in test
423    * methods.
424    * <p>
425    * Example:
426    *
427    * <pre>
428    * // interactions
429    * mock.doSomething();
430    * mock.doSomethingUnexpected();
431    *
432    * // verification
433    * verify(mock).doSomething();
434    *
435    * // following will fail because 'doSomethingUnexpected()' is unexpected
436    * verifyNoMoreInteractions(mock);
437    *
438    * </pre>
439    *
440    * See examples in javadoc for {@link Mockito} class
441    *
442    * @param mocks
443    * to be verified
444    */
 
445  0 toggle protected static void verifyNoMoreInteractions(final Object... mocks) {
446  0 Mockito.verifyNoMoreInteractions(mocks);
447    }
448   
449    /**
450    * Use doThrow() when you want to stub the void method with an exception.
451    * <p>
452    * Stubbing voids requires different approach from {@link Mockito#when(Object)} because the compiler does not like
453    * void methods inside brackets...
454    * <p>
455    * Example:
456    *
457    * <pre>
458    * doThrow(new RuntimeException()).when(mock).someVoidMethod();
459    * </pre>
460    *
461    * @param toBeThrown
462    * to be thrown when the stubbed method is called
463    * @return stubber - to select a method for stubbing
464    */
 
465  0 toggle protected Stubber doThrow(final Throwable toBeThrown) {
466  0 return Mockito.doThrow(toBeThrown);
467    }
468   
469    /**
470    * Use <code>doThrow()</code> when you want to stub the void method to throw exception of specified class.
471    * <p>
472    * A new exception instance will be created for each method invocation.
473    * <p>
474    * Stubbing voids requires different approach from {@link Mockito#when(Object)} because the compiler does not like
475    * void methods inside brackets...
476    * <p>
477    * Example:
478    *
479    * <pre class="code">
480    * <code class="java">
481    * doThrow(RuntimeException.class).when(mock).someVoidMethod();
482    * </code>
483    * </pre>
484    *
485    * @param toBeThrown
486    * to be thrown when the stubbed method is called
487    * @return stubber - to select a method for stubbing
488    */
 
489  0 toggle public static Stubber doThrow(final Class<? extends Throwable> toBeThrown) {
490  0 return Mockito.doThrow(toBeThrown);
491    }
492   
493    /**
494    * Use doCallRealMethod() when you want to call the real implementation of a method.
495    * <p>
496    * As usual you are going to read <b>the partial mock warning</b>: Object oriented programming is more less tackling
497    * complexity by dividing the complexity into separate, specific, SRPy objects. How does partial mock fit into this
498    * paradigm? Well, it just doesn't... Partial mock usually means that the complexity has been moved to a different
499    * method on the same object. In most cases, this is not the way you want to design your application.
500    * <p>
501    * However, there are rare cases when partial mocks come handy: dealing with code you cannot change easily (3rd
502    * party interfaces, interim refactoring of legacy code etc.) However, I wouldn't use partial mocks for new,
503    * test-driven & well-designed code.
504    * <p>
505    * See also javadoc {@link Mockito#spy(Object)} to find out more about partial mocks. <b>Mockito.spy() is a
506    * recommended way of creating partial mocks.</b> The reason is it guarantees real methods are called against
507    * correctly constructed object because you're responsible for constructing the object passed to spy() method.
508    * <p>
509    * Example:
510    *
511    * <pre>
512    * Foo mock = mock(Foo.class);
513    * doCallRealMethod().when(mock).someVoidMethod();
514    *
515    * // this will call the real implementation of Foo.someVoidMethod()
516    * mock.someVoidMethod();
517    * </pre>
518    * <p>
519    * See examples in javadoc for {@link Mockito} class
520    *
521    * @return stubber - to select a method for stubbing
522    */
 
523  0 toggle protected static Stubber doCallRealMethod() {
524  0 return Mockito.doCallRealMethod();
525    }
526   
527    /**
528    * Use doAnswer() when you want to stub a void method with generic {@link Answer}.
529    * <p>
530    * Stubbing voids requires different approach from {@link Mockito#when(Object)} because the compiler does not like
531    * void methods inside brackets...
532    * <p>
533    * Example:
534    *
535    * <pre>
536    * doAnswer(new Answer() {
537    *
538    * public Object answer(InvocationOnMock invocation) {
539    * Object[] args = invocation.getArguments();
540    * Mock mock = invocation.getMock();
541    * return null;
542    * }
543    * }).when(mock).someMethod();
544    * </pre>
545    * <p>
546    * See examples in javadoc for {@link Mockito} class
547    *
548    * @param answer
549    * to answer when the stubbed method is called
550    * @return stubber - to select a method for stubbing
551    */
 
552  0 toggle protected static Stubber doAnswer(final Answer<?> answer) {
553  0 return Mockito.doAnswer(answer);
554    }
555   
556    /**
557    * Use doNothing() for setting void methods to do nothing. <b>Beware that void methods on mocks do nothing by
558    * default!</b> However, there are rare situations when doNothing() comes handy:
559    * <p>
560    * 1. Stubbing consecutive calls on a void method:
561    *
562    * <pre>
563    * doNothing().doThrow(new RuntimeException()).when(mock).someVoidMethod();
564    *
565    * // does nothing the first time:
566    * mock.someVoidMethod();
567    *
568    * // throws RuntimeException the next time:
569    * mock.someVoidMethod();
570    * </pre>
571    *
572    * 2. When you spy real objects and you want the void method to do nothing:
573    *
574    * <pre>
575    * List list = new LinkedList();
576    * List spy = spy(list);
577    *
578    * // let's make clear() do nothing
579    * doNothing().when(spy).clear();
580    *
581    * spy.add(&quot;one&quot;);
582    *
583    * // clear() does nothing, so the list still contains &quot;one&quot;
584    * spy.clear();
585    * </pre>
586    * <p>
587    * See examples in javadoc for {@link Mockito} class
588    *
589    * @return stubber - to select a method for stubbing
590    */
 
591  0 toggle protected static Stubber doNothing() {
592  0 return Mockito.doNothing();
593    }
594   
595    /**
596    * Use doReturn() in those rare occasions when you cannot use {@link Mockito#when(Object)}.
597    * <p>
598    * <b>Beware that {@link Mockito#when(Object)} is always recommended for stubbing because it is argument type-safe
599    * and more readable</b> (especially when stubbing consecutive calls).
600    * <p>
601    * Here are those rare occasions when doReturn() comes handy:
602    * <p>
603    * 1. When spying real objects and calling real methods on a spy brings side effects
604    *
605    * <pre>
606    * List list = new LinkedList();
607    * List spy = spy(list);
608    *
609    * // Impossible: real method is called so spy.get(0) throws IndexOutOfBoundsException (the list is yet empty)
610    * when(spy.get(0)).thenReturn(&quot;foo&quot;);
611    *
612    * // You have to use doReturn() for stubbing:
613    * doReturn(&quot;foo&quot;).when(spy).get(0);
614    * </pre>
615    *
616    * 2. Overriding a previous exception-stubbing:
617    *
618    * <pre>
619    * when(mock.foo()).thenThrow(new RuntimeException());
620    *
621    * // Impossible: the exception-stubbed foo() method is called so RuntimeException is thrown.
622    * when(mock.foo()).thenReturn(&quot;bar&quot;);
623    *
624    * // You have to use doReturn() for stubbing:
625    * doReturn(&quot;bar&quot;).when(mock).foo();
626    * </pre>
627    *
628    * Above scenarios shows a tradeoff of Mockito's ellegant syntax. Note that the scenarios are very rare, though.
629    * Spying should be sporadic and overriding exception-stubbing is very rare. Not to mention that in general
630    * overridding stubbing is a potential code smell that points out too much stubbing.
631    * <p>
632    * See examples in javadoc for {@link Mockito} class
633    *
634    * @param toBeReturned
635    * to be returned when the stubbed method is called
636    * @return stubber - to select a method for stubbing
637    */
 
638  0 toggle protected static Stubber doReturn(final Object toBeReturned) {
639  0 return Mockito.doReturn(toBeReturned);
640    }
641   
642    /**
643    * Creates InOrder object that allows verifying mocks in order.
644    *
645    * <pre>
646    * InOrder inOrder = inOrder(firstMock, secondMock);
647    *
648    * inOrder.verify(firstMock).add(&quot;was called first&quot;);
649    * inOrder.verify(secondMock).add(&quot;was called second&quot;);
650    * </pre>
651    *
652    * Verification in order is flexible - <b>you don't have to verify all interactions</b> one-by-one but only those
653    * that you are interested in testing in order.
654    * <p>
655    * Also, you can create InOrder object passing only mocks that are relevant for in-order verification.
656    * <p>
657    * InOrder verification is 'greedy'. You will hardly every notice it but if you want to find out more search for
658    * 'greedy' on the Mockito <a href="http://code.google.com/p/mockito/w/list">wiki pages</a>.
659    * <p>
660    * As of Mockito 1.8.4 you can verifyNoMoreInvocations() in order-sensitive way. Read more:
661    * {@link InOrder#verifyNoMoreInteractions()}
662    * <p>
663    * See examples in javadoc for {@link Mockito} class
664    *
665    * @param mocks
666    * to be verified in order
667    * @return InOrder object to be used to verify in order
668    */
 
669  0 toggle protected static InOrder inOrder(final Object... mocks) {
670  0 return Mockito.inOrder(mocks);
671    }
672   
673    /**
674    * Allows verifying exact number of invocations. E.g:
675    *
676    * <pre>
677    * verify(mock, times(2)).someMethod(&quot;some arg&quot;);
678    * </pre>
679    *
680    * See examples in javadoc for {@link Mockito} class
681    *
682    * @param wantedNumberOfInvocations
683    * wanted number of invocations
684    * @return verification mode
685    */
 
686  0 toggle protected VerificationMode times(final int wantedNumberOfInvocations) {
687  0 return Mockito.times(wantedNumberOfInvocations);
688    }
689   
690    /**
691    * Alias to times(0), see {@link Mockito#times(int)}
692    * <p>
693    * Verifies that interaction did not happen. E.g:
694    *
695    * <pre>
696    * verify(mock, never()).someMethod();
697    * </pre>
698    * <p>
699    * If you want to verify there were NO interactions with the mock check out
700    * {@link Mockito#verifyZeroInteractions(Object...)} or {@link Mockito#verifyNoMoreInteractions(Object...)}
701    * <p>
702    * See examples in javadoc for {@link Mockito} class
703    *
704    * @return verification mode
705    */
 
706  0 toggle protected VerificationMode never() {
707  0 return Mockito.never();
708    }
709   
710    /**
711    * Allows at-least-once verification. E.g:
712    *
713    * <pre>
714    * verify(mock, atLeastOnce()).someMethod(&quot;some arg&quot;);
715    * </pre>
716    *
717    * Alias to atLeast(1)
718    * <p>
719    * See examples in javadoc for {@link Mockito} class
720    *
721    * @return verification mode
722    */
 
723  0 toggle protected VerificationMode atLeastOnce() {
724  0 return Mockito.atLeastOnce();
725    }
726   
727    /**
728    * Allows at-least-x verification. E.g:
729    *
730    * <pre>
731    * verify(mock, atLeast(3)).someMethod(&quot;some arg&quot;);
732    * </pre>
733    *
734    * See examples in javadoc for {@link Mockito} class
735    *
736    * @param minNumberOfInvocations
737    * minimum number of invocations
738    * @return verification mode
739    */
 
740  0 toggle protected static VerificationMode atLeast(final int minNumberOfInvocations) {
741  0 return Mockito.atLeast(minNumberOfInvocations);
742    }
743   
744    /**
745    * Allows at-most-x verification. E.g:
746    *
747    * <pre>
748    * verify(mock, atMost(3)).someMethod(&quot;some arg&quot;);
749    * </pre>
750    *
751    * See examples in javadoc for {@link Mockito} class
752    *
753    * @param maxNumberOfInvocations
754    * max number of invocations
755    * @return verification mode
756    */
 
757  0 toggle protected static VerificationMode atMost(final int maxNumberOfInvocations) {
758  0 return Mockito.atMost(maxNumberOfInvocations);
759    }
760   
761    /**
762    * Allows checking if given method was the only one invoked. E.g:
763    *
764    * <pre>
765    * verify(mock, only()).someMethod();
766    * // above is a shorthand for following 2 lines of code:
767    * verify(mock).someMethod();
768    * verifyNoMoreInvocations(mock);
769    * </pre>
770    * <p>
771    * See also {@link Mockito#verifyNoMoreInteractions(Object...)}
772    * <p>
773    * See examples in javadoc for {@link Mockito} class
774    *
775    * @return verification mode
776    */
 
777  0 toggle protected static VerificationMode only() {
778  0 return Mockito.only();
779    }
780   
781    /**
782    * Allows verifying with timeout. May be useful for testing in concurrent conditions.
783    * <p>
784    * It feels this feature should be used rarely - figure out a better way of testing your multi-threaded system
785    * <p>
786    * Not yet implemented to work with InOrder verification.
787    *
788    * <pre>
789    * // passes when someMethod() is called within given time span
790    * verify(mock, timeout(100)).someMethod();
791    * // above is an alias to:
792    * verify(mock, timeout(100).times(1)).someMethod();
793    *
794    * // passes when someMethod() is called *exactly* 2 times within given time span
795    * verify(mock, timeout(100).times(2)).someMethod();
796    *
797    * // passes when someMethod() is called *at lest* 2 times within given time span
798    * verify(mock, timeout(100).atLeast(2)).someMethod();
799    *
800    * // verifies someMethod() within given time span using given verification mode
801    * // useful only if you have your own custom verification modes.
802    * verify(mock, new Timeout(100, yourOwnVerificationMode)).someMethod();
803    * </pre>
804    *
805    * See examples in javadoc for {@link Mockito} class
806    *
807    * @param millis
808    * - time span in millis
809    * @return verification mode
810    */
 
811  0 toggle protected static VerificationWithTimeout timeout(final int millis) {
812  0 return Mockito.timeout(millis);
813    }
814   
815    /**
816    * First of all, in case of any trouble, I encourage you to read the Mockito FAQ:
817    * <a href="http://code.google.com/p/mockito/wiki/FAQ">http://code.google.com/p/mockito/wiki/FAQ</a>
818    * <p>
819    * In case of questions you may also post to mockito mailing list:
820    * <a href="http://groups.google.com/group/mockito">http://groups.google.com/group/mockito</a>
821    * <p>
822    * validateMockitoUsage() <b>explicitly validates</b> the framework state to detect invalid use of Mockito. However,
823    * this feature is optional <b>because Mockito validates the usage all the time...</b> but there is a gotcha so read
824    * on.
825    * <p>
826    * Examples of incorrect use:
827    *
828    * <pre>
829    * // Oups, someone forgot thenReturn() part:
830    * when(mock.get());
831    *
832    * // Oups, someone put the verified method call inside verify() where it should be outside:
833    * verify(mock.execute());
834    *
835    * // Oups, someone has used EasyMock for too long and forgot to specify the method to verify:
836    * verify(mock);
837    * </pre>
838    *
839    * Mockito throws exceptions if you misuse it so that you know if your tests are written correctly. The gotcha is
840    * that Mockito does the validation <b>next time</b> you use the framework (e.g. next time you verify, stub, call
841    * mock etc.). But even though the exception might be thrown in the next test, the exception <b>message contains a
842    * navigable stack trace element</b> with location of the defect. Hence you can click and find the place where
843    * Mockito was misused.
844    * <p>
845    * Sometimes though, you might want to validate the framework usage explicitly. For example, one of the users wanted
846    * to put validateMockitoUsage() in his &#064;After method so that he knows immediately when he misused Mockito.
847    * Without it, he would have known about it not sooner than <b>next time</b> he used the framework. One more benefit
848    * of having validateMockitoUsage() in &#064;After is that jUnit runner will always fail in the test method with
849    * defect whereas ordinary 'next-time' validation might fail the <b>next</b> test method. But even though JUnit
850    * might report next test as red, don't worry about it and just click at navigable stack trace element in the
851    * exception message to instantly locate the place where you misused mockito.
852    * <p>
853    * <b>Built-in runner: {@link MockitoJUnitRunner}</b> does validateMockitoUsage() after each test method.
854    * <p>
855    * Bear in mind that <b>usually you don't have to validateMockitoUsage()</b> and framework validation triggered on
856    * next-time basis should be just enough, mainly because of enhanced exception message with clickable location of
857    * defect. However, I would recommend validateMockitoUsage() if you already have sufficient test infrastructure
858    * (like your own runner or base class for all tests) because adding a special action to &#064;After has zero cost.
859    * <p>
860    * See examples in javadoc for {@link Mockito} class
861    */
 
862  0 toggle protected static void validateMockitoUsage() {
863  0 Mockito.validateMockitoUsage();
864    }
865   
866    /**
867    * Allows mock creation with additional mock settings.
868    * <p>
869    * Don't use it too often. Consider writing simple tests that use simple mocks. Repeat after me: simple tests push
870    * simple, KISSy, readable & maintainable code. If you cannot write a test in a simple way - refactor the code under
871    * test.
872    * <p>
873    * Examples of mock settings:
874    *
875    * <pre>
876    *
877    * // Creates mock with different default answer &amp; name
878    * Foo mock = mock(Foo.class, withSettings().defaultAnswer(RETURNS_SMART_NULLS).name(&quot;cool mockie&quot;));
879    *
880    * // Creates mock with different default answer, descriptive name and extra interfaces
881    * Foo mock = mock(Foo.class,
882    * withSettings().defaultAnswer(RETURNS_SMART_NULLS).name(&quot;cool mockie&quot;).extraInterfaces(Bar.class));
883    * </pre>
884    *
885    * {@link MockSettings} has been introduced for two reasons. Firstly, to make it easy to add another mock settings
886    * when the demand comes. Secondly, to enable combining different mock settings without introducing zillions of
887    * overloaded mock() methods.
888    * <p>
889    * See javadoc for {@link MockSettings} to learn about possible mock settings.
890    * <p>
891    *
892    * @return mock settings instance with defaults.
893    */
 
894  0 toggle protected static MockSettings withSettings() {
895  0 return Mockito.withSettings();
896    }
897    }