如何测试仅返回系统值的API?

时间:2019-03-13 07:04:27

标签: c++ unit-testing testing libunwind

例如,我们有一个例程

int unw_getcontext(unw_context_t *ucp)

The unw_getcontext() routine initializes the context structure pointed to by ucp with the machine-state of the call-site. The exact set of registers stored by unw_getcontext() is platform-specific

对于这样的例程,什么是单元测试?当然,我可以使用一些系统调用来获取CPU寄存器和类似的东西,然后将其与例程返回的内容进行比较。但这对于单元测试来说似乎是很多工作。测试理论对测试此类API有何看法?

1 个答案:

答案 0 :(得分:1)

我会说这更多地取决于上下文。

您应该在公共API中测试您依赖或承诺的所有内容(还隐藏未测试的所有内容)。

如果此方法是您的库的一部分,则应确保该方法完成了文档中所述的所有操作。将寄存器设置为特定值,并验证函数是否正确返回它们。

如果这是内部的,而您仅依赖其中的一部分,则可以仅测试该部分并修改文档以表明未测试且不应使用其他内容(除非正确测试)是可以的。假设您只需要获取指令指针,就可以从代码的其他部分跳回来,然后仅测试行为的这一部分。

我不会完全跳过测试。该文档正确指定了特定于平台的组件。如果代码需要某种奇怪的体系结构上缺少的特定内容,那么如果测试失败会很好。它也可以用作更奇特的体系结构的用户添加自己的测试的不错的模板,从而使代码总体上更健壮。