Cucumber 专题系列 - 第三篇:编写第一个 Feature 文件
什么是 Feature 文件?
Feature 文件是 Cucumber 的核心入口,用于描述软件功能和测试场景。它使用 Gherkin 语法 编写,以 .feature
为文件扩展名。Feature 文件的目标是让所有相关人员(开发人员、测试人员、业务分析师等)都能理解测试内容,同时为自动化测试提供基础。
Gherkin 语法基础
Gherkin 是一种结构化的自然语言,主要包括以下关键字:
- Feature:定义功能或用户故事。
- Scenario:描述一个具体的测试场景。
- Given:设置初始条件或上下文。
- When:触发某个动作或事件。
- Then:验证预期结果。
- And / But:补充前述步骤。
编写第一个 Feature 文件
让我们以一个简单的登录功能为例,逐步编写一个 Feature 文件。
示例:用户登录功能
Feature: 用户登录作为一个用户我希望能够登录系统以便访问我的账户Scenario: 成功登录Given 用户输入用户名 "user1"And 用户输入密码 "pass123"When 用户点击登录按钮Then 系统显示 "欢迎, user1"
结构分解
-
Feature 部分:
Feature: 用户登录
:功能名称。- 接下来的三行(
作为一个用户...
)是可选的描述,通常用来说明功能的目的和价值。
-
Scenario 部分:
Scenario: 成功登录
:一个具体的测试用例。- 使用 Given/When/Then 描述测试步骤:
- Given:初始条件,用户输入用户名和密码。
- When:触发动作,点击登录按钮。
- Then:预期结果,系统显示欢迎消息。
添加更多场景
为了覆盖更多情况,我们可以添加其他测试场景,例如登录失败:
Feature: 用户登录作为一个用户我希望能够登录系统以便访问我的账户Scenario: 成功登录Given 用户输入用户名 "user1"And 用户输入密码 "pass123"When 用户点击登录按钮Then 系统显示 "欢迎, user1"Scenario: 密码错误导致登录失败Given 用户输入用户名 "user1"And 用户输入密码 "wrongpass"When 用户点击登录按钮Then 系统显示 "登录失败,请检查用户名或密码"
- 说明:
- 每个 Scenario 是独立的测试用例。
- 步骤可以复用(如
用户输入用户名 "user1"
在两个场景中都出现)。
使用参数化步骤
Gherkin 支持在步骤中使用参数(用引号括起来),以提高灵活性。上述例子中,"user1"
和 "pass123"
是参数,它们会被传递到 Step Definitions。
Feature 文件的执行流程
Feature 文件本身只是描述,实际执行需要与 Step Definitions 配合。以下是绘制的简要流程: