SpecFlow - 表格转换为字典

表格可以在特征文件中水平和垂直方向保存数据。使用 Dictionary 对象,我们将了解如何以键值对的形式垂直访问特征文件中的数据。

步骤 1:创建特征文件

有关如何创建特征文件的详细信息在"特征文件"一章中进行了详细讨论。

Feature: User credential
Scenario: Login module
   When User types details
   | KY       | Val            |
   | username | tutorialspoint |
   | password | pwd1           |
Then user should be able to login

步骤 2:创建 C# 文件以访问表数据

我们必须通过 System.Collections.Generic 包将表转换为字典。我们将在项目中创建一个新文件夹并在其中放置一个 C# 文件。右键单击 SpecFlow 项目,然后单击 添加

选择选项 新建文件夹

SpecFlow Assists

将文件夹命名为 Utils

右键单击新创建的文件夹,然后选择选项 添加。 单击

Utils

项目文件夹结构

Utilses

C# 类实现

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using TechTalk.SpecFlow;
namespace SpecFlowProject1.Utils {
   class Class1 {
      public static Dictionary<string, string> ToDT(Table t) {
         var dT = new Dictionary<string, string>();
         
         // iterating through rows
         foreach (var r in t.Rows) {
            dT.Add(r[0], r[1]);
         }
         return dT;
      }
   }
}

步骤 3:创建步骤定义文件

有关如何创建步骤定义文件的详细信息,请参阅第 − 章"步骤定义文件"。

using System;
using TechTalk.SpecFlow;
namespace SpecFlowProject1.Features {
   [Binding]
   public class UserCredentialSteps {
      [When(@"User types details")]
      public void WhenUserTypesDetails(Table t) {  
         
         //Accessing C# class method from Step Definition
         var dict = Utils.Class1.ToDT(t);
         Console.WriteLine(dict["username"]);
         Console.WriteLine(dict["password"]);
      }   
      [Then(@"user should be able to login")]
      public void ThenUserShouldBeAbleToLogin() {
         Console.WriteLine("User should be able to login");
      }
   }
}

步骤 4:执行和结果

选择 用户凭据 (1) 功能,然后单击 在视图中运行所有测试

测试视图

选择 登录模块场景,然后单击 为此结果打开其他输出链接

测试视图

测试视图

场景已使用从 When 步骤中的功能文件中的表 (转换为字典) 传递的数据执行。