这绝对是我见过全网最新最细没有之一的python全栈接口自动化测试框架,脚本,实例,报告。(附带源码

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注软件测试)
img

正文

10.1到官方文档去了下requests.post()方法的定义,如下:

10.2源码:

10.3常用返回信息:

十一.post方法简单使用:

11.1带数据的post:

11.2带header的post:

11.3带json的post:

11.4带参数的post:

11.5普通文件上传:

11.6定制化文件上传:

11.7多文件上传:

11.8流式上传:

十二.Cookie&Session

十三.Cookie:

13.1获取cookie:

13.2发送Cookie

十四.Session

14.1保持会话同步

14.3删除已存在的会话信息,保存为No

十五.其他(认证&代理&超时设置)

15.1认证

15.1.1基本认证:

15.2数字认证:

15.3OAuth认证:

十六.代理

16.1方法一:proxy参数:

16.2方法二:设置环境变量:

16.3HTTP Basic Auth使用代理方法:http://user:password@host/

十七.证书验证

17.1SSL证书(HTTPS):

17.2客户端证书:

十八.超时配置

18.1利用timeout参数来配置最大请求时间:

18.2设置timeout=None,告诉请求永远等待响应,而不将请求作为超时值传递

十九错误异常:

19.1所有Requests显式抛出的异常都继承自:requests.exctptions.RequestException

19.2遇到网络问题(如:DNS查询失败,拒绝连接等)时,requests会抛出一个 ConnectionError 异常

19.3遇到罕见的无效HTTP响应时,Request则会抛出一个 HTTPError 异常

19.4若请求超时,则抛出一个 Timeout 异常

19.5若请求超过了最大的重写向次数,则会抛出一个 TooManyRedirects 异常

二十.unittest-单个用例管理:

20.1单个用例管理起来比较简单,参考如下图,单个用例一般多用在调试的时候:

20.2代码如下:

二十一.unittest-生成测试报告:

21.1下载HTMLTestRunner下载:

21.2mac下配置:

二十二.使用该模块生成报告:

22.1目录结构

22.2运行后生成报告如下:

22.3run_all_case.py代码如下:


一.前言

最近听闻很多的小伙伴都对博主私信说到不会写接口测试下让博主出一篇关于接口测试文章,让大家来学习,我这里也是不负众望花了大概·一个星期的时间写出了这边从关于python接口自动化测试文章供大家学习,同时博主写作也不易,希望各位看官能帮忙点个关注加转发和点赞,在这里谢过各位。废话也不多说了,接下来开始正文。

二.环境准备:

接口测试的方式有很多,比如可以用工具(jmeter,postman)之类,也可以自己写代码进行接口测试,工具的使用相对来说都比较简单,重点是要搞清楚项目接口的协议是什么,然后有针对性的进行选择,甚至当工具不太适合项目时需要自己进行开发。

在我们项目的初期,我们采用的是jmeter进行接口测试,当时觉得这个工具上手简单,团队成员学习成本低,并且接口测试的脚本稍微调整一下还可以用来做性能测试。

不过随着项目规模、团队人数的不断增长,渐渐的这个工具有适应不了当前项目的需求了,为此我们项目也重新开发了相关接口自动化的平台。但是,但是。。。可能是我让大家中毒太深,现在很多同学一提到接口测试关联到jmeter,为此,我深深感到不安。毕竟jmeter只是个工具,换个项目换个协议你是否还能玩转接口测试呢?session和cookie有什么区别?工具又是怎么实现的呢?

比如session如何保存,接口依赖如何处理,case如何管理及执行顺序,测试数据如何管理等等题,这个过程也有助于我们更加深刻的理解接口测试和http协议。

本文主要采用python语言,python中http协议接口相关的库有urllib,urllib2以及reqeusts库,这其中reqeusts库用来起来最方便,因此我也主要采用requests库来做http协议的接口测试。首先来看下需要哪些环境信息:

三、安装python

mac下自带安装了python,这个不多说了。

四、安装虚拟环境:

我们在一台机器上可以安装多个python版本,为了使每个版本的环境相互不受干扰,可以安装虚拟环境,安装方法如下:

