在我们的项目中,我们有多个按 SKU ID 区分的 SKU。我们正在测试将 SKU 添加到数据库的不同场景。每个场景之后,数据库中都应该进行清理,以使用 AfterScenario
Hook 删除该特定场景添加的 SKU。清理方法应接收每个场景添加的 SKU Id,以便仅删除这些数据。如何将参数传递给 AfterScenario
标记的清理方法(下面给出的需求示例)。
[AfterScenario]
public void Cleanup(string skuId)
{
//delete skuId from Db.
}
最佳答案
最好通过将每个场景创建的 SKU 放入 ScenarioContext 中来跟踪它们。您可以将其引用作为步骤定义的构造函数参数。然后你可以在你的钩子(Hook)中访问它并删除它们:
public class SkuSteps
{
private readonly ScenarioContext scenario;
public SkuSteps(ScenarioContext scenario)
{
this.scenario = scenario;
}
[Given(@"a sku named ""(.*)"" exists")]
public void GivenASkuNamedExists(string sku)
{
// create sku
scenario.AddSku(sku);
}
}
public static class ScenarioExtensions
{
public static void AddSku(this ScenarioContext scenario, string sku)
{
var skus = scenario.GetSkus();
skus.Add(sku);
}
public static List<string> GetSkus()
{
if (!scenario.ContainsKey("skus"))
{
scenario["skus"] = new List<string>();
}
return (List<string>)scenario["skus"];
}
}
public class Hooks
{
private readonly ScenarioContext scenario;
public Hooks(ScenarioContext scenario)
{
this.scenario = scenario;
}
[AfterScenario]
public void DeleteSkus()
{
var skusToDelete = scenario.GetSkus();
// delete the skus
}
}
关于c# - 如何使用钩子(Hook)的参数化方法 - SpecFlow,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63065202/