接口自动化框架(java)--3.get,delete请求,Excel管理多种请求类型

这套框架的报告是自己封装的

每种请求类型放入不同的sheet中,就可以避免新建太多的excel去做数据驱动。

XSSFSheet类提供了一个读取sheet的方法,getSheetAt(int),通过下标去访问想要的sheet

1.Excel,添加两个sheet页改名成get , delete,代表这两种类型的接口

2. 在用例的dataProvider中将这两个sheet作两个方法分别读取。再传入对应的test中

 1 package com.qa.tests;
 2
 3 import com.alibaba.fastjson.JSON;
 4 import com.qa.base.TestBase;
 5 import com.qa.Parameters.postParameters;
 6 import com.qa.restclient.RestClient;
 7 import com.qa.util.TestUtil;
 8 import org.apache.http.client.methods.CloseableHttpResponse;
 9 import org.testng.Assert;
10 import org.testng.annotations.BeforeClass;
11 import org.testng.annotations.DataProvider;
12 import org.testng.annotations.Test;
13
14 import java.io.IOException;
15 import java.util.HashMap;
16
17 import static com.qa.util.TestUtil.dtt;
18
19 public class testCase1 extends TestBase {
20     TestBase testBase;
21     RestClient restClient;
22     CloseableHttpResponse closeableHttpResponse;
23     //host根url
24     String host;
25     //Excel路径
26     String testCaseExcel;
27     //header
28     HashMap<String ,String> postHeader = new HashMap<String, String>();
29     @BeforeClass
30     public void setUp(){
31         testBase = new TestBase();
32         restClient = new RestClient();
33         postHeader.put("Content-Type","application/json");
34         //载入配置文件,接口endpoint
35         host = prop.getProperty("Host");
36         //载入配置文件,post接口参数
37         testCaseExcel=prop.getProperty("testCase1data");
38
39     }
40
41     @DataProvider(name = "postData")
42     public Object[][] post() throws IOException {
43         //post类型接口
44         return dtt(testCaseExcel,0);
45
46     }
47
48     @DataProvider(name = "get")
49     public Object[][] get() throws IOException{
50         //get类型接口
51         return dtt(testCaseExcel,1);
52     }
53
54     @DataProvider(name = "delete")
55     public Object[][] delete() throws IOException{
56         //delete类型接口
57         return dtt(testCaseExcel,2);
58     }
59     @Test(dataProvider = "postData")
60     public void login(String loginUrl,String username, String passWord) throws Exception {
61         //使用构造函数将传入的用户名密码初始化成登录请求参数
62         postParameters loginParameters = new postParameters(username,passWord);
63         //将登录请求对象序列化成json对象
64         String userJsonString = JSON.toJSONString(loginParameters);
65         //发送登录请求
66         closeableHttpResponse = restClient.postApi(host+loginUrl,userJsonString,postHeader);
67         //从返回结果中获取状态码
68         int statusCode = TestUtil.getStatusCode(closeableHttpResponse);
69         Assert.assertEquals(statusCode,200);
70
71     }
72
73     @Test(dataProvider = "get")
74     public void getApi(String url) throws Exception{
75         closeableHttpResponse = restClient.getApi(host+ url);
76         int statusCode = TestUtil.getStatusCode(closeableHttpResponse);
77         Assert.assertEquals(statusCode,200);
78     }
79
80     @Test(dataProvider = "delete")
81     public void deleteApi(String url) throws Exception{
82         System.out.println(url);
83         closeableHttpResponse = restClient.deleteApi(url);
84         int statusCode = TestUtil.getStatusCode(closeableHttpResponse);
85         Assert.assertEquals(statusCode,204);
86     }
87
88     @BeforeClass
89     public void endTest(){
90         System.out.print("测试结束");
91     }
92
93 }

原文地址https://blog.csdn.net/qq_34693151/article/details/81875790

原文地址:https://www.cnblogs.com/111testing/p/10624742.html

时间: 2024-11-07 20:17:55

接口自动化框架(java)--3.get,delete请求,Excel管理多种请求类型的相关文章

接口自动化框架(java)--4.接口Token传递

