聚焦于任务调度的测试平台pytestx

image1

设计理念

聚焦于任务调度,接口自动化80%本地编写,20%交由平台管理。

如果使用pytest做接口自动化,那么个人认为最好的编写工具是PyCharm,任何低代码测试平台都无法取代。当然不会代码,或者不使用pytest,那低代码测试平台,或者yaml,甚至excel写自动化用例,都是可以接受的。而在使用pytest这个特定场景里面,要做平台化,平台的功能就需要仔细斟酌。既然编写用例最好使用PyCharm,平台也就只能专注于用例编排和任务调度,即创建任务,关联用例,批量运行,以及定时,并行,通知等。

pytestx正是基于此理念设计的一款纯粹的任务调度平台。

image2

平台架构

image3

tep1.0.0的延续

tep1.0.0版本已经封版,在pytestx中对它进行了延续。

从pypi到git

tep是上传到pypi的,通过pip命令安装,使用tep startproject命令创建项目脚手架,代码结构分为项目代码和tep代码。改造后的tep只有项目代码,存放在:

https://gitee.com/dongfanger/tep-project.git

也就是说,在这个项目中,能看到整个tep全貌。之前的tep内核代码,比如fixtures自动寻找、内置fixture、环境变量等,全部迁移到了项目代码里面,尤其是conftest.py的文件内容。pip install tep顺带安装的依赖包,也整理到了requirements.txt,按照说明安装即可。

pytest-html替换allure

由重到轻,化繁为简,pytest-html能够满足数据+日志的报告需要,最新的V3.2.0版本的界面尚可。诚然allure漂亮,但安装Java、下载Allure、配置环境变量、安装pytest-allure、添加pytest hook还是相对麻烦。更重要的是,要支持平台在线查看报告,减少存储占用,pytest-html无疑是更好的选择。

下载脚手架

既可以从使用git clone下载代码,也可以从页面下载,就像spring.io那样:

image4

fastapi到django

之前的示例代码是调用的fastapi启动的应用,pytestx则将示例代码的接口换成了Django自身的mock接口。

teprunner的延续

pytestx的基础代码是从teprunner来的,对数据库设计、代码规范、项目结构做了优化。

image5

任务管理

image6

一、同步项目

同步项目,是把项目配置的Git仓库地址和分支,更新到本地沙箱中,项目之间完全隔离。

image7

并把用例落库:

image8

二、任务关联用例

创建任务,任务关联用例,就形成了新的用例集。

三、容器化运行

当前是假容器,未真正引入Docker,所谓容器,是指每次运行,都将用例拉取到新的目录,批量执行:

image9

四、生成报告

pytest命令生成html报告,存放于reports,借助于Django挂载页面,从页面点击,在线查看报告:

image10

体验平台

下载源码:https://github.com/dongfanger/pytestx

安装依赖:前端(npm install)后端(pip install -r requirements.txt)

启动服务:前端(npm run serve)后端(python manage.py runserver)

即可畅快体验。

学习交流

添加微信cekaigang,加入交流群,欢快讨论吧。

image11