我正在尝试关闭我的应用程序中的一些测试漏洞,并发现 JaCoCo 声纳插件在我的枚举中的覆盖率较小,因为它认为我应该测试包名称。
这是为什么?
它在我的一个枚举中显示了 97% 的覆盖率,并在包声明的顶部显示了一条红线,告诉我测试它......它在所有枚举和枚举中都这样做。
我来这里是为了寻找这个问题的答案,经过更多的挖掘,我发现这是由于一些静态方法可以在 Jacoco 期望被覆盖的编译枚举类的字节码中找到。经过一些实验,我想出了以下超类,用于使用 JUnit 4 进行单元测试,这些单元测试专注于枚举。这解决了我的枚举覆盖问题。
import org.junit.Test;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import static org.junit.Assert.assertEquals;
public abstract class EnumTest {
@Test
public void verifyEnumStatics() throws NoSuchMethodException, InvocationTargetException, IllegalAccessException {
Class e = getEnumUnderTest();
Method valuesMethod = e.getMethod("values");
Object[] values = (Object[]) valuesMethod.invoke(null);
Method valueOfMethod = e.getMethod("valueOf", String.class);
assertEquals(values[0], valueOfMethod.invoke(null, ((Enum)values[0]).name()));
}
protected abstract Class getEnumUnderTest();
}
然后像这样使用它:
public class TravelTypeTest extends EnumTest {
@Override
protected Class getEnumUnderTest() {
return TravelType.class;
}
// other test methods if needed
}
这是一个粗略的第一次尝试 - 它不适用于无论出于何种原因没有任何条目的枚举,并且无疑有更好的方法来获得相同的效果,但这将通过确保您可以锻炼生成的静态方法检索枚举的值,并且如果将第一个枚举条目的名称传递给 valueOf() 方法,您将获得第一个枚举条目。
理想情况下,我们会编写一个测试来搜索被测包中的所有枚举并以相同的方式自动执行它们(并且避免必须记住为每个继承自 EnumTest 的新枚举创建一个新的测试类),但我不'没有很多枚举,所以我还没有感到任何压力来尝试这个。