我想验证 public static void
方法被称为。
@RunWith(PowerMockRunner.class)
@PrepareForTest({ConsoleLog.class})
public class AdContentDataUnitTest {
@Before
public void setUp() throws Exception {
PowerMockito.mockStatic(ConsoleLog.class);
}
@Test
public void adContentData_sendTrackingEvent_noUrl() throws Exception {
mAdContentData = spy(mAdContentData);
// PowerMockito.doNothing().when(ConsoleLog.class);
verifyStatic();
mAdContentData.sendTrackingEvent("event1");
//verifyStatic();
}
}
将调用 sendTrackingEvent
,并调用ConsoleLog.v(String, String)
。我可以在调试中看到调用静态方法,但出现以下日志并且测试失败:
Wanted but not invoked com.example.logger.ConsoleLog.v(
"AdContentData",
"sendTrackingEvent: event event1 does not exist."
);
我尝试在相同的日志之后添加verifyStatic
,如果我删除第一个验证,则不会检查任何内容。如果我模拟整个ConsoleLog类,则会出现错误Unfinished stubbing detected here: [...] PowerMockitoCore.doAnswer
。
有谁知道如何正确地做到这一点?
答案 0 :(得分:3)
有谁知道如何正确地做到这一点?
是。不要这样做。
假设你有一个类调用这样的静态方法:
class Person {
private final int id;
Person() {
id = IdGenerator.gen();
}
}
将静态调用解压缩为非静态方法:
class Person {
private final int id;
Person() {
id = generateId();
}
protected int generateId() {
return IdGenerator.gen();
}
}
现在您可以编写测试,覆盖提取的方法:
final int id = 1;
Person person = new Person() {
@Override
protected int generateId() {
return id;
}
};
// test with person, knowing we control id
但理想的解决方案实际上是重构被测试的代码,根本不使用这种静态调用,而是依赖注入。