gpt4 book ai didi

javascript - 从外部文件加载 cucumber /小 cucumber 中的数据

转载 作者:行者123 更新时间:2023-12-05 06:56:29 25 4
gpt4 key购买 nike

我在 JS/Node 项目中使用 Cucumber(并在小 cucumber 中编写测试),我发现自己在不同的示例中复制了大量测试数据(场景大纲示例)。

大多数情况是使用具有不同属性的用户列表,需要使用这些属性来确保网页的不同部分适用于所有用户。

因此测试以这样的方式结束:

Scenario: s1
Given xxx
Then yyy <field1>
Then zzz <field2>

Examples:
| username | field1 | field2 |
| user1 | f11 | f21 |
| user2 | f12 | f22 |

Scenario: s2
Given xxx
Then yyy <field1>
Then zzz <field2>

Examples:
| username | field1 | field2 |
| user1 | f11 | f21 |
| user2 | f12 | f22 |

如您所见,场景s1s2示例 是相同的...所以我认为这是个好主意从外部文件加载它们,从而可以轻松地跨场景/文件共享(这只是一个包含 2 个场景的简单示例,但请考虑一个具有很多功能的真实应用程序)。

如果更新了用户的数据,则意味着我必须更新所有示例...而如果我只是从外部文件加载它,则只有一个地方需要更新。

我看到有些网站提供了该功能,例如 as here ,但不知道如何自己做才能拥有类似的东西:

Scenario: s2
Given xxx
Then yyy <field1>
Then zzz <field2>

Examples: {"dataFile":"./users.csv"}

总有一些替代方案,比如预处理 .feature 文件并将这些行替换为文件的内容或类似的东西......但我想知道是否还有更多原生 或直接,因为我不想走那条路,或大量定制...

我找不到任何东西,所以欢迎任何东西。

最佳答案

您不能使用功能文件进行任何编程。这是设计的,因为功能文件旨在成为一种人类可读的文档形式;它应该以业务和 IT 利益相关者都能理解的方式描述系统的预期行为。

考虑到这一点,问题就变成了您是否需要在特征文件中添加字段及其值的详细信息。拥有这些详细信息是否会使文件更易于理解? (剧透:事实并非如此)。

我的建议是将这些细节向下移动到步骤定义中,并仅以高级术语描述特定案例(步骤/场景/示例)。

例如,我处理订单的系统之一。我们有不同类型的订单,其中包含不同类型的产品、交付方式、付款方式等。虽然每个订单都需要填写所有这些字段,但并非所有字段都与任何特定场景相关。因此,我们在特征文件中描述相关部分,并对其余数据使用默认值。此数据在创建我们需要的对象的辅助方法中设置,步骤定义为特定步骤/场景调用相关的辅助方法。

因此,步骤给定一个信用卡付款订单 将创建默认订单并添加信用卡付款。给定一个包含多个产品的订单 创建一个包含多个产品(以及默认付款信息等)的订单。

(虽然您可以将这些数据存储在 Excel 或其他文件中并从那里读取,但我可以根据经验告诉您,这会让您的生活变得更艰难,而不是更轻松。设置它比使用您的程序需要更多时间创建对象/数据的语言,而且您的测试将需要更长的时间才能运行,因为处理文件需要时间)。

关于javascript - 从外部文件加载 cucumber /小 cucumber 中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65121893/

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