php - Behat是否可以根据当前环境使用不同的步骤数据?

标签 php continuous-integration integration-testing functional-testing behat

我遇到了一个难题。我们有一个过时的系统,我正在为其编写 Behat 测试。它在大多数情况下都很好用。但我注意到一个问题,如果我针对当前环境测试的数据是针对/从不同环境提取的,Behat 测试将失败。

例如,如果我在 QA 中测试电话搜索功能并希望它返回特定的实体 ID,我就不能使用相同的电话号码和实体 ID 在 RC 或 Live 中进行测试。所以我想要一种可管理的方式来维护 Behat 中每个环境的测试数据。

这里有一些想法,例如将数据放入配置文件(非常不受欢迎)或为每个功能创建 CSV 文件。我也在考虑使用表格或场景大纲构建所有特定于数据的场景,并拥有一个环境列,用于检查当前环境并在该行不适用于当前环境时跳过。也许使用背景或其他一些 Hook 来帮助解决这个问题。

有没有人知道使用 Behat 处理每个环境中具有不同数据集的多个环境的好方法或最佳实践?

最佳答案

根据 KNP Labs 的人员在他们的一次培训中所说,最佳做法是为场景创建必要的数据,作为 Given 或 Background 的一部分,因此您最终的步骤是“Given I have 7 phone numbers”,步骤定义插入七个电话号码,该场景的其余部分可以依赖这些电话号码。

当然,如果您希望针对生产站点运行测试,这通常是不可行的,而且我看到的策略确实会根据所涉及的特定数据量以及生产中数据的易变性而有所不同。

由于最佳实践还规定功能文件应根据功能受益人可以合理预期理解的术语来描述应用程序行为,因此在功能文件中公开环境条件数据的任何内容都不太可能是最佳方法。目标功能用户可能不知道不同的环境。

如果生产数据足够稳定,可以针对其编写测试,我会考虑在 behat.yml 中设置一个参数或配置文件,它可用于指示运行时的环境并编写自定义步骤定义。自定义步骤定义可以在一种情况下提供已知的生产值,并在其他情况下插入这些值。 Gherkin 仍然看起来像“假设我有 7 个电话号码”,因此该功能将专注于业务值(value)和对用户的好处,而不是测试环境。

关于php - Behat是否可以根据当前环境使用不同的步骤数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17457842/

相关文章:

php - MySQL查询根据某列进行join和group

php - 如何为每个目录设置 Php 的 auto_prepend_file 指令?

github - 如何在 GitHub actions 中安装旧版本的 Direct X Api

javascript - 将参数传递给回调函数而不更改方法(Siesta 测试命名空间)

javascript - 使用 Datatables 从 JSON 数据构建 HTML 动态表

javascript - 通过使用 ajax 更改 HTML 内容来制作多步表单无法正常工作

reactjs - 在 react 脚本测试中禁用颜色输出

continuous-integration - 使用 Travis CI 配置 Mysql 5.7

java - Spring boot 测试 API 和存储库的多个类

grails - 使用NetBeans在Grails中进行集成测试