我在我的库的实现中使用了函数和类模板。 到目前为止,我刚刚在库单元测试(CppUnit)中实例化了一个模板, 然后开始测试它几乎像任何其他正常的类或功能。
最近我一直在计划为库API添加一些模板。 良好的界面当然是最重要的,模板与否。 通过精心设计和实施的模板,您可以,如果不能完全阻止, 至少使用户更难以在脚下射击自己。 无论如何,我认为单元测试公共模板需要更严格一些, 与纯粹的内部模板相比。
那么,您如何对C ++模板进行单元测试? 你有没有想出任何优雅的解决方案, 特别是对于公共库API中的模板?
答案 0 :(得分:6)
对于初学者,使用您认为最有可能供用户提供的参数对您的模板代码进行单元测试。我经常制作模板“以防万一”,最后我从不使用任何东西,只有我编写原始代码时的一种类型。因此,在这种情况下,测试最可能的案例涵盖所有案例!
如果您觉得需要测试更多,请使用与第一个参数尽可能不同的另一个模板参数。可能没有必要再次测试所有方法。某些方法实际上可能不依赖于模板参数。
答案 1 :(得分:5)
我有一个额外的建议。除了对每个模板进行单元测试之外,还要检查有助于约束潜在巨大范围的技术您的库用户可能尝试传递给模板的模板参数。
例如:假设您只使用类型参数“string”和“char”测试模板。您没有证据证明其他类型参数对于此特定模板会有问题,但出于某种原因,您“怀疑”其他未经测试的类型将 会出现问题。
在上述示例的情况下,并不一定意味着您应该详尽地测试其他类型的args。相反,您有一个案例可能意味着您应该使用一些编译时模板元编程技术来确保您的模板永远不会与任何其他参数一起使用,而是“string”和“char”。
一种资源:
Modern C++ Design -- by Andrei Alexandrescu
在本书的早期,作者展示了如下例子:
如何制作一个自我强制执行的模板,其第一个类型arg的类型小于第二个类型arg
如何在编译时检测可转换性和继承
“现代C ++设计”(尽管其标题相当宽泛/模糊)是对模板编程技术的一种相当高级的探索。
答案 2 :(得分:3)
Boost.Test有一个组件,可以根据一组模板参数来测试模板。
答案 3 :(得分:0)
在单元测试中实现模板是测试模板类。
有什么风险?它们取决于您的库正在使用模板参数做什么;根据用于实例化模板类和编写新测试的类,考虑可能出现的问题。
至少您将准备好您的单元测试环境,以重现将要报告的任何问题。