问:如何检测真实的测试覆盖率?
我注意到代码覆盖率指标和测试质量存在一个问题:100% 的代码覆盖率并不意味着代码真的经过测试。
有时测试会提供 100% 的覆盖率,即使它不能覆盖所有内容。问题在于覆盖定义,我们假设覆盖==可达代码。
但事实并非如此,代码可能 100% 可访问,但测试无法 100% 覆盖。
看一个例子,这个测试提供了 100% 的覆盖率 (EMMA),但实际上它不包括将传递给服务模拟的值。所以,如果值会改变,测试不会失败。
例子:
public class User {
public static final int INT_VALUE = 1;
public static final boolean BOOLEAN_VALUE = false;
public static final String STRING_VALUE = "";
private Service service;
public void setService(Service service) {
this.service = service;
}
public String userMethod() {
return service.doSomething(INT_VALUE, BOOLEAN_VALUE, STRING_VALUE);
}
}
并对其进行测试:
public class UserTest {
private User user;
private Service easyMockNiceMock;
@Before
public void setUp() throws Exception {
user = new User();
easyMockNiceMock = EasyMock.createNiceMock(Service.class);
}
@Test
public void nonCoverage() throws Exception {
// given
user.setService(easyMockNiceMock);
expect(easyMockNiceMock.doSomething(anyInt(), anyBoolean(), (String) anyObject())).andReturn("");
replay(easyMockNiceMock);
// when
user.userMethod();
// then
verify(easyMockNiceMock);
}
}