1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
/*
* Copyright 2001-2009 OFFIS, Tammo Freese
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.easymock.internal;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Stack;
import org.easymock.IArgumentMatcher;
import org.easymock.internal.matchers.And;
import org.easymock.internal.matchers.Not;
import org.easymock.internal.matchers.Or;
public class LastControl {
private static final ThreadLocal<MocksControl> threadToControl = new ThreadLocal<MocksControl>();
private static final ThreadLocal<Stack<Invocation>> threadToCurrentInvocation = new ThreadLocal<Stack<Invocation>>();
private static final ThreadLocal<Stack<IArgumentMatcher>> threadToArgumentMatcherStack = new ThreadLocal<Stack<IArgumentMatcher>>();
public static void reportLastControl(MocksControl control) {
if (control != null) {
threadToControl.set(control);
} else {
threadToControl.remove();
}
}
public static MocksControl lastControl() {
return threadToControl.get();
}
public static void reportMatcher(IArgumentMatcher matcher) {
Stack<IArgumentMatcher> stack = threadToArgumentMatcherStack.get();
if (stack == null) {
stack = new Stack<IArgumentMatcher>();
threadToArgumentMatcherStack.set(stack);
}
stack.push(matcher);
}
public static List<IArgumentMatcher> pullMatchers() {
Stack<IArgumentMatcher> stack = threadToArgumentMatcherStack.get();
if (stack == null) {
return null;
}
threadToArgumentMatcherStack.remove();
return new ArrayList<IArgumentMatcher>(stack);
}
public static void reportAnd(int count) {
Stack<IArgumentMatcher> stack = threadToArgumentMatcherStack.get();
assertState(stack != null, "no matchers found.");
stack.push(new And(popLastArgumentMatchers(count)));
}
public static void reportNot() {
Stack<IArgumentMatcher> stack = threadToArgumentMatcherStack.get();
assertState(stack != null, "no matchers found.");
stack.push(new Not(popLastArgumentMatchers(1).get(0)));
}
private static List<IArgumentMatcher> popLastArgumentMatchers(int count) {
Stack<IArgumentMatcher> stack = threadToArgumentMatcherStack.get();
assertState(stack != null, "no matchers found.");
assertState(stack.size() >= count, "" + count + " matchers expected, "
+ stack.size() + " recorded.");
List<IArgumentMatcher> result = new LinkedList<IArgumentMatcher>();
result.addAll(stack.subList(stack.size() - count, stack.size()));
for (int i = 0; i < count; i++) {
stack.pop();
}
return result;
}
private static void assertState(boolean toAssert, String message) {
if (!toAssert) {
threadToArgumentMatcherStack.remove();
throw new IllegalStateException(message);
}
}
public static void reportOr(int count) {
Stack<IArgumentMatcher> stack = threadToArgumentMatcherStack.get();
assertState(stack != null, "no matchers found.");
stack.push(new Or(popLastArgumentMatchers(count)));
}
public static Invocation getCurrentInvocation() {
Stack<Invocation> stack = threadToCurrentInvocation.get();
if (stack == null || stack.empty()) {
return null;
}
return stack.lastElement();
}
public static void pushCurrentInvocation(Invocation invocation) {
Stack<Invocation> stack = threadToCurrentInvocation.get();
if (stack == null) {
stack = new Stack<Invocation>();
threadToCurrentInvocation.set(stack);
}
stack.push(invocation);
}
public static void popCurrentInvocation() {
Stack<Invocation> stack = threadToCurrentInvocation.get();
stack.pop();
}
}
|