使用谷歌测试同时为多个测试模块运行单元测试
Using googletest to run unit-tests for multiple tested modules at once
我正在处理一个大型C++项目,该项目包含50多个库和可执行文件。我开始为每个模块添加谷歌测试。我读到谷歌建议将测试放在可执行文件中,而不是放在库中,以使生活更轻松。为每个单独的组件创建一个单独的可执行文件我会得到50多个测试可执行文件,为了一次运行所有这些文件,我需要创建一个外部脚本,该脚本还需要将它们的输出组合为一个。这是推荐的做法吗?
或者我应该为每个单独模块的测试创建一个库,并将所有这些库链接到一个可执行的测试?但是,为单个模块运行测试变得不那么方便了。我需要构建所有的测试,并通过gtest_filter标志向主测试可执行文件指定此时应该执行哪些测试。
这将真正帮助我了解其他人是如何做到这一点的,以及这里的最佳实践是什么。
感谢
[…]为了同时运行它们,我需要创建一个外部脚本,也需要将其输出组合到单个。
也许实际上没有必要将输出合并到一个文件中。例如,使用Jenkins,您可以为Google测试输出文件指定通配符模式。
因此,如果你真的只是想在Jenkins(或Hudson或你使用的任何CI工具)中看到谷歌测试结果,这可能是一个可能的解决方案:
您可以从一个简单的脚本(甚至从Make规则)运行所有测试可执行文件,参数--gtest_output=xml:
后跟目录名(即以斜杠结尾)。然后,每个测试可执行文件都会将自己的XML文件写入该目录,然后您可以将CI工具配置为从该目录读取所有文件。
相关文章:
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 尝试导入pybind-opencv模块时出现libgtk错误
- 无法编译 rtmidi 测试 cmidiin.cpp 文件, 非法指令
- 尽管测试成功,CppUnit测试核心仍被丢弃.为什么
- 数据成员SFINAE的C++17测试:gcc vs clang
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么二进制搜索在我的测试中不起作用
- 从父数组测试用例构造二叉树失败
- 试图对缓存进行跨步测试,但程序并没有结束
- 有什么好的方法可以让系统调用代理允许在单元测试中进行模拟
- OpenGL在启用深度测试时不会丢弃我的碎片
- 为测试目标创建具有不同源文件夹的文件
- 在子目录中使用target_sources()命令时用于单元测试(qtest)的项目结构
- VC++本机单元测试,找不到调试符号
- 换位表导致测试失败(但在游戏中运行良好)
- 用于交叉编译和CMake的预处理器宏的单元测试
- 可以测试SPI通信外部模块
- 异常模块测试C++
- 使用谷歌测试同时为多个测试模块运行单元测试
- 如何用clang++编译boost单元测试模块