接口测试 react+unittest+flask 接口自动化测试平台

目录

[1 前言](#1 前言)

[2 框架](#2 框架)

[2-1 框架简介](#2-1 框架简介)

[2-2 框架介绍](#2-2 框架介绍)

[2-3 框架结构](#2-3 框架结构)

[3 平台](#3 平台)

[3-1 平台组件图](#3-1 平台组件图)

[1 新建用例](#1 新建用例)

[2 生成测试任务](#2 生成测试任务)

[3 执行并查看测试报告](#3 执行并查看测试报告)

[3-2 用例管理](#3-2 用例管理)

[3-2-1 用例设计](#3-2-1 用例设计)

[3-3 任务管理](#3-3 任务管理)

[3-3-1 创建任务](#3-3-1 创建任务)

[3-3-2 执行任务](#3-3-2 执行任务)

[3-3-3 测试报告](#3-3-3 测试报告)

[3-3-4 邮件通知](#3-3-4 邮件通知)


1 前言

构建一个基于React、Unittest和Flask的接口自动化测试平台是一个很好的选择。React是一个流行的JavaScript库,用于构建用户界面,而Unittest是Python的一个单元测试框架,用于编写和执行测试用例。Flask是一个轻量级的Python Web框架,可以用于构建接口。

接口自动化测试的工具很多,比如 soapUI,postman,jmeter 等等,但是这些通用的工具的可扩展性以及跟项目的契合度上并不是十分合适。

单有框架,还不足以让接口自动化更简化,自动化测试需要大量编码维护工作,为了改善这些问题,解放重复的劳动力,所以将其做成平台型的,可以让不懂技术的人都能使用,同时也让接口用例更加简单明了,易维护。

简单示范下使用流程。

2 框架

2-1 框架简介

前端 reactjs 语言实现,后台由 flask 提供 restful 接口,基于 python unittest 测试框架,一键生成测试脚本,可视化的维护测试数据。

2-2 框架介绍

1-基于 Python+unittest 测试框架

2-二次封装了 urlib 库,对于 cookie 及存在业务流程依赖的数据,做了保存处理,可连贯测试业务流程及不同的请求场景。

3-支持多项目、不同环境数据参数的扩展。

4-支持返回值的 code、指定字段校验,提升测试准确性。

5-定时任务、即时任务执行,满足稳定接口自动化业务测试及临时接口的调试测试。

6-在线报告展示以及 Email 自动发送报告

2-3 框架结构

结构图:

分为前后台两套代码:

3 平台

3-1 平台组件图

1 新建用例

2 生成测试任务

3 执行并查看测试报告

3-2 用例管理

在线编写自动化测试,让大家都能够参与测试

自动化用例编辑可视化,使自动化过程更加简单明了

针对需要连续流程获取的参数值,提供 json 类型的数据解析,获取指定的值。

3-2-1 用例设计

平台用例执行流程图

3-3 任务管理

3-3-1 创建任务

根据测试用例,生成指定域名或测试机器 ip 的测试任务。

3-3-2 执行任务

定时任务是在每日的指定时间点自动执行指定的测试任务集。

每次执行(包括手动执行和定时任务)之后,都会生成一份测试报告,发送给指定人。

3-3-3 测试报告

可按测试时间及给定文件名,生成对应时间的 html 可视化报告,报告内容包含测试耗时,测试执行用例总数,执行成功、失败、出错用例数统计;还有单个用例的执行情况 (ID,用例名称,服务端返回值,运行结果等)

3-3-4 邮件通知

暂时发送人和接收人是写在代码里的,看需求再看是否需要做成前端配置,邮件会直接显示报告结果,也可以查看附件详细内容。

作为一位过来人也是希望大家少走一些弯路

在这里我给大家分享一些自动化测试前进之路的必须品,希望能对你带来帮助。

(WEB自动化测试、app自动化测试、接口自动化测试、持续集成、自动化测试开发、大厂面试真题、简历模板等等)

相信能使你更好的进步!

点击下方小卡片

相关推荐
共享家95273 小时前
搭建 AI 聊天机器人:”我的人生我做主“
前端·javascript·css·python·pycharm·html·状态模式
小白郭莫搞科技4 小时前
鸿蒙跨端框架Flutter学习:CustomTween自定义Tween详解
学习·flutter·harmonyos
Halo_tjn5 小时前
基于封装的专项 知识点
java·前端·python·算法
阳光九叶草LXGZXJ5 小时前
达梦数据库-学习-47-DmDrs控制台命令(LSN、启停、装载)
linux·运维·数据库·sql·学习
lightningyang5 小时前
DVWA 在 openEuler 系统的安装部署
docker·渗透测试·openeuler·dvwa·天枢一体化虚拟仿真靶场平台
摘星编程5 小时前
OpenHarmony环境下React Native:自定义useTruncate文本截断
javascript·react native·react.js
A9better6 小时前
嵌入式开发学习日志53——互斥量
stm32·嵌入式硬件·学习
进阶小白猿7 小时前
Java技术八股学习Day30
java·开发语言·学习
近津薪荼7 小时前
优选算法——双指针6(单调性)
c++·学习·算法
m0_748229997 小时前
Vue2 vs Vue3:核心差异全解析
前端·javascript·vue.js