事情是这样式儿的,在之前的公司使用过接口自动化测试框架,但不是自己搭建的,所以想尝试着自己搭建一个接口自动化测试框架,在网上找了好多的资料,然后借鉴大佬们的经验,自己搞了一个。希望看到的小伙伴能有些帮助。我就很开心啦~
本人csdn博客:https://blog.csdn.net/Mojitoice/article/details/108992622
一、环境的搭建:python+HTMLTestRunnerCN+request+unittest+mock+db
这个我就不用多说了吧。这个网上有好多哒。
1、pycharm下载安装
windows的下载地址:Download PyCharm: Python IDE for Professional Developers by JetBrains
mac的下载地址:Download PyCharm: Python IDE for Professional Developers by JetBrains
2、python环境搭建
3、创建项目,给自己的框架起一个好听的名字~
如果不知道上面这三点的童鞋呢,可以参考这个:PyCharm 安装教程(Windows) | 菜鸟教程 ❤️❤️
二、框架的思路
一)大体思路
先说下大体的思路哈!
其实就是通过构建一个case的py文件。该文件的主要作用就是从excel中读取需要执行的case,然后生成相关的测试报告以及log,最终执行runAll.py就是执行所有的test_case.py文件。这是大体的思路。
二)细节介绍
细节一点的可以看这个图图~
可能微微有点乱哈,我来捋一捋:
testGetItemByProductId.py:就是我们自己构建出来的case相关的py文件,它主要是
1、通过readExcel.py内封装的方法,然后读取到excel中我们已经写好的case
2、通过excel中的标记来判断该case是否需要进行mock,如果需要mock的话就会调用configapiMock.py中的方法读取在config.ini配置好了的返回参数,进行mock
3、至于访问那个url呢?就是通过getUrlParams.py中的方法,拿到域名+excel中的api = 最终的url
4、那么要使用什么请求方法呢?需要拿到excel中写好的方法,然后调用configHttp.py中的对应方法就好啦,就可以拿到接口的返回值。
5、那如果需要查询数据库中的数据和返回结果对比应该咋搞呢?就是写好相应的sql,调用configDB.py方法,再拿到上面的返回值,进行断言就好了。
6、最后会通过调用log.py生成log,调用HTMLTestRunnerCN.py生成html的测试报告。
7、至于runAll.py是通过读取caselist.txt,看有哪些需要执行的py文件,然后执行。
我感觉只要能把具体需要什么了解了 框架自己而然就好搭啦~
其中还缺少了发送邮件,这个我还没有搞~哈哈哈哈哈 后续我会再补充进来哒!
三)excel表格的设计
1、get
2、post
有的时候会出现奇怪的报错。大家要注意excel的格式嗷!!
三、目录的架构
这是在framework下一层的文件夹和文件,后面会对其中每个文件夹里面的文件做具体介绍。
上面指的就是这些。
详细介绍一下嗷~
1、case文件夹:各个case的具体执行&断言等,其中的py文件是以test为开头,为了能够让unittest找到
test*.py其中主要包括:1)将从excel中读取到的内容进行参数化
2)setUp、tearDown、setUpClass、tearDownClass
3)具体case执行的方法,比如判断该用例是否需要进行mock,如果进行断言。
2、common文件夹:包括一些公共的方法
1)configapiMock.py:主要是提供了mock方法
2)configDB.py:主要是链接数据库并且执行sql
3)configHttp.py:get。post的方法,拿到请求的返回值
4)HTMLTestRunnerCN.py:生成html测试报告,使用方式是固定的。
5)log.py:生成log文件的方法
3、excel文件夹:主要是excel形式的case。
4、result文件夹:测试结果
1)logfile文件夹:主要是存储生成的log文件
2)report文件夹:主要是存储最终生成的html测试报告
5、testFile文件夹:其他测试文件
1)caselist.txt:是txt格式的,主要是用来表明需要运行那些py文件的case,不需要运行的前面放“#”
2)config.ini:主要是一些配置,db,HTTP,mock等。
3)getUrlParams.py:拼接域名的方法
4)readConfig.py:读取配置文件的方法封装
5)readExcel.py:读取excel的方法封装
6、getPath.py:获取该项目绝对路径的方法,好多地方涉及到读取文件中的内容,所以需要封装一个该方法,绝对路径不容易出问题。
7、runAll.py:从caselist.txt中读取符合要求的case,执行对应的py文件。
以上!!!希望看到的小伙伴能够受到一丢丢的启发,奏很开森啦~~❤️❤️ 后续还会更新各个文件的内容嗷。