1、安装virtualenv:pip install virtualenv

2、新建名为venv的虚拟环境:virtualenv venv

3、进入新环境:source venv/bin/activate

4、退出:deactivate

4.1安装requests库:

pip install requests

ps:用python做http协议的接口测试会用到这个库。

五、http测试工具:

一个使用 Python + Flask 编写的 HTTP 请求和响应服务,该服务主要用于测试 HTTP 库。后续测试我们都基于这个网站。

http://httpbin.org

六、在本地搭建httpbin:

考虑到测试时要不断访问 httpbin 网站,请求过多担心被拉到黑名单,我们自己在本志搭建一套httpbin服务。

1、安装:pip install gunicorn

2、安装:pip install httpbin

3、启动:gunicorn httpbin:app

至此,环境搭建已经完毕,可以开始玩了~

6.1requests.get()

环境搭建好后,接下来我们先来了解一下requests的一些简单使用,主要包括:

  1. requests常用请求方法使用,包括:get,post
  2. requests库中的Session、Cookie的使用
  3. 其它高级部分:认证、代理、证书验证、超时配置、错误异常处理等。

本节首先来了解一下requests库中如何发送get请求:

七、看下方法定义:

7.1到官方文档去了下requests.get()方法的定义,如下:

7.2点击右上角的【source】,看一下它的源码如下:

看到最后一行return,get方法最后是通过调用 requests.request 方法实现的,其实在其它的请求方法如post,put,head,delete等方法都是调用的request方法,然后把请求方法的类型传递给request方法第一个参数。

7.3HTTP协议是一个基于请求/响应模式的、无状态的,应用层协议。既然有请求,就有响应,来看下resquest中常用的响应信息:

八、get方法简单使用:

8.1不带参数的get:

-- coding:utf-8 --

#不带参数的get

import requests
import json

host = “http://httpbin.org/”
endpoint = “get”

url = ‘’.join([host,endpoint])
r = requests.get(url)
#response = r.json()

print type(r.text)
print (eval(r.text))

输出:

{
‘origin’: ‘183.14.133.88’,
‘headers’: {
‘Connection’: ‘close’,
‘Host’: ‘httpbin.org’,
‘Accept-Encoding’: ‘gzip,
deflate’,
‘Accept’: ‘/’,
‘User-Agent’: ‘python-requests/2.18.1’
},
‘args’: {

},
‘url’: ‘http: //httpbin.org/get’
}

8.2 带参数的get:

-- coding:utf-8 --

#带参数的get

import requests
import json

host = “http://httpbin.org/”
endpoint = “get”

url = ‘’.join([host,endpoint])
params = {“show_env”:“1”}
r = requests.get(url=url,params=params)

print r.url

输出:

http://httpbin.org/get?show_env=1
{
‘origin’: ‘183.14.133.88’,
‘headers’: {
‘X-Request-Id’: ‘ebe922b4-c463-4fe9-9faf-49748d682fd7’,
‘Accept-Encoding’: ‘gzip,
deflate’,
‘X-Forwarded-Port’: ‘80’,
‘Total-Route-Time’: ‘0’,
‘Connection’: ‘close’,
‘Connect-Time’: ‘0’,
‘Via’: ‘1.1vegur’,
‘X-Forwarded-For’: ‘183.14.133.88’,
‘Accept’: ‘/’,
‘User-Agent’: ‘python-requests/2.18.1’,
‘X-Request-Start’: ‘1504755961007’,
‘Host’: ‘httpbin.org’,
‘X-Forwarded-Proto’: ‘http’
},
‘args’: {
‘show_env’: ‘1’
},
‘url’: ‘http: //httpbin.org/get?show_env=1’
}

8.3带header的get:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “get”

url = ‘’.join([host,endpoint])
headers = {“User-Agent”:“test request headers”}

r = requests.get(url)
r = requests.get(url,headers=headers)
#response = r.json()
print (eval(r.text))[‘headers’][‘User-Agent’]

输出:

test request headers

8.4同时带参数和header:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “get”

url = ‘’.join([host,endpoint])
headers = {“User-Agent”:“test request headers”}
params = {“show_env”:“1”}

