如何拆除 specflow 场景

How to teardown a specflow scenario

我正在尝试创建一组新的测试来测试我正在处理的旧网站。该站点在后端使用数据库。我正计划使用 SpecFlow 和 Selenium,但是我对处理清理数据的最佳方法有点困惑。

目前我有一个数据库备份,其中包含我在每次测试前恢复的一组样本数据运行。然而,这很麻烦,所以我只想在发布前对关键测试 运行s 执行此操作,并让持续集成 运行s 在两者之间的同一数据库上工作。

目前我有大量的测试是这样的:

Secenario: Test Item Creation
    Given I am logged in
    When I create an item with a unique name
    Then an item exists with the unique name

when 步骤使用 GUID 确保名称是唯一的,然后步骤可以通过模块变量访问它以检查它是否存在。

就像我说的,但是我有很多类似的测试,我在同一个数据库上多次 运行ning 它们,所以测试系统被塞满了项目,这会减慢搜索速度等等。

我的问题是处理此问题的最佳方法是什么?我是否应该在测试中创建另一个步骤来再次删除该项目,如下所示:

Secenario: Test Item Creation
    Given I am logged in
    When I create an item with a unique name
    Then an item exists with the unique name
    Then delete the item with the unique name

或者我的测试框架是否应该能够以某种方式处理这个问题?如果是这样,人们会做什么?鉴于 SpecFlow 步骤的全局性质,我认为如果具有父子关系的多个项目可能会出现问题,则以正确的顺序获取拆卸步骤。

一个好的测试应该没有依赖关系,所以创建测试步骤然后 "tear down" 测试数据是个好主意。

您可以采取的一种方法是存储生成的唯一名称:

When I create an item with a unique name

ScenarioContext 对象中,例如

ScenarioContext.Current["testItem"] = "testItemName";

这将允许您在场景持续期间保留此值。

然后您可以创建一个与特定标签相关联的 SpecFlow hook 以在场景完成时拆除此数据,例如场景将是(注意标签):

@deleteTestItem
Secenario: Test Item Creation
Given I am logged in
When I create an item with a unique name
Then an item has exists with the unique name

清理代码为:

[AfterScenario("deleteTestItem")]
public void DeleteTestItem()
{
 var testItemName = ScenarioContext.Current["testItemName"];

 // Use testItemName to clean-up your database
}

此代码将仅 运行 用于具有此标签的场景。请注意,如果您的所有测试都涉及创建测试项,那么您可以省略标记并简单地使用 AfterScenario 挂钩。

或者,您可以将所有测试项名称保留在 FeatureContext 中,然后在 AfterFeature 挂钩中删除这些项。这将导致更少的数据库调用(即您不会在每个场景后调用数据库进行清理)。

我更喜欢 ScenarioContext 方法,因为我觉得如果一个 Scenario 创建了数据,那么该场景应该负责自己清理。