gpt4 book ai didi

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

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:35:46 26 4
gpt4 key购买 nike

我遇到了一个难题。我们有一个过时的系统,我正在为其编写 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com