上两篇文章演示了怎样用Excel配合Page Object Model来实现数据驱动。Excel功能很强大,自带的POI插件用起来很方便,没有什么问题。但是,现在越来越多的公司都在用各式各样的版本控制系统来管理项目,比如git,功能非常强大,假如你现在服务器上有一个项目,它允许多人下载这个项目然后同时各自修改,然后把改完的推送至服务器端再整合成一个。
这就带来一个问题:每个人改的地方不一样还好说,但假如有A,B两个人改了同一处代码势必会产生冲突,其中A就得再下载一份包含B改动的项目然后再解决冲突。不过git也很聪明,能很方便的解决冲突,不会让A重新写一遍。可惜的是,不是每个项目里的文件有了冲突都可以被轻松解决,Excel就不幸成为了其中一员。一旦A,B两人修改了同一个Excel文件产生了冲突问题,解决起来很麻烦。
由于这个原因,如果可以选择,我们可以选择用excel的变种csv文件来存放测试数据。csv文件可以用纯文本形式存储信息,以逗号来分隔字符,非常适合放有一定格式要求的文字。比如我们的测试数据是用户名和密码,放在csv文件里就是按照“用户名,密码”一行一行显示。演示一下,新建一个空的.xlsx或.xls的Excel文件 ->另存为–>选择csv(comma delimiter )。然后按照下面格式输入:
关闭csv文件,用记事本打开,会发现它们用逗号隔开:
csv默认情况下是用逗号进行分割,当然你也可以把逗号改成别的符号,比如"|"或空格之类的,有兴趣的朋友做完项目可以去改改试试。再看一遍Test case,步骤如下:
1. 打开http://localhost:8081/selenium/hrsystem/index.php;
2. 输入用户名和密码;
3. 点击登录按钮(断言点:home按钮出现在home.php页);
4. 退出(断言点:登录按钮出现在index.php页)。
项目的结构保持不变,还是POM的结构:
由于只是改的数据源文件格式,所以只用修改Test.java中读取数据源的步骤就可以了,loginPage.properties和LoginPage.java都不用改。直接粘上来:
loginPage.properties:
LoginPage.java:
因为csv文件里的是字符,所以这里我用缓冲字符流的方式读,不太清楚缓冲流怎么回事的请复习文件与字符流那篇的内容。我们先上代码,然后按行讲解:
我在第42行用while循环让缓冲字符流对象br每次读一行,第一行只是个标题,不重要,重要的后面几行。比如现在读出了第一行”1001,123”,我一看,这逗号真讨厌,我只需要这两个数,怎样才能把它去掉呢?之前讲字符串操作那节说过我们可以用一个叫split()的方法,它以一个字符为基准把该字符串拆成若干部分,并把它们用一个字符串数组装起来。现在就可以用了。因为csv文件的分隔符是个逗号,而且代表每一行的字符串变量是line,所以我在第45行用line.split(“,”)来根据逗号拆分。每一行里只有一个逗号,显然只能拆成前后两部分,返回的就是一个长度为2的字符串数组,我用arr_loginDetails代表它。0号位置放”1001”,1号位置放”123”,以此类推:
如果刚读完第一行就直接进行下一次循环,第二次arr_loginDetails就会存”1002,456”,第一次的值就丢了,所以该到用ArrayList存数据的时候了。我在第26行创建的叫al的ArrayList<String[]>,然后在第48行来存每一次循环完的字符串数组。最后循环完毕al就会变成<[EmpCode,Password],[1001,123],[1002,456],[1003,789]>。
从al中取数组时还是使用遍历,在第77行,注意循环从1号位置开始,因为0号位置的数组是[EmpCode,Password],是表头,用不着。然后arr_loginDetails[0]取出的是用户名,arr_loginDetails[1]取出的是密码。剩下的就是把数据用在登录和断言步骤中,和上篇用Excel的例子一致。这样,每次循环都用了不同的参数来,以此来达到数据驱动的目的。
执行一下,没问题:
这就是用csv文件承载测试数据的一个简单演示。Excel和csv演示数据驱动就都说完了,其实txt/xml等文件格式也可以用来存数据源,道理大同小异,大家可以任选,不过真正工作的时候还是根据老板的要求来写。
这篇文章的源代码是SeleniumCsvDataDrivenPOM项目。