设计理念「聚焦于任务调度」,接口自动化80%本地编写,20%交由平台管理。 如果使用pytest做接口自动化,那么个人认为最好的编写工具是PyCharm,任何低代码测试平台都无法取代。当然不会代码,或者不使用pytest,那低代码测试平台,或者yaml,甚至excel写自动化用例,都是可以接受的。而在使用pytest这个特定场景里面,要做平台化,平台的功能就需要仔细斟酌。既然编写用例最好使用PyCharm,平台也就只能专注于用例编排和任务调度,即创建任务,关联用例,批量运行,以及定时,并行,通知等。 「pytestx」正是基于此理念设计的一款纯粹的任务调度平台。 平台架构tep1.0.0的延续tep1.0.0版本已经封版,在pytestx中对它进行了延续。 「从pypi到git」 tep是上传到pypi的,通过pip命令安装,使用tep startproject命令创建项目脚手架,代码结构分为项目代码和tep代码。改造后的tep只有项目代码,存放在: https:///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那样: 「fastapi到django」 之前的示例代码是调用的fastapi启动的应用,pytestx则将示例代码的接口换成了Django自身的mock接口。 teprunner的延续pytestx的基础代码是从teprunner来的,对数据库设计、代码规范、项目结构做了优化。 任务管理「一、同步项目」 同步项目,是把项目配置的Git仓库地址和分支,更新到本地沙箱中,项目之间完全隔离。 并把用例落库: 「二、任务关联用例」 创建任务,任务关联用例,就形成了新的用例集。 「三、容器化运行」 当前是假容器,未真正引入Docker,所谓容器,是指每次运行,都将用例拉取到新的目录,批量执行: 四、生成报告 pytest命令生成html报告,存放于reports,借助于Django挂载页面,从页面点击,在线查看报告: 体验平台下载源码:https://github.com/dongfanger/pytestx 安装依赖:前端(npm install)后端(pip install -r requirements.txt) 启动服务:前端(npm run serve)后端(python manage.py runserver) 即可畅快体验。 学习交流 |
|