gpt4 book ai didi

c#-4.0 - 在单元测试中添加模拟数据表

转载 作者:行者123 更新时间:2023-12-02 21:08:52 25 4
gpt4 key购买 nike

我正在对我的职能之一进行单元测试。这是我的代码:

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"));
}

}

现在我收到错误:列“名称”不属于表。正如您所看到的,我在此处指定了列名称“Name”,并且还添加了该特定行。那为什么我会收到这个错误呢?有什么帮助吗?

谢谢!

最佳答案

您尚未设置列(除非您在示例中遗漏了某些代码)。

您需要先创建具有所需名称的列,然后才能像这样访问它们:

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

当您从数据库读取数据时,如果您已将 AutoGenerateColumns 设置为 true(默认值),则无需显式执行此操作,因为它已在幕后为您完成。

关于c#-4.0 - 在单元测试中添加模拟数据表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4444111/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com