r = requests.get(url)
r = requests.get(url,headers=headers,params=params)

#response = r.json()
print (eval(r.text))[‘headers’][‘User-Agent’]
print r.url

输出:

test request headers
http://httpbin.org/get?show_env=1

九.requests.post()

9.1方法定义

9.1.1post方法简单使用

1、带数据的post

2、带header的post

3、带json的post

4、带参数的post

5、普通文件上传

6、定制化文件上传

7、多文件上传

十.方法定义:

10.1到官方文档去了下requests.post()方法的定义,如下:

10.2源码:

10.3常用返回信息:

十一.post方法简单使用:

11.1带数据的post:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”
url = ‘’.join([host,endpoint])
data = {‘key1’:‘value1’,‘key2’:‘value2’}

r = requests.post(url,data=data)
#response = r.json()
print (r.text)

输出:

{
“args”: {},
“data”: “”,
“files”: {},
“form”: {
“key1”: “value1”,
“key2”: “value2”
},
“headers”: {
“Accept”: “/”,
“Accept-Encoding”: “gzip, deflate”,
“Connection”: “close”,
“Content-Length”: “23”,
“Content-Type”: “application/x-www-form-urlencoded”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.18.1”
},
“json”: null,
“origin”: “183.14.133.88”,
“url”: “http://httpbin.org/post”
}

11.2带header的post:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])
headers = {“User-Agent”:“test request headers”}

r = requests.post(url)

r = requests.post(url,headers=headers)
#response = r.json()

输出:

{
“args”: {},
“data”: “”,
“files”: {},
“form”: {},
“headers”: {
“Accept”: “/”,
“Accept-Encoding”: “gzip, deflate”,
“Connection”: “close”,
“Content-Length”: “0”,
“Host”: “httpbin.org”,
“User-Agent”: “test request headers”
},
“json”: null,
“origin”: “183.14.133.88”,
“url”: “http://httpbin.org/post”
}

11.3带json的post:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])
data = {
“sites”: [
{ “name”:“test” , “url”:“www.test.com” },
{ “name”:“google” , “url”:“www.google.com” },
{ “name”:“weibo” , “url”:“www.weibo.com” }
]
}

r = requests.post(url,json=data)

r = requests.post(url,data=json.dumps(data))

response = r.json()

输出:

{
“args”: {},
“data”: “{“sites”: [{“url”: “www.test.com”, “name”: “test”}, {“url”: “www.google.com”, “name”: “google”}, {“url”: “www.weibo.com”, “name”: “weibo”}]}”,
“files”: {},
“form”: {},
“headers”: {
“Accept”: “/”,
“Accept-Encoding”: “gzip, deflate”,
“Connection”: “close”,
“Content-Length”: “140”,
“Content-Type”: “application/json”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.18.1”
},
“json”: {
“sites”: [
{
“name”: “test”,
“url”: “www.test.com”
},
{
“name”: “google”,
“url”: “www.google.com”
},
{
“name”: “weibo”,
“url”: “www.weibo.com”
}
]
},
“origin”: “183.14.133.88”,
“url”: “http://httpbin.org/post”
}

11.4带参数的post:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])
params = {‘key1’:‘params1’,‘key2’:‘params2’}

r = requests.post(url)

r = requests.post(url,params=params)
#response = r.json()
print (r.text)

输出:

