承接上篇

改变我们的测试驱动方式,灵活设置测试用例。

数据驱动测试

数据驱动测试的核心是:

测试数据与测试脚本分离,实现测试脚本参数化,

提高测试脚本的可重用性。在自动化功能测试中如果灵活使用数据源与测试脚本,

便能轻松创建与运行成百上千个测试用例。自动化测试框架必须要有与电子表格、文本文件、数据库集成的能力。

首先小伙伴们就会问,你要先解析Excel吧,那你肯定得给我上代码,是的,必须的上代码。

  1. package com.testapi.until;
  2.  
  3. import java.io.FileInputStream;
  4. import java.io.FileNotFoundException;
  5. import java.io.IOException;
  6. import org.apache.poi.xssf.usermodel.XSSFCell;
  7. import org.apache.poi.xssf.usermodel.XSSFRow;
  8. import org.apache.poi.xssf.usermodel.XSSFSheet;
  9. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  10. public class ExcelUtils {
  11. private static XSSFSheet ExcelWSheet;
  12. private static XSSFWorkbook ExcelWBook;
  13. private static XSSFCell Cell;
  14. private static XSSFRow Row;
  15. public static Object[][] getTableArray(String FilePath, String SheetName) throws Exception {
  16. String[][]tabArray = null;
  17. try {
  18. FileInputStream ExcelFile = new FileInputStream(FilePath);
  19. ExcelWBook = new XSSFWorkbook(ExcelFile);
  20. ExcelWSheet = ExcelWBook.getSheet(SheetName);
  21. int startRow = 1;
  22. int startCol = 1;
  23. int ci,cj = 0;
  24. int totalRows = ExcelWSheet.getLastRowNum();
  25. int totalCols = 2;
  26. tabArray=new String[totalRows][6];
  27. ci=0;
  28. cj=0;
  29. int cm = 0;int cl = 0;int ch = 0;
  30. for (int i=startRow;i<=totalRows;i++, ci++) {
  31. tabArray[ci][0]=getCellData(i,2);
  32. tabArray[ci][1]=getCellData(i,3);
  33. tabArray[ci][2]=getCellData(i,4);
  34. tabArray[ci][3]=getCellData(i,5);
  35. tabArray[ci][4]=getCellData(i,6);
  36. }
  37. }
  38. catch (FileNotFoundException e){
  39. System.out.println("Could not read the Excel sheet");
  40. e.printStackTrace();
  41. }
  42. catch (IOException e){
  43. System.out.println("Could not read the Excel sheet");
  44. e.printStackTrace();
  45. }
  46. return(tabArray);
  47. }
  48. public static String getCellData(int RowNum, int ColNum) throws Exception {
  49. try{
  50. Cell = ExcelWSheet.getRow(RowNum).getCell(ColNum);
  51. int dataType = Cell.getCellType();
  52. if (dataType == 3) {
  53. return "";
  54. }
  55. else{
  56. String CellData = Cell.getStringCellValue();
  57. return CellData;
  58. }
  59. }
  60. catch (Exception e){
  61. // System.out.println(e.getMessage());
  62. throw (e);
  63. }
  64. }
  65. public static void main(String[] args) throws Exception {
  66. ExcelUtils excelUtils=new ExcelUtils();
  67. Object[][] m = excelUtils.getTableArray("C:\\Users\\Administrator\\eclipse-workspace\\ApiTest\\casedata\\casedata.xlsx","Sheet1");
  68.  
  69. }
  70. }

这就是我们的代码,那么小伙伴迫不及待了,你快来告诉我,

你的测试用例怎么组织的,好的 ,热腾腾的钙素你,我给你的就是代码,就是源码。源码如下

  1. package com.testapi.casev;
  2. import static org.testng.Assert.assertEquals;
  3.  
  4. import org.testng.annotations.AfterTest;
  5. import org.testng.annotations.BeforeTest;
  6. import org.testng.annotations.DataProvider;
  7. import org.testng.annotations.Listeners;
  8. import org.testng.annotations.Test;
  9.  
  10. import com.testapi.until.ExcelUtils;
  11. import com.testapi.until.Getcode;
  12. import com.testapi.until.Makejson;
  13. import com.testapi.until.ParseJson;
  14. import com.testapi.until.*;
  15. @Listeners({ZTestReport.class})
  16. public class Testapi {
  17. @DataProvider(name="DP1")
  18. public Object[][] createData() throws Exception {
  19. ExcelUtils excelUtils=new ExcelUtils();
  20. Object[][] m = ExcelUtils.getTableArray("casedata\\casedata.xlsx","Sheet1");
  21. return m;
  22. }
  23. @Test(dataProvider="DP1")
  24. public void f(String url,String path,String meth,String map,String jsonid,String qiwang) {
  25. String param1 = Makejson.makejson(map);
  26. Getcode getcode=new Getcode();
  27. url=url+path;
  28. String resulst=getcode.getHttpResponse(param1, url,meth.toUpperCase());
  29. String bnei=ParseJson.Json(resulst);
  30. assertEquals(bnei,qiwang);
  31. }
  32. @BeforeTest
  33. public void beforeTest() {
  34. }
  35. @AfterTest
  36. public void afterTest() {
  37. }
  38.  
  39. }

