我目前正在尝试为小型图书馆构建或多或少完整的单元测试集。由于我们希望允许存在不同的实现,因此我们希望这组测试是 (a) 通用的,以便我们可以重新使用它来测试不同的实现,并且 (b) 尽可能完整。对于 (b) 部分,我想知道是否有任何用于测试枚举类型的最佳实践。因此,例如我有一个枚举如下:
public enum Month {
January,
February,
...
December;
}
这里我要确保所有枚举类型都真实存在。那有必要吗?目前我正在使用 Hamcrests assertThat
如以下示例所示:
assertThat(Month.January, is(notNullValue()));
缺少“January”枚举会导致编译时错误,可以通过创建缺少的枚举类型来修复该错误。
我在这里使用的是 Java,但我不介意您的答案是否适用于其他语言。
编辑:
正如 mkato 和 Mark Heath 都指出的那样,可能没有必要测试枚举,因为当您使用不存在的枚举类型时,编译器将无法编译。但我仍然想测试这些枚举,因为我们想构建一个单独的类似 TCK 的 test.jar,它将在不同的实现上运行相同的测试。所以我的问题更像是:测试枚举类型的最佳方法是什么?
仔细考虑之后,我将上面的 Hamcrest 语句更改为:
assertThat(Month.valueOf("January"), is(notNullValue()));
当 1 月(还)不存在时,该声明现在会抛出 NPE。这种方法有什么问题吗?
原文由 seb 发布,翻译遵循 CC BY-SA 4.0 许可协议
对于枚举,我只在它们确实有方法时才测试它们。如果它像您的示例一样是纯值枚举,我会说不要打扰。
但是由于您热衷于测试它,因此选择第二个选项比第一个要好得多。第一个问题是,如果您使用 IDE,对枚举的任何重命名也会重命名您的测试类中的枚举。