问:如何检测真实的测试覆盖率?
我注意到代码覆盖率度量和测试质量存在一个问题:100%的代码覆盖率并不意味着代码真正得到了测试。
有时,即使测试并没有覆盖所有内容,它也会给出100%的覆盖率。问题在于覆盖率的定义,我们假设 覆盖率==可达代码。
但这并不是真的,代码可能是100%可达的,但测试可能并没有完全覆盖代码。
以一个例子为例,这个测试(EMMA)给出了100%的覆盖率,但实际上它并没有覆盖将传递给服务模拟程序的值。因此,如果值发生更改,测试将不会失败。
例子:
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);
}
}