这套框架的报告是自己封装的 一般token会在登录接口返回结果中呈现,从代码层面获取token的方式有很多种,我是使用jsonpath这个json路径语言去匹配token所在路径的key值 1 package com.qa.tests; 2 3 4 import com.alibaba.fastjson.JSON; 5 import com.qa.base.TestBase; 6 import com.qa.Parameters.postParameters; 7 import com.qa.r

接口自动化框架(java)--5.通过testng.xml生成extentreport测试报告

这套框架的报告是自己封装的 由于之前已经通过Extentreport插件实现了Testng的IReport接口,所以在testng.xml中使用listener标签并指向实现IReport接口的那个类就可以替换原始的testngreport testng配置如下: 单suite,单test test name 指向你写的testCase,methods放入需要执行的方法 1 <?xml version="1.0" encoding="UTF-8"?> 2

python3+request接口自动化框架

首次书写博客,记录下写的自动化接口框架,框架比较简单,哈哈哈,算是记录下历程把!~~~ 一.本次框架由python3.6 书写 1.准备代码环境,下载python3.6    下载地址:https://www.python.org/downloads 2.下载pycharm 软件. 二.开始创建python接口自动化框架: 1.这是我创建的框架中的各个文件夹,分别有config  配置文件夹.fengzhuang   将接口用get post  两种传输方式进行封装并自动来区分执行. 2.log

接口自动化框架好文

接口自动化框架好文 2017-04-13 API 自动化测试框架分享 接口测试的一些感悟 HTTP API自动化测试从手工到平台的演变

python接口自动化框架

基于 python 的接口测试框架 接口测试 · jphtmt · 于 5 月前发布 · 最后由 jphtmt 于 4 月前回复 · 3553 次阅读 项目背景 公司内部的软件采用B/S架构,管理实验室数据,实现数据的存储和分析统计.大部分是数据的增删改查,由于还在开发阶段,所以UI界面的变化非常快,之前尝试过用python+selenium进行UI自动化测试,后来发现今天刚写好的脚本第二天前端就改了页面,又得重新去定位元素什么的,消耗大量的精力与时间维护自动化脚本.针对此种情况,对接口测试较为

python写接口自动化框架

代码如下: 1 #!/usr/bin/env python 2 # -*- coding: utf_8 -*- 3 # 获取测试用例文件excel 4 5 import xlrd 6 import json 7 8 9 class CreateExcel: 10 def __init__(self): 11 pass 12 13 @classmethod 14 def open_excel(cls): 15 path = "testcase.xls" 16 workbook = xlr

pytest+requests+excel 接口自动化框架

一.项目框架如图: 1.common :这个包都是一些公共的方法,如:手机号加解密,get/post接口请求的方法封装,接口鉴权,发邮件,读写excel文件方法等等 2.result:存放每次运行的log和测试报告 3.testcase:这个包放test开头的测试用例 4.testFile:这个包放接口上传的图片(如注册需要上传头像),excel管理的接口参数 5.caselist.txt:需要运行的用例 6.config.ini :放一些配置信息,如发邮件的房间账户,接口需要使用的固定参数和版

python学习笔记(接口自动化框架)

之前是利用python自带的unittest测试框架 这次自己设计一个 之后再一点点往里面加功能 (ps:当然这个框架真的是很简单..很简单...很简单...) excel文件格式: 1 #!/usr/bin/env python 2 # -*- coding: utf_8 -*- 3 4 import xlrd 5 import json 6 7 8 class CreateExcel: 9 def __init__(self): 10 pass 11 12 @classmethod 13 d

Postman+Newman+Jenkins接口自动化框架

postman做接口测试简单易用很容易上手,但是接口越来越多,每次手动点击runner进行测试不灵活,最近就研究了下newman,利用newman实现接口的自动化测试,但是每次需要命令行操作也不方便,就想着利用Jenkins做真正的自动化测试,刚好部门有现成的Jenkins环境就用了起来,目前已经实现了接口的自动化测试.postman导出的json文件直接上传git,Jenkinsjob配置git路径,每次只要点击下job就可以进行接口测试或者有新的接口更新也会实现自动化测试,同时可以发送邮件告