这就是源码,这就是源码,

那么,你能让我看看你的Excel怎么写的吗,可以

目前支持的断言是断言code的字段,其实还可以丰富,接下来会优化这方面。

运行testng测试

控制台输出

最后的测试报告

测试报告,要感谢飞总的ztest

开源代码   github  传送门   喜欢的可以star。

作者寄语:

前进的道路我们充满着迷茫,

前进的每一步我们都会有收获。

路在脚下,我们决定不了我们的出身,但是我们可以努力改变我们未来。

告别昨天失败的自己,努力拼搏今天,成就美好明天

java 接口测试,使用excel做数据驱动(二)的更多相关文章

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

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

  2. java结合testng,利用excel做数据源的数据驱动实例

    数据驱动部分,是自动化测试常用部分,也是参数化设计的重要环节,前面分享了,mysql.yaml做数据源,那么再来分享下excel做数据驱动 思路: 先用POI读取excel.解析读取数据,返回list ...

  3. 接口测试 java+httpclient+testng+excel

    最近项目不忙,研究了下java实现接口自动化,借助testng+excel实现数据驱动 目前只用post方式测试,返回结果列没有通过列名去找 另外,请求参数是转义之后的,接口之间的依赖也是个问题,批量 ...

  4. java读取大容量excel之二(空格、空值问题)

    最近在项目中发现,对于Excel2007(底层根本是xml) ,使用<java读取大容量excel之一>中的方式读取,若待读取的excel2007文件中某一列是空值,(注意,所谓的空值是什 ...

  5. Testng之使用@DataProvider注解做数据驱动【转】

    原文:http://www.jianshu.com/p/8e333a0ec42a 前两天学了一下@DataProvider,今天有时间总结一下.testng很强大,提供了很多注解,其中利用@DataP ...

  6. 12、借助Jacob实现Java打印报表(Excel、Word)

    12.使用Jacob来处理文档 Word或Excel程序是以一种COM组件形式存在的.如果能够在Java中调用相应组件,便能使用它的方法来获取文档中的文本信息.Jacob是一个JAVA到微软的COM接 ...

  7. [Java聊天室server]实战之二 监听类

    前言 学习不论什么一个稍有难度的技术,要对其有充分理性的分析,之后果断做出决定---->也就是人们常说的"多谋善断":本系列尽管涉及的是socket相关的知识,但学习之前,更 ...

  8. Java JDBC的基础知识(二)

    在我的上一篇Java JDBC的基础知识(一)中,最后演示的代码在关闭资源的时候,仅仅用了try/catch语句,这里是有很大的隐患的.在程序创建连接之后,如果不进行关闭,会消耗更多的资源.创建连接之 ...

  9. 20172301 《Java软件结构与数据结构》实验二报告

    20172301 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...

随机推荐

  1. THE MATRIX PROBLEM

    THE MATRIX PROBLEM Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...

  2. scanf和cin性能的比较

    我的实验机器配置是: 处理器:Intel(R) Core(TM) i3-7100U CPU @ 2.40GHz 2.40GHz 随机访问存储器:4.00GB 操作系统:Windows10 集成开发环境 ...

  3. 引入CSS的方式有哪些?link和@import的有何区别应如何选择【转载】

    看到淘宝网页中这样写使用的是import,而很多网站都是使用link,当然还有一些页面比较简单,流量很大的网站,是直接将CSS写在html代码中的?他们有什么区别?CSS用import还是link好? ...

  4. C#之可选参数和命名参数

    设计方法的参数是,可以将部分参数和全部参数分配默认值,然后调用这些方法的时候可以选择不提供部分实参,使用参数定义的默认值,另外,还可以在调用方法的时候通过指定参数名称来传递实参. 例如: public ...

  5. windows下 sbulime text 安装less2css踩的几个坑

    sublime 就不介绍了,less2css 是一个安装在sublime上的插件,可以让你书写less后自动生成css文件,而且还可以提示less的语法错误. 搜了一下相关的教程,很多都写的不全,按照 ...

  6. python添加自定义cookies

    import cookielib,urllib2 class AddCookieHandler(urllib2.BaseHandler): def __init__(self,cookieValue) ...

  7. 团队工作准则&贡献分配规则

    团队工作准则&贡献分配规则 NewTeam 2017/10/24 v1.0 工作准则及内容 全体成员 所有成员在接受任务时应结合自身情况考虑,如果认为任务内容或时间有不合理之处应当立即提出修改 ...

  8. Velocity(1)——初步入门

    1.变量 (1)变量的定义: 1 #set($name = "hello") 说明:velocity中变量是弱类型的. 2 3 当使用#set 指令时,括在双引号中的字面字符串将解 ...

  9. Python的路径引用

    1.以HOME目录为准,进行跳转 sys.path.append(os.path.dirname(__file__) + os.sep + '../') from config import swor ...

  10. IIS解决CPU和内存占用率过高的问题

    发现进程中的w3wp占用率过高. 经过查询,发现如下: w3wp.exe是在IIS(因特网信息服务器)与应用程序池相关联的一个进程,如果你有多个应用程序池,就会有对应的多个w3wp.exe的进程实例运 ...