如何拆除specflow场景

时间:2016-03-29 12:50:25

标签: database specflow test-data scenarios teardown

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

目前,我有一组数据库备份,其中包含一组示例数据,我会在每次测试运行之前将其恢复。然而,这很麻烦,所以我只想在发布之前进行关键测试运行,并让持续集成运行在同一个数据库之间。

目前我有大量的测试类似于:

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来确保名称是唯一的,然后步骤可以通过模块变量访问它以检查它是否存在。

就像我说的那样,我有很多与此相似的测试,并且我在同一个数据库上多次运行它们,因此测试系统充满了物品,这会减慢搜索速度等。 / p>

我的问题是解决这个问题的最佳方法是什么?我是否应该在测试中创建另一个步骤,再次删除该项目:

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步骤的全球性,我想象如果有多个具有父子关系的项目可能会出现问题,那么以正确的顺序执行拆解步骤。

1 个答案:

答案 0 :(得分:7)

一个好的测试应该没有依赖关系,因此创建测试步骤然后“拆除”测试数据是一个好主意。

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

When I create an item with a unique name
<{3>}对象中的

,例如

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

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

然后,您可以创建与特定代码相关联的ScenarioContext,以便在方案完成时拆除此数据,例如场景将是(注意标签):

@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创建数据,那么该方案应该负责自己清理。