一、总体思路

以类为excel名,测试方法名为sheet名,建立excel文件。用jxl包里的方法去读取excel文件里的内容,然后用testng里的dataprovider,将数据传递给测试用例

二、代码实现

package com.jxl.excel;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List; import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException; public class ExcelData {
String classname;
String casename; /**
* @param classname
* excel文件名
* @param casename
* sheet名
*/
public ExcelData(String classname, String casename) {
this.classname = classname;
this.casename = casename;
} /**
* 获取excel文件的路径
*
* @return
*/
public String getPath() {
String path = "./testdata/" + classname + ".xls";
return path;
} /**
* 获取excel对应sheet中的数据
*
* @return
* @throws IOException
*/
public Object[][] getExcelData() {
File file = new File(getPath());
Workbook book = null;
Sheet sheet = null;
try {
book = Workbook.getWorkbook(file);
sheet = book.getSheet(casename);
} catch (Exception e) {
System.out.println(classname + ".xls文件读取失败");
}
int rows = sheet.getRows();
int cols = sheet.getColumns();
// 如果行数少于2,则没有必要再继续运行下去了,不会返回数据,直接退出程序
if (rows <= 1) {
System.out.println(classname + ".xls的" + casename + " sheet没有数据");
System.exit(0);
}
// 为了返回值是Object[][]类型,定义一个多行单列的二维数组
HashMap<String, String>[][] arrMap = new HashMap[rows - 1][1];
// 对数组中的所有元素初始化
for (int i = 0; i < rows - 1; i++) {
arrMap[i][0] = new HashMap<>();
}
// 定义一个list,存储第一行的标题,作为key用
// 需要注意的是,getCell(col,row),第一个纵坐标,第二个位横坐标
List<String> list = new ArrayList<String>();
for (int c = 0; c < cols; c++) {
list.add(sheet.getCell(c, 0).getContents());
}
// 以行为单位,将一行的数据,以键值对的形式,存进一个哈希表里
for (int r = 1; r < rows; r++) {
for (int c = 0; c < cols; c++) {
arrMap[r - 1][0].put(list.get(c), sheet.getCell(c, r).getContents());
}
}
book.close();
return arrMap;
}
}

 

testng的测试用例里,这样传递数据 

@DataProvider(name = "noNameTip")
public Object[][] noNameData() {
//excel的文件名和类名一致,为LoginTest,测试方法和sheet名一致,为testNoNameLogin
ExcelData e = new ExcelData("LoginTest", "testNoNameLogin");
return e.getExcelData();
} /**
* 测试登录没有输入用户名
*/
@Test(dataProvider = "noNameTip")
public void testNoNameLogin(HashMap<String, String> data) {
//按列名取值
String username = data.get("username");
String password = data.get("password");
loginPage.doLogin(username, password);
assertEquals(loginPage.getNoNameTip(), data.get("expectedNoNameTip"));
}

testng中当有多个方法,需要传递数据的时候,将method传递给dataprovider

@DataProvider(name = "loginData")
public Object[][] testData(Method method) {
ExcelData e = new ExcelData("LoginTest", method.getName());
return e.getExcelData();
} /**
* 测试登录没有输入用户名
*/
@Test(dataProvider = "loginData")
public void testNoNameLogin(HashMap<String, String> data) {
//按列名取值
String username = data.get("username");
String password = data.get("password");
loginPage.doLogin(username, password);
assertEquals(loginPage.getNoNameTip(), data.get("expectedNoNameTip"));
}

  

