Python 在功能间共享数据

Python Behave sharing data between features

我从 Python 开始,因为我想做一个 API 测试。
目前我偶然发现了一些甚至可能无效的东西,但问题是:我可以在功能之间共享数据吗?我可以将一些存储在数据库或文件中,但也许有一些东西 'builtin'?

或者这是无效的,我不应该像那样共享数据,或者可能在功能内部共享?

实际上它看起来像:

我必须向端点发出请求,在响应中我得到一个数字,需要它才能发出另一个需要测试的请求。

是的,你可以,而且很简单。在您拥有特征文件的同一目录中,您可以创建一个名为 environment.py 的文件。在其中,您可以输入:

def before_all(context):
    context.db = whatever

before_all 挂钩在所有测试之前 运行 并且您在那里设置的任何内容都可用于所有功能。例如,我使用它来创建一个新的 Selenium 实例,该实例将被测试套件中的所有测试使用。 context.db 以上可能是数据库连接。这样的分享就好了

您分享的内容应该是只读的,或者可以在测试之间重置为已知状态。在测试之间共享可写资源不是一个好习惯。当测试失败时很难找出问题所在,并且使测试相互依赖。因此,如果你在测试 C 上失败,但它取决于 A 和 B,你不能只要求 Behave to 运行 测试 C。你必须要求它 运行 A,B 然后 C.

如果您决定违背最佳实践并仍然这样做,您应该知道 context 上设置的新值受功能和场景的限制。因此,如果您的 before_all 挂钩设置 context.foo = 1,然后功能 A 设置 context.foo = 2。当特征 B 在特征 A 之后 运行s 时,它将看到 context.foo 的值 1 因为 Behave 将删除特征 A 所做的更改(特征 A 所做的更改是 "scoped" 到特征 A。)现在,您必须记住 Python 如何存储值。如果钩子设置 context.foo = [] 而功能 A 设置 context.foo.append(1),那么功能 B 将看到 context.foo 的值为 [1] 因为 context.foo 包含一个 reference 到数组并调用 append 更改数组 本身 。因此可以解决范围界定问题。不过,这仍然不可取。

我最后检查了一下,功能是 运行 按字母顺序排列的。您可以通过在命令行上指定功能来强制执行顺序:behave B.feature A.feature