Cucumber-CPP 技术文档
2024-12-14 15:20:47作者:谭伦延
1. 安装指南
Cucumber-CPP 是一个允许使用 C++ 编写步骤定义的库。以下是安装 Cucumber-CPP 的步骤:
依赖性
Cucumber-CPP 依赖于以下可执行文件和库:
- cmake 3.16 或更高版本。用于设置环境和构建软件。
- Asio 1.18.1 或更高版本。
- Boost.Test 1.70(可选,用于 Boost 测试驱动程序)。
- GTest 1.11.0 或更高版本(可选,用于 GTest 驱动程序)。
- GMock 1.11.0 或更高版本(可选,用于内部测试套件)。
- nlohmann-json 3.10.5 或更高版本。
- Qt6 或 Qt5(可选,用于 CalcQt 示例和 QtTest 驱动程序)。
- TCLAP 1.2.5 或更高版本。
为了安装 Ruby 预先条件:
gem install bundler // 对于 Windows:gem install bundle
bundle install
Windows 与 Linux
为了在特定的系统(Windows 或 Linux)上设置依赖项,可以查看 Windows 和 Linux 的工作流文件以获取灵感。
2. 项目的使用说明
安装完所有依赖后,你可以通过以下步骤构建和运行 Cucumber-CPP。
构建步骤
构建 Cucumber-CPP,包括测试和示例:
# 创建构建目录
cmake -E make_directory build
# 生成 Makefile
cmake -E chdir build cmake \
-DCUKE_ENABLE_BOOST_TEST=on \
-DCUKE_ENABLE_GTEST=on \
-DCUKE_ENABLE_QT_6=on \
-DCUKE_TESTS_UNIT=on \
-DCUKE_ENABLE_EXAMPLES=on \
..
# 构建 cucumber-cpp
cmake --build build
# 运行单元测试
cmake --build build --target test
# 运行安装
cmake --install build
运行示例
Unix 系统上的 Calc 示例
build/examples/Calc/BoostCalculatorSteps >/dev/null &
(cd examples/Calc; cucumber)
Windows 系统上的 Calc 示例(NMake)
start build\examples\Calc\BoostCalculatorSteps.exe
cucumber examples\Calc
3. 项目 API 使用文档
Cucumber-CPP 使用线缆协议与 Cucumber-Ruby 进行通信。你需要确保 Cucumber-Ruby 已经安装在系统路径上。关于 Cucumber-CPP 的详细 API 文档,请参考官方 GitHub Wiki。
4. 项目安装方式
Cucumber-CPP 可以通过以下方式安装:
- 通过源代码下载和构建。
- 使用包管理器(如果支持的话)。
确保你已经安装了所有必要的依赖项,并按照上述构建步骤进行操作。
通过上述内容,你应该能够成功地安装和使用 Cucumber-CPP,并开始编写 C++ 的步骤定义。如果遇到任何问题,请参考官方文档或在社区讨论组中提问。
热门项目推荐
相关项目推荐
- 国产编程语言蓝皮书《国产编程语言蓝皮书》-编委会工作区017
- nuttxApache NuttX is a mature, real-time embedded operating system (RTOS).C00
- qwerty-learner为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workersTSX027
- 每日精选项目🔥🔥 01.17日推荐:一个开源电子商务平台,模块化和 API 优先🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~026
- Cangjie-Examples本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie045
- 毕方Talon工具本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python039
- PDFMathTranslatePDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython05
- mybatis-plusmybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript0108
- taro开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/TypeScript09
热门内容推荐
最新内容推荐
项目优选
收起
Python-100-Days
Python - 100天从新手到大师
Python
266
55
国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区
65
17
Cangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
196
45
openHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
53
44
HarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
268
69
qwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
333
27
CangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
896
0
advanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
419
108
MateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。
官网地址:https://matechat.gitcode.com
144
24
HarmonyOS-Cangjie-Cases
参考 HarmonyOS-Cases/Cases,提供仓颉开发鸿蒙 NEXT 应用的案例集
Cangjie
58
4