首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

返回null的EasyMock

EasyMock是一个用于Java单元测试的开源框架,它可以模拟对象的行为和状态,以便进行测试驱动开发(TDD)和行为驱动开发(BDD)。当使用EasyMock进行单元测试时,有时我们希望模拟的方法返回null值。

在EasyMock中,我们可以使用expect方法来设置模拟对象的行为。如果我们希望模拟的方法返回null值,可以使用andReturn(null)方法来指定返回值为null。例如:

代码语言:java
复制
import static org.easymock.EasyMock.*;

// 创建模拟对象
SomeClass mockObject = createMock(SomeClass.class);

// 设置模拟对象的行为
expect(mockObject.someMethod()).andReturn(null);

// 激活模拟对象
replay(mockObject);

// 调用被测试的代码,期望返回null
Object result = testedObject.someMethod();

// 验证模拟对象的调用
verify(mockObject);

在上面的示例中,我们创建了一个名为mockObject的模拟对象,并使用expect方法设置了模拟对象的行为,即someMethod方法返回null。然后,我们通过调用被测试的代码来触发模拟对象的调用,并将返回值存储在result变量中。最后,我们使用verify方法验证模拟对象的调用是否符合预期。

需要注意的是,返回null值可能会导致空指针异常(NullPointerException),因此在使用返回null值的模拟对象时,需要确保被测试的代码能够正确处理null值的情况。

腾讯云提供了一系列与云计算相关的产品,例如云服务器(ECS)、云数据库(CDB)、云存储(COS)等。这些产品可以帮助用户在云上构建和管理各种应用和服务。具体的产品介绍和相关链接地址可以在腾讯云官方网站上找到。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • EasyMock PowerMock 的简单使用(with spring Autowired)


    import java.math.BigDecimal;

    import org.easymock.EasyMock;
    import org.junit.Assert;
    import org.junit.Test;
    import org.junit.runner.RunWith;
    import org.powermock.api.easymock.PowerMock;
    import org.powermock.core.classloader.annotations.PowerMockIgnore;
    import org.powermock.core.classloader.annotations.PrepareForTest;
    import org.powermock.modules.junit4.PowerMockRunner;
    import org.springframework.aop.framework.Advised;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.test.util.ReflectionTestUtils;

    @RunWith(PowerMockRunner.class)
    @PrepareForTest( { PaymentReconService.class })
    @PowerMockIgnore(“org.apache.log4j.*”)
    public class PaymentGatherServiceTest extends PaymentServiceTestBase {

    @Autowired
    private GatherService gatherResultService;
    @Autowired
    private PaymentBaseDAO baseDAO;

    /**
    * 测试正常postback
    */
    public void testPaymentSucc() {
    PaymentReconService mock = mock();

    Long pbId = 10004L;
    String pbStatus = PaymentBaseEO.PB_STATUS_GATHER_SUCC;
    BigDecimal succAmount = new BigDecimal(“99.3”);

    try {
    GatherOrderRO ro = gatherResultService.processPaymentGather(pbId, pbStatus, succAmount, succAmount);
    assertNotNull(ro);

    } catch (SystemException e) {
    fail(e.getLocalizedMessage());
    } catch (BusinessException e) {
    fail(e.getBusinessCode());
    }
    EasyMock.verify(mock);
    }

    /**
    * MOCK PaymentReconService实现
    * @return
    */
    private PaymentReconService mock() {
    PaymentReconRO mockRO = new PaymentReconRO(PaymentReconRO.Status.SUCESS, “OK”);

    PaymentReconService mock = EasyMock.createMock(PaymentReconServiceImpl.class);
    EasyMock.expect(mock.paymentSuccessRecon(EasyMock.anyObject(Long.class))).andReturn(mockRO);
    EasyMock.replay(mock);
    //这里把依赖的数据注进去
    ReflectionTestUtils.s

    03

    玩花招的PowerMock

    当我们面对一个遗留系统时,常见的问题是没有测试。正如Michael Feathers在Working Effectively with Legacy Code一书中对“遗留代码”的定义。他将其简单归纳为“没有测试的代码”。真是太贴切了!正是因为没有测试,使得我们对遗留代码的任何重构都有些战战兢兢,甚至成为开发人员抵制重构的借口。从收益与成本的比例来看,对于这样的系统,我一贯认为不要盲目进行重构。因为重构的真正适用场景其实是发生在开发期间,而非维护期间。当然,提升自己的重构能力,尤其学会运用IDE提供的自动重构工具,可以在一定程度上保障重构的质量。然而,安全的做法,还是需要为其编写测试。

    02
    领券