2

我对 Specflow/Specrun 和 C# 编程非常陌生。我需要帮助来解决我面临的问题。

我有一个查询数据库的 Specrun 功能文件。以下是功能文件的代码:

Scenario Outline: Ensure all rows are correctly inserted on in the table
    Given I am connected to "Database-XYZ"
    When I run a script to ensure all rows are inserted for <tableName> of a <schemaName>
    Then All tables have correct <columnCount> count.

这绝对没问题。但我想注释第二行并在运行时使用 default.srprofile 文件指定数据库名称。

我想runtests.cmd使用 default.srprofile 文件执行文件(从命令行)并在运行时提供数据库名称。有可能实现这一目标吗?

4

1 回答 1

2

不确定这是否会有所帮助,但您可能想要使用 app.config。我设置了我的数据库和环境,然后从一个步骤中调用它。这样,您只需更改 app.config 中的值,就可以根据被测环境创建调用并设置数据库。您可以执行以下操作。

 app.config
 <add key="DatabaseTest" value="myDBConnectionString" />
 <add key="DatabaseDev" value="myDBConnectionString" />
 <add key="Environment" value="test" />

 Step:
 using System.Configuration; //make sure you have this included to use ConfigurationManager

    [Given(@"I am connected to my environment database")]
    public void GivenIAmConnectedToMyEnvironmentDatabase()
    {

     var myEnv = ConfigurationManager.AppSettings["Environment"];
     switch (myEnv)
     {
       case "test":
         var  _testDatabase = ConfigurationManager.AppSettings["DatabaseTest"];
         //create db connection 
         break;
       case "dev":
          var _devDatabase = ConfigurationManager.AppSettings["DatabaseDev"];
          //create db connection 
          break;
     }
     }
于 2016-11-12T03:59:09.543 回答