0

可以说以下是我需要测试的课程

public class ClassToTest{
//some code
    SomeOtherClass soc = new SomeOtherClass();
    Object returnedObject = soc.doMethodCall(passedObject);
}

我不想让实际的 doMethodCall 发生,我需要模拟它并返回我自己的值。

在 mytest 课程中,我为 SomeOtherClass 添加了 preprare for test

@PrepareForTest({ SomeOtherClass.class})

我做了如下的嘲笑。

SomeOtherClass mockSoc = EasyMock.createMock(SomeOtherClass.class);
Easymock.expect(mockSoc.doMethodCall((ParamClass)EasyMock.anyObject())).andReturn(null);
EasyMock.replayAll();

问题是拦截方法调用并返回 null 而不是方法调用不会发生,并且单元测试进入 doMetodCall(我不想要)并产生空指针错误。

我做错了什么。

4

1 回答 1

0

编辑

我对这个问题的原始答案是正确的,但具体到为什么。在对 PowerMock 进行了更多阅读和使用之后,我自己也遇到过几次这个问题。您面临的问题是因为需要为测试做好准备的课程是您正在测试的课程,而不是您正在模拟的课程。

因此,要解决您的问题,请更改@PrepareForTest({ SomeOtherClass.class})@PrepareForTest({ ClassToTest.class})

结束编辑


我最近一直在阅读 PowerMock 并遇到了这个页面:如何使用 PowerMock 模拟对象实例化

我已经测试了您自己创建几个类的场景。所以这里是我为测试你的场景而创建的测试类:

public class Class2 {
    public Object doMethodCall(final Object passedObject) {
        return passedObject.toString();
    }
}

public class Class1 {
    public Object method(final Object passedObject) {
        final Class2 class2 = new Class2();
        return class2.doMethodCall(passedObject);
    }
}

使用该页面上的建议,我创建了以下成功运行的测试方法,并测试该方法是否已在新实例上调用。

@RunWith(PowerMockRunner.class)
@PrepareForTest(Class1.class)
public class Class1Test {

    @Test
    public void testMethod() throws Exception {
        final Object passedObject = new Object();
        final Class2 mockClass2 = PowerMock.createMock(Class2.class);

        PowerMock.expectNew(Class2.class).andReturn(mockClass2);
        EasyMock.expect(mockClass2.doMethodCall(passedObject)).andReturn("YEAH!");

        PowerMock.replay(mockClass2, Class2.class);

        final Class1 class1 = new Class1();
        final Object returnedValue = class1.method(passedObject);
        Assert.assertEquals(returnedValue.toString(), "YEAH!");

        PowerMock.verify(mockClass2, Class2.class);
    }
}
于 2014-06-02T09:44:59.510 回答