【框架】用excel管理测试用例需要的参数数据(二)的更多相关文章

  1. excel+requests管理测试用例接口自动化框架

    背景: 某项目有多个接口,之前使用的unittest框架来管理测试用例,将每个接口的用例封装成一个py文件,接口有数据或者字段变动后,需要去每个py文件中找出变动的接口测试用例,维护起来不方便,为了便 ...

  2. python_reques接口测试框架,Excel作为案例数据源

    一.框架菜单 1.1 common模块  1.2 其他 二.Excel接口测试案例编写 三.读取Excel测试封装(核心封装) excel_utils.py  读取Excel中的数据 import o ...

  3. Django框架 之 admin管理工具(组件使用)

    Django框架 之 admin管理工具(组件使用) 浏览目录 激活管理工具 使用管理工具 admin的定制 admin组件使用 Django 提供了基于 web 的管理工具. Django 自动管理 ...

  4. 分布式服务框架 Zookeeper -- 管理分布式环境中的数据

    转自:http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/index.html Zookeeper 分布式服务框架是 Apa ...

  5. 分布式服务框架 Zookeeper -- 管理分布式环境中的数据(转载)

    本文转载自:http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/ Zookeeper 分布式服务框架是 Apache Had ...

  6. 分布式服务框架 Zookeeper -- 管理分布式环境中的数据--转载

    原文:http://www.ibm.com/developerworks/cn/opensource/os-cn-zookeeper/ Zookeeper 分布式服务框架是 Apache Hadoop ...

  7. MUI框架-08-窗口管理-创建子页面

    MUI框架-08-窗口管理-创建子页面 之前写过这一篇,不知道为什么被删了,我就大概写了,抱歉 创建子页面是为了,页面切换时,外面的页面不动,让 MUI 写出来的页面更接近原生 app 官方文档:ht ...

  8. Spring 框架的事务管理

    1. Spring 框架的事务管理相关的类和API PlateformTransactionManager 接口: 平台事务管理器(真正管理事务的类); TransactionDefinition 接 ...

  9. 【Zookeeper】分布式服务框架 Zookeeper -- 管理分布式环境中的数据

    Zookeeper 分布式服务框架是 Apache Hadoop 的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务.状态同步服务.集群管理.分布式应用配置项的管理 ...

随机推荐

  1. c++ cmakelist 详解

    基本元素 首先cmaklist必须包括以下几个部分: #工程名 project(study_case) #cmake最低版本需求 cmake_minimum_required(VERSION 2.8. ...

  2. macOS下Hive 2.x的安装与配置

    1 简介 Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供简单的[SQL]查询功能,可以将SQL语句转换为MapReduce任务进行运行.其优点是学习成本 ...

  3. Inception Network

    1. 下图为一个Inception 模块,即将输入的图像通过多种过滤器或者池化操作后,全部再给拼起来形成新的图像. 2. Inception 网络就是讲将多个Inception模块连起来而已,如下图的 ...

  4. Codeforces Gym - 101102B - The Little Match Girl

    B. The Little Match Girl time limit per test 1 second memory limit per test 256 megabytes input stan ...

  5. vue-cli的webpack模板项目配置文件分析,配置信息详解

    比较不错的一篇详解文章: 地址:http://blog.csdn.net/hongchh/article/details/55113751#comments

  6. 生成pyd文件时提示“Unable to find vcvarsall.bat”的问题

    本文内容 Unable to find vcvarsall.bat的问题描述 问题分析 总结 一.问题描述 我们在windows下通过pip安装一些外部Python 模块(比如,pycrypto)时通 ...

  7. Getting started with Processing 第六章总结

    平移,旋转和缩放 前言 在这一章节中,平移.旋转和缩放都是以原点为基准的.并且是通过控制坐标系原点的位置来达到图元平移,旋转.缩放的视觉效果.作者在文中的原话是:另一种在屏幕上改变位置和移动物体的技术 ...

  8. 上传RNA-seq数据到NCBI GEO数据库

    SRA - NCBI example - NCBI 要发文章了,审稿时编辑肯定会要求你上传NGS测序数据. 一般数据都是放在集群,不可能放在个人电脑上,因为有的数据大的吓人(几个T). 所以我们就建一 ...

  9. 2018-02-16 GetSameTypeQuestion

    '目前存在的BUG '图片补丁存在多个URL Private Declare Function URLDownloadToFile Lib "urlmon" Alias " ...

  10. BFS+二进制状态压缩 hdu-1429

    好久没写搜索题了,就当练手吧. vis[][][1025]第三个维度用来维护不同key持有状态的访问情况. 对于只有钥匙没有对应门的位置,置为'.',避免不必要的状态分支. // // main.cp ...