Easymock
时间: 2025-06-18 13:03:03 浏览: 11
### Easymock 使用指南及示例
#### 创建 Mock 对象
为了创建 mock 对象,可以使用 `@TestSubject` 和 `@Mock` 注解来简化这一过程。这使得测试类能够自动识别并替换被测对象及其依赖项[^1]。
```java
import org.easymock.EasyMockRunner;
import org.junit.runner.RunWith;
@RunWith(EasyMockRunner.class)
public class ExampleTest {
@TestSubject
private ClassUnderTest systemUnderTest = new ClassUnderTest();
@Mock
private Dependency dependency;
}
```
#### 设置预期行为
通过定义方法调用的期望结果来进行设置。对于每一个要模拟的方法调用,都需要指定其返回值或异常抛出情况,并且可以通过 `expect()` 方法链式调用来实现这一点。
```java
@Test
public void shouldReturnExpectedValue() {
// Arrange
expect(dependency.someMethod()).andReturn("expected value");
// Act & Assert
replay(dependency);
assertEquals(systemUnderTest.methodToTest(), "expected value");
verify(dependency);
}
```
#### 验证交互
完成动作之后,应该验证所有已记录的行为确实发生过一次而且仅有一次;如果某些特定条件下的操作未被执行,则应确保这些情形也被适当处理了。此步骤通常放在断言之前执行以确认所有的预设都被满足。
```java
verify(dependency); // Verifies that all expected interactions occurred.
```
#### 控制重复次数
除了简单的单次匹配外,还可以利用 `times(int)` 或者其他类似的限定符来自定义某个行为发生的频率范围。这对于那些需要多次触发相同逻辑的情况特别有用。
```java
// Expecting method to be called exactly twice.
expect(dependency.anotherMethod()).andReturn(true).times(2);
```
#### 处理参数变化
当面对具有不同输入值得函数时,可借助于捕获器(Capture)机制收集实际传入的数据以便后续分析,或是采用更为灵活的方式——即允许任意类型的实参传递给目标方法而不限定具体形式。
```java
// Using anyInt() matcher for integer parameters.
dependency.processData(anyInt());
expectLastCall().once();
```
阅读全文
相关推荐
















