命令行应用的验收测试实践
1. 命令行应用测试概述
命令行应用与 Web 应用不同,其用户界面简单,输出也不复杂,这使得模拟输入和测试输出相对容易。然而,测试命令行应用也面临一些挑战,例如 db_backup.rb 执行备份操作需要访问真实数据库且耗时较长, todo 应用会对任务列表进行不可逆的修改。我们需要一种方法来运行应用,尽可能模拟“真实世界”的场景,同时确保测试具有可重复性和可预测性,且不会对环境造成永久性改变。
1.1 验收测试的概念
验收测试是从用户角度出发,用于确认应用是否正确实现某些功能的测试。它通常只测试用户可能尝试的操作子集(即所谓的“快乐路径”),不涵盖不常见的边缘情况。以 todo 应用为例,用户可能会进行以下操作:
- 添加新任务
- 列出任务
- 完成任务
- 获取帮助
1.2 测试工具选择
我们可以使用 Cucumber 作为验收测试工具,它能处理测试的基本基础设施。Cucumber 的附加库 Aruba 则为我们提供运行应用和验证其行为所需的工具。接下来,我们将了解这些工具的工作原理,进行安装和设置,最后编写测试用例。
2. 理解 Cucumber 和 Aruba
2.1 Cucumber 测试格式
Cucumber 编写的验收测试看起来像普通英语文本。它将测试划分为特性(Feature)和场景(Scenario),特性是应用的一个功能,场景则是对特性某个方面的测试。每个场景有一行描述,并由步骤(Step
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