{
“args”: {
“key1”: “params1”, 
“key2”: “params2”
}, 
“data”: “”, 
“files”: {}, 
“form”: {}, 
“headers”: {
“Accept”: “*/*”, 
“Accept-Encoding”: “gzip, deflate”, 
“Connection”: “close”, 
“Content-Length”: “0”, 
“Host”: “httpbin.org”, 
“User-Agent”: “python-requests/2.18.1”
}, 
“json”: null, 
“origin”: “183.14.133.88”, 
“url”: “http://httpbin.org/post?key2=params2&key1=params1”
}

11.5普通文件上传:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])
#普通上传
files = {
‘file’:open(‘test.txt’,‘rb’)
}

r = requests.post(url,files=files)
print (r.text)

输出:

{
“args”: {},
“data”: “”,
“files”: {
“file”: “hello world!\n”
},
“form”: {},
“headers”: {
“Accept”: “/”,
“Accept-Encoding”: “gzip, deflate”,
“Connection”: “close”,
“Content-Length”: “157”,
“Content-Type”: “multipart/form-data; boundary=392865f79bf6431f8a53c9d56c62571e”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.18.1”
},
“json”: null,
“origin”: “183.14.133.88”,
“url”: “http://httpbin.org/post”
}

11.6定制化文件上传:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])
#自定义文件名,文件类型、请求头
files = {
‘file’😦‘test.png’,open(‘test.png’,‘rb’),‘image/png’)
}

r = requests.post(url,files=files)
print (r.text)heman793

11.7多文件上传:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])
#多文件上传
files = [
(‘file1’,(‘test.txt’,open(‘test.txt’, ‘rb’))),
(‘file2’, (‘test.png’, open(‘test.png’, ‘rb’)))
]

r = requests.post(url,files=files)
print (r.text)

11.8流式上传:

-- coding:utf-8 --

import requests
import json

host = “http://httpbin.org/”
endpoint = “post”

url = ‘’.join([host,endpoint])

#流式上传
with open( ‘test.txt’ ) as f:
r = requests.post(url,data = f)

print (r.text)

输出:

{
“args”: {},
“data”: “hello world!\n”,
“files”: {},
“form”: {},
“headers”: {
“Accept”: “/”,
“Accept-Encoding”: “gzip, deflate”,
“Connection”: “close”,
“Content-Length”: “13”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.18.1”
},
“json”: null,
“origin”: “183.14.133.88”,
“url”: “http://httpbin.org/post”
}

十二.Cookie&Session

掌握了前面几节的的内容,就可以做一些简单的http协议接口的请求发送了,但是这些还不够。HTTP协议是一个无状态的应用层协议,也就是说前后两次请求是没有任何关系的,那如果我们测试的接口之前有相互依赖关系怎么办呢(比如我要在博客园发文章,是需要先登录的),这时我们就要用到cookie和session技术来保持客户端与服务器端连接的状态,这也就是本节要介绍的内容:

十三.Cookie:

13.1获取cookie:

-- coding:utf-8 --

#获取cookie
import requests
import json

url = “https://www.baidu.com/”
r = requests.get(url)

#将RequestsCookieJar转换成字典
c = requests.utils.dict_from_cookiejar(r.cookies)

print r.cookies
print c

for a in r.cookies:
print a.name,a.value

输出:

<RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]>
{‘BDORZ’: ‘27315’}
BDORZ 27315

13.2发送Cookie

-- coding:utf-8 --

#发送cookie到服务器
import requests
import json

host = “http://httpbin.org/”
endpoint = “cookies”

url = ‘’.join([host,endpoint])
#方法一:简单发送

cookies = {“aaa”:“bbb”}

r = requests.get(url,cookies=cookies)

print r.text

#方法二:复杂发送
s = requests.session()
c = requests.cookies.RequestsCookieJar()
c.set(‘c-name’,‘c-value’,path=‘/xxx/uuu’,domain=‘.test.com’)
s.cookies.update©

十四.Session

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
s.dict_from_cookiejar(r.cookies)

print r.cookies
print c

for a in r.cookies:
print a.name,a.value

输出:

<RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]>
{‘BDORZ’: ‘27315’}
BDORZ 27315

13.2发送Cookie

-- coding:utf-8 --

#发送cookie到服务器
import requests
import json

host = “http://httpbin.org/”
endpoint = “cookies”

url = ‘’.join([host,endpoint])
#方法一:简单发送

cookies = {“aaa”:“bbb”}

r = requests.get(url,cookies=cookies)

print r.text

#方法二:复杂发送
s = requests.session()
c = requests.cookies.RequestsCookieJar()
c.set(‘c-name’,‘c-value’,path=‘/xxx/uuu’,domain=‘.test.com’)
s.cookies.update©

十四.Session

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
[外链图片转存中…(img-Y1W1TzmX-1713252478355)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值