Cucumber-Rails 项目技术文档
2024-12-23 19:19:34作者:钟日瑜
1. 安装指南
1.1 添加 Gem 到项目
首先,将 cucumber-rails 添加到项目的 Gemfile 中。在 Gemfile 的 test 组中添加以下内容:
group :test do
gem 'cucumber-rails', require: false
# database_cleaner 不是必须的,但强烈推荐使用
gem 'database_cleaner'
end
1.2 安装 Gem
运行以下命令来安装 Gem:
bundle install
1.3 生成配置文件
安装完成后,运行以下命令来生成 Cucumber 的配置文件:
rails generate cucumber:install
你可以通过以下命令查看生成器的帮助信息:
rails generate cucumber:install --help
2. 项目的使用说明
2.1 运行 Cucumber
安装完成后,你可以通过以下命令运行 Cucumber 测试:
bundle exec cucumber
2.2 配置选项
2.2.1 禁用数据库清理
默认情况下,cucumber-rails 会在每个场景前后运行 DatabaseCleaner.start 和 DatabaseCleaner.clean。你可以通过以下方式禁用此行为:
# features/support/env.rb
Cucumber::Rails::Database.autorun_database_cleaner = false
2.2.2 禁用 Rack::Test 助手
默认情况下,cucumber-rails 会自动将 Rack::Test 的助手方法混合到默认的 Cucumber World 实例中。你可以通过以下方式禁用此行为:
# features/support/env.rb
ENV['CR_REMOVE_RACK_TEST_HELPERS'] = 'true'
3. 项目 API 使用文档
cucumber-rails 提供了一些配置选项和助手方法,帮助你在 Rails 项目中更好地使用 Cucumber。以下是一些常用的 API 和配置选项:
3.1 数据库清理 API
Cucumber::Rails::Database.autorun_database_cleaner = false:禁用自动数据库清理。
3.2 Rack::Test 助手 API
ENV['CR_REMOVE_RACK_TEST_HELPERS'] = 'true':禁用Rack::Test助手方法。
4. 项目安装方式
4.1 升级到新版本
如果你从旧版本升级到新版本,建议重新运行安装命令:
rails generate cucumber:install
4.2 设置开发环境
如果你需要为项目贡献代码,可以按照以下步骤设置开发环境:
- 确保你安装了支持的 Ruby 版本。
- 进入
cucumber-rails仓库目录并运行以下命令:
gem install bundler
bundle install
bin/install_geckodriver.sh
bin/install_webpacker.sh
4.3 运行测试
安装所有依赖后,运行以下命令来执行所有测试:
bundle exec rake
4.4 运行 Appraisal 测试套件
为了测试多个版本的依赖项,cucumber-rails 使用了 Appraisal 来生成多个 Gemfile。你可以通过以下命令运行完整的测试套件:
bundle exec appraisal install
bundle exec appraisal rake test
或者针对特定的 Gemfile 运行测试:
bundle exec appraisal rails_6_0 rake test
4.5 添加依赖项
在添加新的依赖项时,请遵循以下规则:
- 如果是运行时依赖项,添加到 Gemspec 中。
- 如果是主要的开发依赖项,添加到 Gemspec 中。
- 如果是生成 Rails 应用测试的依赖项,添加到修改
Gemfile的辅助方法中。
例如,rspec 是一个主要的开发依赖项,因此它位于 Gemspec 中。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
new-apiAI模型聚合管理中转分发系统,一个应用管理您的所有AI模型,支持将多种大模型转为统一格式调用,支持OpenAI、Claude、Gemini等格式,可供个人或者企业内部管理与分发渠道使用。🍥 A Unified AI Model Management & Distribution System. Aggregate all your LLMs into one app and access them via an OpenAI-compatible API, with native support for Claude (Messages) and Gemini formats.JavaScript01
idea-claude-code-gui一个功能强大的 IntelliJ IDEA 插件,为开发者提供 Claude Code 和 OpenAI Codex 双 AI 工具的可视化操作界面,让 AI 辅助编程变得更加高效和直观。Java01
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
519
3.69 K
暂无简介
Dart
760
182
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
67
20
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
875
569
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
334
160
方舟分析器:面向ArkTS语言的静态程序分析框架
TypeScript
169
53
Ascend Extension for PyTorch
Python
321
373
React Native鸿蒙化仓库
JavaScript
301
347