学习.NET Framework 3.5时,经常会遇到LINQ进行查询问题,这里将介绍LINQ进行查询问题的解决方法。
.NET Framework 3.5中引入了一个新特性LINQ(集成语言查询),据说.NET Framework 3.5中很多特性都是为LINQ而服务的,例如Lambda表达式的支持,匿名类型,等等……这篇文章会讲述一个把Linq to Object应用于测试的例子。
前一阵子需要测试一个搜索在线会员的功能,如果一个用户是在线的,那么他所能够被搜索到的信息都会作为一条记录,保存在一个表中,主要的字段有5 个,也就是根据这5个字段的信息可以查询出用户想要的在线会员。一个简单的方案就是写一个比较复杂的存储过程,然后根据5个输入来查询出不同的结果,不过 DBA说在SQL SERVER中进行逻辑运算的性能不是很好,所以开发人员写了12条存储过程,分别对应不同的组合,那么对于我做集成测试来说,我起码要有12个测试方法对应这12条存储过程。同时我还要设计一定数量的测试数据,供我查询测试,而比较要命的是,这些测试数据随着我对这个功能的理解的深入,在不断地增加,结果就是如果我写第一个测试的时候,我准备的数据是30条,OK,测试通过; 等我写到第五个测试的时候,测试数据可能有40条了,当我用这40条测试数据重新指向第一个测试的时候,FAILED!!!这让人非常郁闷。所以我想到了能不能用round trip的方法来进行测试。做一个比喻,假如说我想证明WIN7的计算器程序是正确的,那么可以把相同的计算在WIN XP的计算器中跑一遍,如果两者结果一样,那么我可以认为WIN7的计算器程序也是正确的(如果XP的计算器有错怎么办?先别较真,有风险,但很小)。
我的做法就是,准备一些数据,首先用SUT进行查询,然后用LINQ进行查询,如果两者查询结果一致,那么可以认为程序是正确的,否则就是两者之一存在问题。
首先准备一些测试数据,保存为XML文件,第一方便对测试数据进行CRUD,第二可以用XmlSerializer把这些数据转换为对象,方便用LINQ进行查询。
- < ?xml version="1.0" encoding="utf-8" ?>
- <onlinefriends>
- <friends>
- <onlinefrienddata>
- <friendid>1300010000friendid>
- <province>北京市province>
- <city>北京市city>
- <age>18age>
- <gender>2gender>
- <hasphoto>truehasphoto>
- onlinefrienddata>
- <onlinefrienddata>
- <friendid>1300010002friendid>
- <province>北京市province>
- <city>北京市city>
- <age>27age>
- <gender>2gender>
- <hasphoto>falsehasphoto>
- onlinefrienddata>
- <onlinefrienddata>
- <friendid>1300010004friendid>
- <province>广东省province>
- <city>广州市city>
- <age>45age>
- <gender>1gender>
- <hasphoto>truehasphoto>
- onlinefrienddata>
- friends>
- onlinefriends>
【编辑推荐】