接口自动化测试三部曲:1、构造请求  2、判断结果  3、数据库查询

1、Python的第三方包:requests

简介:requests可以用来做接口测试、接口自动化测试、爬虫等

requests的环境搭建:管理员身份在cmd运行:pip3 install requests -i https://pypi.tuna.tsinghua.edu.cn/simple(pip和pip3是一样的东西,但是安装了loadrunner的接只能用pip3不能用pip了)

requests如何做http请求(请求接口)

1.1、导入包:import requests

1.2、构造请求:

如果是get请求:

#用url存放接口地址,注意要加引号
#获取首页轮播图接口地址
url = "http://118.24.105.78:2333/get_title_img"    #接口地址一定是一个字符串
h = {"Content-Type":"application/json"}
#使用requests去请求get类型的接口,最终的返回值就是接口返回的内容了
res = requests.get(url=url,headers=h)     #就相当于postman里边去填写接口地址
#获取返回值:res.text
print(res.text)

如果是post请求:

#post请求:用户登录接口 (依次从接口文档上填写请求地址、请求头、请求数据)
u = "http://118.24.105.78:2333/login"     #接口地址
h = {"Content-Type":"application/json"}    #请求头:字典格式
d = {"username":"liuyun1","password":"a12345678"}    #请求数据:json格式、字典

res = requests.post(url=u,headers=h,json=d)    #依次传参
print(res.text)

1.3、判断结果(以用户登录为例)

需要判断两个结果,先是接口状态码,后是返回值结果码

首先需要通过判断接口状态码看接口是否正确(如果接口都不正确了,就没有必要看返回结果了),然后看接口返回结果中的status是否=200,等于200标志着接口执行成功(返回的结果是字符串类型的字典格式,我们首先要将字符串真正的转换为字典,这里字符串转地址用魔鬼方法evar也不行,只能用.json()方法)

#判断结果(要判断两个:先接口状态码和后结果返回值)
#状态码:标志着接口的状态:预判接口是否有问题       res.status_code获取状态码
assert res.status_code == 200     #运行这步要把前面的print(res.text)删掉或者注释掉
#结果返回值(结果码)  接口返回的结果是放在res中了,但是它存放的是字符串类型,python中用res.json()将字符串转换为字典类型
assert res.json()["status"] == 200

在这里可能会遇到断言错误的问题,以注册为例

python接口自动化测试目录结构 python3接口自动化测试_json

遇到这种情况,就要排查,首先从日志中可以看出是判断结果码那块的断言报错,说明接口返回的结果码不等于200,我们可以先把接口返回的结果打印出来

python接口自动化测试目录结构 python3接口自动化测试_python接口自动化测试目录结构_02

1.4、查询数据库

使用pymysql查询数据库,由于前面已经封装好了pymysql的查询方法,要想查询数据库,首先就是将qurey方法导入进来:from dbtools import query(兄弟关系导方法)

#查询数据库
sql = "select * from t_user where username = '{}'".format(d["username"])
# print(sql)   #从这里就可以看见数据库语句拼接起来了
# r = query(sql)
assert len(query(sql)) != 0
print("登录成功的测试用例通过")

注意注意:由于我们是调用的query方法,封装query()方法时的url地址一定要和构造请求的url地址一致,否则会报错(接口地址要和数据库地址一致)

2、关联

以登录-退出登录为例

python接口自动化测试目录结构 python3接口自动化测试_接口自动化_03

 

import requests
from dbtools import query

#登录
u = "http://118.24.105.78:2333/login"
h = {"Content-Type":"application/json"}
d = {"username":"liuyun1","password":"a12345678"}

res = requests.post(url=u,headers=h,json=d)

assert res.status_code == 200
assert res.json()["status"] == 200

sql = "select * from t_user where username = '{}'".format(d["username"])
assert len(query(sql)) !=0
print("用户登录成功")

#取token值
token = res.json()["data"]["token"]

#关联用户退出
u = "http://118.24.105.78:2333/logout"
h = {"Content-Type":"application/json","token":token}

res = requests.get(url=u,headers=h)

assert res.status_code == 200
assert res.json()["status"] == 200
print("用户退出登录成功")

 

the end:

python接口自动化测试目录结构 python3接口自动化测试_接口自动化_04

 

python接口自动化测试目录结构 python3接口自动化测试_json_05