如何优雅的用Python做接口自动化测试

时间:2022-04-26
本文章向大家介绍如何优雅的用Python做接口自动化测试,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

直接上硬货,请接收~

框架结构如下:

Test_Api_Project

|

|---base.py

|---base_api

||---register_api.py

||---send_sms_code_api.py

|---settings.py

|---test_case

||---test_register_api.py

|---utilities

||---conn_db.py

||---user.py

一、先说settings配置文件,与WEB端自动化类似,settings文件中存放整个项目的配置,如:被测项目域名、数据库地址、redis地址、APP版本号、请求头等。

二、base.py

该文件中主要是对测试url的处理、对常用的请求类型重新封装(如:GET、POST等)

三、conn_db.py连接数据库

user.py文件主要是对数据库中用户相关的一些操作

#-*-coding:utf-8-*-
importdb
defget_sms_captcha(mobile):
#获取短信验证码
sms_captcha=db.execute('selectcodefromsend_sms_codewheremobile=%sorderbyiddesc',params=(mobile))
returnsms_captcha['code']
defdelete_user(mobile):
#删除用户
db.execute('deletefromuserwheremobile=%s',params=(mobile))

四、下面以注册接口为例子

因注册时需要获取短信验证码,所以除了调用注册接口之外,还需要调用获取短信验证码皆苦,在base_api下新建register_api.py、send_sms_code_api.py,内容如下:

register_api.py

send_sms_code_api.py

对两个接口的url地址和所需要的入参都已经封装好了,接下来开始写case。

在test_case下新建test_register_api.py

下面是一个注册成功的例子

最后和WEB端类似,通过teardown()方法将新注册的用户在数据库中删除,防止该手机号下次执行case时候报手机号已被注册。

为了更好了验证通过接口注册的用户信息,也可以调用登录接口测试一下注册接口反参中的用户名是否可以正常登陆返回token。

五、如果调用接口的前提需要用户登录,那么就需要BaseApi类中build_base_param方法中的token有一个有效的值,否则调用接口时可能会提示token错误或者用户未登录等,这种情况下可以新建一个LoginBaseApi类,继承BaseApi,代码如下:

假设对登录接口已经进行了封装,入参为login_name和password

这时,底层类就有两个,一个是BaseApi()一个是LoginBaseApi(),需要登录的接口在封装入参时继承LoginBaseApi,不需要登录的接口继承BaseApi

不同项目接口的入参格式,反参格式可能会不同,仅供参考。