转载:https://blog.csdn.net/heart_1014/article/details/52013173

使用@DataProvider注解定义当前方法中的返回对象CSV文件(存放测试数据)作为测试脚本的测试数据集进行数据驱动。

用法参考代码:

代码在搜索完成后使用显式等待方式,确认页面已经加载完成,页面底部的关键字"搜索帮助"已经显示在页面上

  1.  
    //从CSV文件中读取每行中前2个逗号分割的中文词作为搜索框中输入的搜索关键词
  2.  
    //断言搜索结果页面是否包含CSV文件中每行的最后一个词汇的关键字
  3.  
    import java.io.BufferedReader;
  4.  
    import java.io.FileInputStream;
  5.  
    import java.io.IOException;
  6.  
    import java.io.InputStreamReader;
  7.  
    import java.util.ArrayList;
  8.  
    import java.util.List;
  9.  
    import java.util.concurrent.TimeUnit;
  10.  
     
  11.  
    import org.openqa.selenium.By;
  12.  
    import org.openqa.selenium.WebDriver;
  13.  
    import org.openqa.selenium.firefox.FirefoxDriver;
  14.  
    import org.openqa.selenium.support.ui.ExpectedCondition;
  15.  
    import org.openqa.selenium.support.ui.WebDriverWait;
  16.  
    import org.testng.Assert;
  17.  
    import org.testng.annotations.AfterMethod;
  18.  
    import org.testng.annotations.BeforeMethod;
  19.  
    import org.testng.annotations.DataProvider;
  20.  
    import org.testng.annotations.Test;
  21.  
     
  22.  
    public class TestDataByCSVFile {
  23.  
    private static WebDriver driver;
  24.  
    @DataProvider(name="searchData")
  25.  
    public static Object[][] data() throws IOException
  26.  
    {
  27.  
    return getSearchData("E:\\AutoData\\testData.csv");//获取CSV文件的测试数据
  28.  
    }
  29.  
    @Test(dataProvider="searchData")
  30.  
    public void testSearch(String searchdata1,String searchdata2,String searchResult) {
  31.  
    //打开sogou首页
  32.  
    driver.get("http://www.sogou.com/");
  33.  
    //输入搜索条件
  34.  
    //从CSV文件中读取每行中前2个逗号分割的中文词作为搜索框中输入的搜索关键词,在两个搜索词中间增加一个空格
  35.  
    driver.findElement(By.id("query")).sendKeys(searchdata1+" "+searchdata2);
  36.  
    //单击搜索按钮
  37.  
    driver.findElement(By.id("stb")).click();
  38.  
     
  39.  
    //使用显式等待方式,确认页面已经加载完成,页面底部的关键字"搜索帮助"已经显示在页面上
  40.  
    (new WebDriverWait(driver,3)).until(new ExpectedCondition<Boolean>(){
  41.  
     
  42.  
    @Override
  43.  
    public Boolean apply(WebDriver d) {
  44.  
    return d.findElement(By.id("sogou_webhelp")).getText().contains("搜索帮助");
  45.  
    }});
  46.  
     
  47.  
    //断言搜索结果页面是否包含CSV文件中每行的最后一个词汇的关键字
  48.  
    Assert.assertTrue(driver.getPageSource().contains(searchResult));
  49.  
    }
  50.  
    @BeforeMethod
  51.  
    public void beforeMethod() {
  52.  
    //若无法打开Firefox浏览器,可设定Firefox浏览器的安装路径
  53.  
    System.setProperty("webdriver.firefox.bin", "D:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe");
  54.  
    //打开Firefox浏览器
  55.  
    driver=new FirefoxDriver();
  56.  
    //设定等待时间为5秒
  57.  
    driver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);
  58.  
    }
  59.  
     
  60.  
    @AfterMethod
  61.  
    public void afterMethod() {
  62.  
    //关闭打开的浏览器
  63.  
    driver.quit();
  64.  
    }
  65.  
    //读取CSV文件的静态方法,使用CSV文件的绝对文件路径作为函数参数
  66.  
    public static Object[][] getSearchData(String FileNameroot) throws IOException{
  67.  
    List<Object[]> records=new ArrayList<Object[]>();
  68.  
    String record;
  69.  
    //设定UTF-8字符集,使用带缓冲区的字符输入流BufferedReader读取文件内容
  70.  
    BufferedReader file=new BufferedReader(new InputStreamReader(new FileInputStream(FileNameroot),"UTF-8"));
  71.  
    //忽略读取CSV文件的标题行(第一行)
  72.  
    file.readLine();
  73.  
    //遍历读取文件中除第一行外的其他所有内容并存储在名为records的ArrayList中,每一行records中存储的对象为一个String数组
  74.  
    while((record=file.readLine())!=null){
  75.  
    String fields[]=record.split(",");
  76.  
    records.add(fields);
  77.  
    }
  78.  
    //关闭文件对象
  79.  
    file.close();
  80.  
    //将存储测试数据的List转换为一个Object的二维数组
  81.  
    Object[][] results=new Object[records.size()][];
  82.  
    //设置二位数组每行的值,每行是一个Object对象
  83.  
    for(int i=0;i<records.size();i++){
  84.  
    results[i]=records.get(i);
  85.  
    }
  86.  
    return results;
  87.  
    }
  88.  
    }

运行结果:

  1.  
    PASSED: testSearch("老九门", "演员", "赵丽颖")
  2.  
    PASSED: testSearch("X站警天启", "导演", "布莱恩·辛格")
  3.  
    PASSED: testSearch("诛仙青云志", "编剧", "张戬")
  4.  
     
  5.  
    ===============================================
  6.  
    Default test
  7.  
    Tests run: 3, Failures: 0, Skips: 0
  8.  
    ===============================================

