ADO.NET测试(一) --当期望值是DataSet时

本文介绍了一种使用SQLDataAdapter从数据库中读取数据到DataSet的方法,并提供了两种验证数据完整性的策略:直接字符串比较和MD5哈希值对比。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     设有一个用户信息的SQL表,表中有Id和description两项。待测系统适用一个SqlDataAdapter对象从这个表里把数据读取到一个DataSet对象。

 

     假如对于一个特定的测试用例输入,期望的DataSet包含下面3项数据:

                                                                                                  001 Widget

                                                                                                  002 Wadget

                                                                                                  003 Wodget

    那么期望的聚合字符串就应该是:001Widget002Wadget003Wodget

 

    可以通过下面代码检查实际的DataSet对象是否包含期望的数据项:

  1. string ds = new DataSet(); //把实际结果保存到DataSet ds
  2. string expectData = "001Widget002Wadget003Wodget";
  3. string actualData = null;
  4. DataTable dt = ds.Tables[0];
  5. foreach(DataRow de in dt.Rows)
  6. {
  7.     foreach(DataColumn dc in dt.Columns)
  8.     {
  9.         actualData += dr[dc];
  10.     }
  11. }
  12. if(actualData == expectData)
  13.     Console.WriteLine("Pass");
  14. else
  15.     Console.WriteLine("Fail");

    我们应该首先取回实际DataSet对象里的DataTable对象,然后遍历它的DataRow集合,获得每个列的值,并且把它追加到字符串变量的后面。

 

    如果期望数据非常多,我们可以通过计算并比较这些数据的哈希值即可:

  1. string ds = new DataSet();
  2. //string expectedData = "001Widget002Wadget003Wodget";
  3. string expectedHash = "EC-5C-E5-E5-6D-1D-8C-DD-6E-2A-2B-6B-D3-CB-C1-28"
  4. string actualData = null;
  5. string actualHash = null;
  6. DataTable dt = ds.Tables[0];
  7. foreach(DataRow de in dt.Rows)
  8. {
  9.     foreach(DataColumn dc in dt.Columns)
  10.     {
  11.         actualData += dr[dc];
  12.     }
  13. }
  14. MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
  15. byte[] ba = md5.ComputeHash(Encodeing.ASCII.GetBytes(actualData));
  16. actualHash = BitConverter.ToString(ba);  //返回一个用连字符号(-)连接的表示16进制数的字符串
  17. if(actualHash == expectedHash)
  18.     Console.WriteLine("Pass");
  19. else
  20.     Console.WriteLine("Fail");

    通过比较期望值数据的MD5(Message Digest version 5)哈希值,可以避免存储非常多的期望字符串数据,因为所有MD5哈希值的长度都是16个字节。用于加密的哈希算法(和用于哈希表的哈希算法不同),其目的是为了产生一个字节序列的指纹,或者说摘要。因为哈希的过程是不可逆的,这些哈希值仅仅用于识别,而不是加密/揭秘。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值