1 /*
2  * Copyright 2001-2009 OFFIS, Tammo Freese
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 package org.easymock;
17 
18 /**
19  * Controls all the mock objects created by it.
20  * For details, see the EasyMock documentation.
21  */
22 public interface IMocksControl {
23     /**
24      * Creates a mock object that implements the given interface.
25      * @param <T> the interface that the mock object should implement.
26      * @param toMock the class of the interface that the mock object should implement.
27      * @return the mock object.
28      */
createMock(Class<T> toMock)29     <T> T createMock(Class<T> toMock);
30 
31     /**
32      * Creates a mock object that implements the given interface.
33      * @param name the name of the mock object .
34      * @param toMock the class of the interface that the mock object should implement.
35      * @param <T> the interface that the mock object should implement.
36      * @return the mock object.
37      * @throws IllegalArgumentException if the name is not a valid Java identifier.
38      */
createMock(String name, Class<T> toMock)39     <T> T createMock(String name, Class<T> toMock);
40 
41     /**
42      * Removes all expectations for the mock objects of this control.
43      */
reset()44     void reset();
45 
46     /**
47      * Removes all expectations for the mock objects of this control and turn
48      * them to nice mocks.
49      */
resetToNice()50     void resetToNice();
51 
52     /**
53      * Removes all expectations for the mock objects of this control and turn
54      * them to default mocks.
55      */
resetToDefault()56     void resetToDefault();
57 
58     /**
59      * Removes all expectations for the mock objects of this control and turn
60      * them to strict mocks.
61      */
resetToStrict()62     void resetToStrict();
63 
64     /**
65      * Switches the control from record mode to replay mode.
66      */
replay()67     void replay();
68 
69     /**
70      * Verifies that all expectations were met.
71      */
verify()72     void verify();
73 
74     /**
75      * Switches order checking on and off.
76      * @param state <code>true</code> switches order checking on, <code>false</code> switches it off.
77      */
checkOrder(boolean state)78     void checkOrder(boolean state);
79 
80     /**
81      * Makes the mock thread safe.
82      *
83      * @param threadSafe If the mock should be thread safe or not
84      */
makeThreadSafe(boolean threadSafe)85     void makeThreadSafe(boolean threadSafe);
86 
87     /**
88      * Check that the mock is called from only one thread
89      *
90      * @param shouldBeUsedInOneThread
91      *            If it should be used in one thread only or not
92      */
checkIsUsedInOneThread(boolean shouldBeUsedInOneThread)93     void checkIsUsedInOneThread(boolean shouldBeUsedInOneThread);
94 }
95