EasyMock日记1

本文介绍了一个使用EasyMock进行单元测试的例子,展示了如何模拟HttpServletRequest和HttpSession对象,并验证PayController类中的recharge方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

private PayController payController; 
private HttpServletRequest request;
private User user;
private HttpSession session;

@Before
public void before(){
    payController=new PayController();
    user=new User();
    user.setUsername("18350591915");
    user.setUseNo("4f62f0e5516346748843df6131072ae0");      
}
@Test
public void Testalipay_notify(){        
    request=EasyMock.createMock(HttpServletRequest.class);
    session=EasyMock.createMock(HttpSession.class);
    EasyMock.expect(request.getParameter("type")).andReturn("1");
    EasyMock.expect(request.getParameter("money")).andReturn("1");
    EasyMock.expect(request.getParameter("paymentId")).andReturn("1");
    //EasyMock.expect((User)request.getSession().getAttribute("user")).andReturn(user);
    //这句话不知道为什么不能实现``
    EasyMock.expect(request.getSession()).andReturn(session);
    EasyMock.expect(session.getAttribute("user")).andReturn(user);
    EasyMock.replay(request);
    assertNotNull(payController.recharge(null, request));
    EasyMock.verify(request);

}
参考http://blog.youkuaiyun.com/chjttony/article/details/14522771[参考地址](http://blog.youkuaiyun.com/chjttony/article/details/14522771%20%E5%8F%82%E8%80%83%E5%8D%9A%E5%AE%A2easymock)
### 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(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值