python自动化测试判断方法_Python接口自动化测试(1)

接口自动化测试三部曲: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

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

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

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)) !=0print("登录成功的测试用例通过")

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

2、关联

以登录-退出登录为例

importrequestsfrom dbtools importquery#登录

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"] == 200sql= "select * from t_user where username = '{}'".format(d["username"])assert len(query(sql)) !=0print("用户登录成功")#取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:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值