Подтвердить что ты не робот

Добавление фиктивного Datatable в модульном тестировании

Я - Единица, проверяющая одну из моих функций. Вот мой код:

public void TestLabels()
{

  //Step 1: Creating a mock table with columns exactly like in the real table.
  DataTable table = new DataTable();

  DataRow mydatarow;
  mydatarow = table.NewRow();

  //Step 2: Adding the row as same as the Real Data!

  mydatarow["Name"] = "Test";
  mydatarow["Address"] = "00000 ST.";
  mydatarow["ZipCode"] = "77665";
  mydatarow["Tracking#"] = "";

  table.Rows.Add(mydatarow);

  foreach (DataColumn column in table.Columns)
    Console.WriteLine(column.ColumnName);

  //Step 3: Call method we are testing.
  var updateTable = IceTechUPSClient.Instance.CreateLabels(table);

  foreach (DataRow row in updateTable.Rows)
  {
    var trackingNumber = row["Tracking#"].ToString();
    Assert.IsFalse(String.IsNullOrWhiteSpace(trackingNumber), "Expecting tracking number generated for every row!");
    Assert.IsTrue(File.Exists(trackingNumber + ".gif"));
  }

}

Теперь я получаю сообщение об ошибке: Столбец "Имя" не относится к таблице. Как вы можете видеть, я указал здесь имя столбца "Имя", а также добавил эту конкретную строку. Тогда почему я получаю эту ошибку? Любая помощь?

Спасибо!

4b9b3361

Ответ 1

Вы не настроили свои столбцы (если вы не пропустили какой-либо код в вашем примере).

Вам необходимо создать столбцы с требуемыми именами, прежде чем вы сможете получить к ним доступ следующим образом:

var columnSpec = new DataColumn
                    {
                        DataType = typeof(string),
                        ColumnName = "Name"
                    };
this.table.Columns.Add(columnSpec);

Когда вы читаете данные из базы данных, если вы установили AutoGenerateColumns в true (по умолчанию), вам не нужно делать это явно, как это сделано для вас за кулисами.