天天看点

接口自动化测试之Requests模块

常见工具框架

Postman+newman+git/svn+jenkins

Jmeter+Ant+Git/svn+jenkins

一、既然我们有这些的接口测试工具,为什么要做接口做自动化?

1、敏捷开发,接口一般数量很大,团队实现接口测试,版本控制

2、功能太死板,有些接口完全无法实现(复杂的加密接口,签名接口等)

3、接口项目当中有多种不同协议的接口

4、排措,定位接口问题不方便,结合抓包实现

5、没有办法生成美观的报告

6、多接口串联,数驷库验证,日志监控

7、有些公司做web自动化+接口自动化

二、python+requests模块

requests第三方库,主要用于发送http请求,做接口自动化

pip install requests

三、requests全局观

请求

1、requests.get() 发送get请求

2、requests.post() 发送post请求

3、requests.delete() 发送delete请求

4、requests.put() 发送put请求

5、requests.request() 最核心的方法

响应 response 对象

import requests
rep = requests.request()
#返回字符串的数据
print(rep.text)
#返回字节格式的数据
print(rep.content)
#返回字 典格式的数据
print(rep.json())
#状态码
print(rep.status_code)
#返回状态信息
print(rep.reason)
#要返回cookie信息
print(rep.cookies) 
#返回编码格式
print(rep.encoding)
#返回响应头信息
print(rep.headers)           

复制

四、接口实战

请求方式: get post delete put

请求参数类型:键值对, JSON格式,文件格式。

pip install pytest

pyest默认规则:

1、py文件必须以_test开头或者test_结尾

2、类名必须以Test开头

3、测试用例心须以test_开头

注意:

get请求通过params传递参数

post请求通过json或data传参。他们的区别是什么?文件通过files传参

data
数据报文: dict字典类型.那么默认情况下请求头:  application/x-www-form-urlencoded。表示以form表单的方式传参。
格式: a=185&b=28&c=3
数据报文:str类型,默认情况下text/ptain(如果是dict格式需要转换成str格式)

json
不管dict还是str类型,默认都是application/json,格式:{"a": 1, "b": 2}           

复制

json.dumps(data) 序列化 把dict格式的数据转换str格式

json.lads(ata) 反序列化 把str格式的数据转换成dict格式

总结:

data只能传简单的只有键值对的dict或者是str格式。json一般只能传dict格式(简单和嵌套都可以)

cookie鉴权 网页的接口基本上都要做cookie鉴权,这种不常用

通过session实现cookie鉴权,这种很常用

五、接口自动化框架封装

接口自动化框架封装的第一步,统一请求方式

requests.request()

session 会话

session = request.session()    # 全局变量
def  get_session(self):
   session = request.session()
   return session           

复制