测试数据的CSV文件内容:

搜索关键词1,搜索关键词2,搜索结果
老九门,演员,赵丽颖
X站警天启,导演,布莱恩·辛格
诛仙青云志,编剧,张戬

注意:使用写字板程序编辑CSV文件内容,在保存文件时要将文件存储为UTF-8编码格式。

数据驱动测试二:使用TestNG和CSV文件进行数据驱动的更多相关文章

  1. 使用TestNG 和 CSV文件进行数据驱动

    package testNGPractice; import java.io.BufferedReader; import java.io.FileInputStream; import java.i ...

  2. Jmeter自动化测试 数据驱动测试,将数据存入csv文件中来调用,或将数据存在DB中进行调用

    1. 将测试的用例名称,测试请求方式,测试链接,预置数据,断言等都放到excel中,然后转成csv格式,在用Jmeter带的csv数据配置文件导入 运行之前将线程组中配置,线程数设置为1,循环的次数设 ...

  3. Selenium+java - 使用csv文件做数据驱动

    前言 早期我们使用TestNG 来做数据驱动进行测试,测试数据是写在测试用例脚本中.这会使得测试脚本的维护工作量很大.因此我们可以将测试的数据和脚本分开. 而我们经常使用会使用csv文件来做为导出数据 ...

  4. 自动化测试框架selenium+java+TestNG——读取csv文件

    读取csv文件可以直接读取,也可以使用javacsv.jar,后者比较简单,这个也可以变相认为是对表格的处理,我们可以在表格中做好数据,存储成csv格式的文件,后续对xlsx表格的操作抽个时间再记录下 ...

  5. selenium java读取csv文件 (数据驱动)

    javacsv2.1 下载地址:http://sourceforge.net/projects/javacsv/files/ 该链接可以下载java读取csv文件的jar 包.下载之后解压找到对应的. ...

  6. (Python基础教程之十二)Python读写CSV文件

    Python基础教程 在SublimeEditor中配置Python环境 Python代码中添加注释 Python中的变量的使用 Python中的数据类型 Python中的关键字 Python字符串操 ...

  7. selenium自动化测试之【数据驱动测试】

    数据驱动测试是自动化测试的主流设计模式之一,相同的测试脚本使用不同的测试数据来执行,测试数据和测试行为进行了完全的分离,这样的测试脚本设计模式称为数据驱动.实施数据驱动测试的步骤:1.编写测试脚本,脚 ...

  8. 使用jmeter+ant进行接口自动化测试(数据驱动)之二:利用apache-ant执行测试用例并生成HTML格式测试报告

    在 使用jmeter+ant进行接口自动化测试(数据驱动)之一 介绍了如何使用csv文件来批量管理接口 本次接着介绍如何利用apache-ant执行测试用例并生成HTML格式测试报告 ①下载安装 ap ...

  9. 如何快速掌握DDT数据驱动测试?

    1.前言 (网盗概念^-^)相同的测试脚本使用不同的测试数据来执行,测试数据和测试行为完全分离, 这样的测试脚本设计模式称为数据驱动.(网盗结束)当我们测试某个网站的登录功能时,我们往往会使用不同的用 ...

随机推荐

  1. Temporary ASP.Net Files探究

    了解.net平台的兄弟都知道,.net也是采用动态编译的也就是说我们常说的build生成的dll只是中间代码而在web第一次请求的时候才是真正意义上的编译生成二进制代码这也就是为什么刚编译完第一次打开 ...

  2. Programming 2D Games 读书笔记(第六章)

      http://www.programming2dgames.com/chapter6.htm 示例一:Bounce 边界碰撞测试 velocity为移动的速度, 超过右边界,velocity.x为 ...

  3. oracle sql 高级

    1  时间   如果是从当前时间到前一个月的这个时候之间的记录总条数:   select count(1)   from uis_md_stcustom u  where firsttime betw ...

  4. 看opengl 写代码(4) 画一个圆

    opengl 编程指南 P30 以下代码 是 用 直线 连起来 画一个圆. // circle.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" ...

  5. Excel部署配置DCOM

    对 Excel进行编程,实际上就是通过 .Net Framework去调用 Excel的 COM组件,所有要在 Web环境下调用 COM组件的时候,都需要对其进行相应的配置. 很多朋友都反映在 Win ...

  6. 升级WINDOWS10后任务栏的图标老是闪动是怎么回事

    解决方法:1.进入设置→更新和安全→恢复2.找到高级启动,点击“立即重启3.重启后,进入第一个选择画面,点击“疑难解答”4.然后点击“高级选项”5.在其中选择“启动设置”6.这里给出了下次重启后的主要 ...

  7. MySql错误处理(三)- 错误处理的例子

    有几种错误处理的声明形式: § 如果任何错误(不是 NOT FOUND ) , 设置 l_error 为 1 后继续执行: DECLARE CONTINUE HANDLER FOR SQLEXCEPT ...

  8. weblogic 12c集群性能测试(与guava13以上版本兼容性问题仍然存在)

    测试了5000并发:

  9. maven的groupid和artifactId

    groupid和artifactId被统称为“坐标”是为了保证项目唯一性而提出的,如果你要把你项目弄到maven本地仓库去,你想要找到你的项目就必须根据这两个id去查找. groupId一般分为多个段 ...

  10. Wireshark的简介

    -------------------------------------------------------------- <Wireshark数据包分析实战>这本书其实还很不错,当时买 ...