- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是CMake的新手,并且正在使用Google Test Framework。我一直在寻找将CMake与Google测试框架相结合的更复杂的示例,但是我并没有获得太多的运气。我希望有人可以对我到达的设置提供意见并为我回答问题。这是基本的项目结构:
项目文件夹
-CMakeLists.txt
/建立
/包括
-我的所有.h文件
/ src
-CMakeLists.txt
-我的所有.cpp文件
/测试
-CMakeLists.txt
/ gtest
-Google的CMakeLists.txt
/模拟
-CMakeLists.txt
-cpp和h文件进行模拟
简而言之,根cmake文件将src和tests作为子目录添加。 src cmake文件将cpp文件放入库中。测试cmake文件将模拟和gtest添加为子目录。模拟cmake文件将其所有cpp文件都放到另一个库中。最后,tests文件夹中的cmake文件将src库,google库和模拟库与单元测试可执行文件链接在一起。
我最终得到的是几个可执行文件:objA_unittest,objB_unittest等
一些东西:
为了构建所有这些并仍然保持我的项目目录相当干净,我将CD放入build文件夹并运行“ cmake ..”。这看起来真的很不错,我正计划将vim配置为始终从该文件夹运行make。是否有人对此有任何提示或发现任何问题?
我不喜欢将google库嵌套在我的项目文件夹中的想法(特别是如果我最终有几个使用它的项目),但是似乎强烈建议您不要预编译我可以看到的google库没办法解决。但是,如果有人知道更好的方法,我很想听听。
运行测试。我喜欢我要做的就是运行“ make test”以使用ctest执行我的所有单元测试。但是,我发现我不太喜欢输出。每个单元测试可执行文件包含几个不同的单元测试。直接运行这些命令可提供Google非常详细的反馈。如果可执行文件中的一项测试失败,则我确切地知道哪些测试失败以及为什么。以前,我使用了一个makefile,在makefile的结尾,我只是执行了所有测试。我首先尝试通过在cmake中创建自定义构建目标来解决此问题。但是,它仅执行第一个命令。我或者需要一种方法来从CTest获得更多详细输出,或者我需要一种方法来自动输出bash脚本或者从CMake类似的东西来执行每个单元测试可执行文件。换句话说,我现在已经设置了cmake文件,因此我只需要在一个位置添加单元测试就可以生成可执行文件,而且如果可以避免的话,我也不必记住将其添加到第二个位置它。在这一点上,是否有人有帮助的经验?
首先十分感谢。
最佳答案
实际上,推荐的cmake练习称为out-of-source build
AFAIK,不建议在系统中安装重新编译的googletest库。因此,如果将其编译为共享库或静态库作为项目构建的一部分,应该没有任何问题。我已经在Windows,Linux,OSX和Android上以这种方式使用googletest 1.6.0了。
我不确定CTest,但是自定义目标肯定可以为您运行所有测试。这是我可以建议的一个简短解决方案:
在顶层CMakeLists.txt
中添加以下行(在添加任何测试之前):
add_custom_target(test)
macro(run_test test_target)
add_custom_target(${test_target}_runtest
COMMAND ${test_target} #cmake 2.6 required
DEPENDS ${test_target}
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}")
add_dependencies(test ${test_target}_runtest)
endmacro()
test
目标:
#add_executable(mytest ${mysources})
run_test(mytest)
关于cmake - 单元测试输出和项目结构建议— CMake + Google测试框架,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7262370/
我试图要求 test/unit 的新版本(即不是与 ruby 捆绑的版本) .根据 instructions我用 gem i test-unit 安装它.但是现在当我需要 test/unit我似乎
简短版本是: 我有一个 systemd 单元,我想在调用时检查脚本的返回代码: systemctl status service.service 长版本:我有一个 lsb init 脚本正是这样做的,
我正在使用反射动态创建一个类的实例,这工作正常,除非尝试通过单元测试执行此操作 - 我使用的是 MS 测试框架。 我收到熟悉的错误:“无法加载文件或程序集‘Assy’或其依赖项之一。系统找不到指定的文
我想知道测试网站“界面功能”的最佳实践是什么。 我对哪些方法可用于测试界面和动态生成的内容感兴趣。特别是,我很难弄清楚是否可以为需要用户交互的操作创建自动化测试,或者这是否只是浪费时间,我应该让一些
我有一个简单的 Python 服务,其中有一个无限执行某些操作的循环。在各种信号上,sys.exit(0) 被调用,这导致 SystemExit 被引发,然后如果可以的话应该进行一些清理。 在测试中,
我正在使用 OpenCV 2.4.2 这是 OpenCV 文档中的引文 C++: void HoughLinesP(InputArray image, OutputArray lines, doubl
忙于 C# 中的自动化测试用例,我们需要在每次测试后恢复数据库快照。问题是,当运行多个测试时它会失败,因为“其他用户正在使用数据库时无法更改数据库状态。” 我们使用 SqlConnection.Cle
我阅读了 C# 规范并用谷歌搜索了它,但一无所获。 我 99% 肯定 C# 中没有像单元命名空间指令这样的功能,但问题是:为什么?是否有惯用或技术原因? 这很方便,尤其是当我们的大部分文件都由单个命名
我目前正在尝试向我的应用程序(一个非常老的项目......评论说 iOS 2.0)添加单元测试(精确的应用程序测试)并且总是偶然发现 undefined symbols for architectur
我正在使用Delphi 7,并且有一个新单元要在我的项目中使用。我已经编译了新的。当我尝试通过将其添加到uses子句在项目中使用此单元时,出现错误,提示未找到.dcu文件。我还尝试将文件的完整路径放在
场景:我需要编写一个复杂的nHibernate查询,该查询将返回预计的DTO,但是我想使用TDD方法。该方法如下所示: public PrintDTO GetUsersForPrinting(int
您可以通过运行以下命令在事件 html 设置中显示 Jupyter 笔记本: $ jupyter nbconvert untitled.ipynb --to slides --post serve 有
如何在一个网站上拥有多个 AdSense 单元? Google 提供的唯一代码是按单位计算的。 (adsbygoogle = window.adsbygoogle || []).push({})
我刚刚开始为大量代码编写测试。有很多类依赖于文件系统,即读取 CSV 文件、读/写配置文件等。 当前测试文件存储在项目(这是一个 Maven2 项目)的 test 目录中,但由于多种原因该目录并不总是
我对 TDD 还很陌生,在单元测试方面也不是很老练,所以才有这个问题。我有这个用 PHP 编写的遗留函数 function foo(){ x = bar(); y = baz();
我创建了一个程序,在 Swing 窗口的一侧显示结果过滤选项,但默认情况下它们水平相邻显示,这浪费了我在 BorderLayout 的西侧分配的空间。我可以在构造函数或添加语句中传递任何内容来将它们堆
标题不好的借口:如果有人能更好地描述它,请做。 我有一个 WeakList类,它“基本上”是一个 List> (虽然不是字面意义上的派生自列表,但它应该对用户完全透明)。 现在的基本思想是“如果引用的
我正在尝试在 UITableView 上添加两个原型(prototype)单元。但是,我不知道如何验证是否能够为每个原型(prototype)“返回”正确的单元格。你们能帮我一下吗? func ta
我正在使用 CloudKit 作为数据库创建一个简单的待办事项列表应用程序。目前我可以添加和删除对象,但对编辑对象感到困惑。 编辑项目 Controller protocol EditItemCont
我正在针对以下任务训练 RNN:给定一个包含 30 个单词的序列,然后将该序列分类为二进制类。 在我的网络中拥有超过 30 个单元(LSTM、GRU 或普通 RNN)有好处吗?我在网上看到过很多例子,
我是一名优秀的程序员,十分优秀!