c# - 比较两个数据表(单元测试、集成测试、C#、TestMethod)

标签 c# unit-testing datatable integration-testing assert

在比较本应不同且具有多行的数据表时,在单元测试中应该进行什么样的测试。

    [TestMethod]
    public void ExecuteOutWithMultipleDataTables()
    {
        //Arrange
        int id1 = TestOrderBuilder.New().Build();
        DataTable dtDefault = CreateDefaultDataTable(id1, "OUT", "TableDesc", DateTime.Now);

        //Act
        object[] result = OracleDatabase.ExecuteOut(SqlStatements.Cursor, procedureParameters);
        DataTable dtResults = result[0] as DataTable;

        //Assert
        Assert.IsNotNull(dtDefault);
        Assert.IsNotNull(dtResults);
        Assert.AreNotEqual(dtDefault, dtResults);
        Assert.AreNotSame(dtDefault.Rows[0][0], dtResults.Rows[0][0]);
        Assert.AreNotSame(dtDefault.Rows[0][1], dtResults.Rows[0][1]);
    }

这是我已经写过的一些例子,但我不确定我是否走在正确的轨道上。

有人有什么建议吗?

苹果

最佳答案

如果您需要验证每一行和每一列的值,您需要编写一个辅助方法。

此外,它看起来不像是单元测试,因为它看起来是在调用真实数据库而不是模拟它。

可能像下面这样

private bool IsTableSame(DataTable t1, DataTable t2)
    {
        if (t1 == null)
            return false;
        if (t2 == null)
            return false;
        if (t1.Rows.Count != t2.Rows.Count)
            return false;

        if (t1.Columns.Count != t2.Columns.Count)
            return false;

        if (t1.Columns.Cast<DataColumn>().Any(dc => !t2.Columns.Contains(dc.ColumnName)))
        {
            return false;
        }

        for (int i = 0; i <= t1.Rows.Count-1; i++)
        {
            if (t1.Columns.Cast<DataColumn>().Any(dc1 => t1.Rows[i][dc1.ColumnName].ToString() != t2.Rows[i][dc1.ColumnName].ToString()))
            {
                return false;
            } 
        }

        return true;
    }

关于c# - 比较两个数据表(单元测试、集成测试、C#、TestMethod),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15221437/

相关文章:

c++ - 有没有办法检测升压单元测试二进制文件中有哪些测试

javascript - DataTable - 在 jQuery 中获取所有选定行的简单方法

ios - XCTAssert NSSet 计数

c# - 更改 MapControl 中的重叠顺序

c# - {"Cannot insert explicit value for identity column in table ' Cantact' 当 IDENTITY_INSERT 设置为 OFF 时。"}

c# - 如何从 C# 中的 Azure HTTP 触发器函数删除 CosmosDB 中的项目

javascript - sinon 监听回调

.net - 当列名包含空格时,为什么我的 DataTable 不能正确序列化?

javascript - 为什么服务器端 DataTable 上的 rows() 不是函数?

c# - 在 ASP.NET MVC 应用程序中保存配置信息的最佳实践在哪里?