接口自动化框架(Pytest+request+Allure)

前言:

接口自动化是指模拟程序接口层面的自动化,由于接口不易变更,维护成本更小,所以深受各大公司的喜爱。
接口自动化包含2个部分,功能性的接口自动化测试和并发接口自动化测试。
本次文章着重介绍第一种,功能性的接口自动化框架。


一、简单介绍

环境:Mac、Python 3,Pytest,Allure,Request
流程:读取Yaml测试数据-生成测试用例-执行测试用例-生成Allure报告
模块类的设计说明:

Request.py 封装request方法,可以支持多协议扩展(get\post\put)
Config.py 读取配置文件,包括:不同环境的配置,email相关配置
Log.py 封装记录log方法,分为:debug、info、warning、error、critical
Email.py 封装smtplib方法,运行结果发送邮件通知
Assert.py 封装assert方法
run.py 核心代码。定义并执行用例集,生成报告

Yaml测试数据格式如下:

---
Basic:dec: "基础设置"parameters:-url: /settings/basic.jsondata: slug=da1677475c27header: {"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko)\Chrome/67.0.3396.99 Safari/537.36","Content-Type": "keep-alive"}

二、代码结构与框架流程

1、代码结构见下图:

2、框架流程见下图:

三、详细功能和使用说明

1、定义配置文件config.ini

该文件中区分测试环境[private_debug]和正式环境[online_release]分别定义相关配置项,[mail]部分为邮件相关配置项

# http接口测试框架配置信息[private_debug]
# debug测试服务
tester = your name
environment = debug
versionCode = your version
host = www.jianshu.com
loginHost = /Login
loginInfo = email=wang@user.com&password=123456[online_release]
# release正式服务
tester = your name
environment = release
versionCode = v1.0
host = www.jianshu.com
loginHost = /Login
loginInfo = email=wang@user.com&password=123456[mail]
#发送邮件信息
smtpserver = smtp.163.com
sender = test1@163.com
receiver = wang@user.com
username = wang@user.com
password = 123456

2、读取yaml测试数据后封装

yaml测试数据例子见第一节,一条接口可定义多条case数据,get_parameter为已封装好的读取yaml数据方法,循环读取后将多条case数据存在list中。

class Basic:params = get_parameter('Basic')url = []data = []header = []for i in range(0, len(params)):url.append(params[i]['url'])data.append(params[i]['data'])header.append(params[i]['header'])

3、编写用例

class TestBasic:@pytest.allure.feature('Home')@allure.severity('blocker')@allure.story('Basic')def test_basic_01(self, action):"""用例描述:未登陆状态下查看基础设置"""conf = Config()data = Basic()test = Assert.Assertions()request = Request.Request(action)host = conf.host_debugreq_url = 'http://' + hosturls = data.urlparams = data.dataheaders = data.headerapi_url = req_url + urls[0]response = request.get_request(api_url, params[0], headers[0])assert test.assert_code(response['code'], 401)assert test.assert_body(response['body'], 'error', u'继续操作前请注册或者登录.')assert test.assert_time(response['time_consuming'], 400)Consts.RESULT_LIST.append('True')

4、运行整个框架run.py

if __name__ == '__main__':# 定义测试集allure_list = '--allure_features=Home,Personal'args = ['-s', '-q', '--alluredir', xml_report_path, allure_list]log.info('执行用例集为:%s' % allure_list)self_args = sys.argv[1:]pytest.main(args)cmd = 'allure generate %s -o %s' % (xml_report_path, html_report_path)try:shell.invoke(cmd)except:log.error('执行用例失败,请检查环境配置')raisetry:mail = Email.SendMail()mail.sendMail()except:log.error('发送邮件失败,请检查邮件配置')raise

5、err.log实例

[ERROR 2018-08-24 09:55:37]Response body != expected_msg, expected_msg is {"error":"继续操作前请注册或者登录9."}, body is {"error":"继续操作前请注册或者登录."}
[ERROR 2018-08-24 10:00:11]Response time > expected_time, expected_time is 400, time is 482.745
[ERROR 2018-08-25 21:49:41]statusCode error, expected_code is 208, statusCode is 200

6、Assert部分代码

def assert_body(self, body, body_msg, expected_msg):"""验证response body中任意属性的值:param body::param body_msg::param expected_msg::return:"""try:msg = body[body_msg]assert msg == expected_msgreturn Trueexcept:self.log.error("Response body msg != expected_msg, expected_msg is %s, body_msg is %s" % (expected_msg, body_msg))Consts.RESULT_LIST.append('fail')raisedef assert_in_text(self, body, expected_msg):"""验证response body中是否包含预期字符串:param body::param expected_msg::return:"""try:text = json.dumps(body, ensure_ascii=False)# print(text)assert expected_msg in textreturn Trueexcept:self.log.error("Response body Does not contain expected_msg, expected_msg is %s" % expected_msg)Consts.RESULT_LIST.append('fail')raise

7、Request部分代码

def post_request(self, url, data, header):"""Post请求:param url::param data::param header::return:"""if not url.startswith('http://'):url = '%s%s' % ('http://', url)print(url)try:if data is None:response = self.get_session.post(url=url, headers=header)else:response = self.get_session.post(url=url, params=data, headers=header)except requests.RequestException as e:print('%s%s' % ('RequestException url: ', url))print(e)return ()except Exception as e:print('%s%s' % ('Exception url: ', url))print(e)return ()# time_consuming为响应时间,单位为毫秒time_consuming = response.elapsed.microseconds/1000# time_total为响应时间,单位为秒time_total = response.elapsed.total_seconds()Common.Consts.STRESS_LIST.append(time_consuming)response_dicts = dict()response_dicts['code'] = response.status_codetry:response_dicts['body'] = response.json()except Exception as e:print(e)response_dicts['body'] = ''response_dicts['text'] = response.textresponse_dicts['time_consuming'] = time_consumingresponse_dicts['time_total'] = time_totalreturn response_dicts

四、Allure报告及Email

1、Allure报告总览,见下图:

2、Email见下图:


五、后续优化

1、集成Jenkins,使用Jenkins插件生成Allure报告
2、多线程并发接口自动化测试
3、接口加密,参数加密


              【下面是我整理的2023年最全的软件测试工程师学习知识架构体系图】


一、Python编程入门到精通

二、接口自动化项目实战 

三、Web自动化项目实战

四、App自动化项目实战 

五、一线大厂简历

六、测试开发DevOps体系 

七、常用自动化测试工具

八、JMeter性能测试 

九、总结(尾部小惊喜)

生命不息,奋斗不止。每一份努力都不会被辜负,只要坚持不懈,终究会有回报。珍惜时间,追求梦想。不忘初心,砥砺前行。你的未来,由你掌握!

生命短暂,时间宝贵,我们无法预知未来会发生什么,但我们可以掌握当下。珍惜每一天,努力奋斗,让自己变得更加强大和优秀。坚定信念,执着追求,成功终将属于你!

只有不断地挑战自己,才能不断地超越自己。坚持追求梦想,勇敢前行,你就会发现奋斗的过程是如此美好而值得。相信自己,你一定可以做到! 

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/214407.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue3.3.4中watch无法监测props的更改

背景 网上说了很多解决方案,都是通过watch(() > props.value, (newValue, oldValue) > {})解决,或者是加上{deep: true}附加属性。但是我在Vue3.3.4中,还是无法解决。 下面说一下我的解决方案。 解决方案 通过父组件调用子组件defineE…

点云/Mesh 常见处理库和软件汇总

注:参考 网址1、网址2 文章目录 软件通用点云/Mesh处理库通用几何处理库专用功能库 软件 Processing MeshLabCloudCompareTrimeshPyVistaVedo Visualization Simple-3dvizPlotOptiX (Requires CUDA-enabled GPU)PolyscopePyrender 通用点云/Mesh处理库 PCL &am…

【开发问题】vue的前端和java的后台,用sm4,实现前台加密,后台解密

sm4加密 vue引入的包代码加密解密 javamaven代码运行结果 vue 引入的包 npm install sm-crypto代码加密解密 加密: key :代表着密钥,必须是16 字节的十六进制密钥 password :加密前的密码 sm4Password :代表sm4加密…

Python之格式化保存数据点

功能:将平面点集存储为格式化txt文档,每个坐标值为5位整数,前三位为整数,后2位为小数 输入:平面点坐标,用列表存储,列表的元素为点坐标元组 输出:txt文件,每行一个点坐…

【计算机网络】应用层电子邮件协议

一、电子邮件系统架构 电子邮件是一个典型的异步通信系统,发送方从UA,也就是邮件客户端,通过应用层SMTP协议,传输层tcp协议,发送给发送方的邮件服务器,比如使用的是163邮箱,163提供的SMTP服务器…

python中实现yaml文件管理参数

yaml参数管理器 这是文件目录关系,其中config存放.yaml文件,scripts存放py文件 然后就可以自由使用了: import yaml import os#获取路径 script_directory os.path.dirname(os.path.abspath(__file__)) # 相对于脚本文件的路径 image_relat…

Swift “黑魔法”之动态获取类实例隐藏属性的值

概览 在 Swift 代码的调试中,我们时常惊叹调试器的无所不能:对于大部分“黑盒”类实例的内容,调试器也都能探查的一清二楚。 想要自己在运行时也能轻松找到 Thread 实例“私有”属性的值吗(比如 seqNum)? 在本篇博文中您将学到如下内容: 概览1. 借我,借我,一双慧眼吧…

字符统计[c]

#include<stdio.h> #include<string.h> int main() {int a,b,c;abc0;char s[100];int i0;while(1){i;scanf("%c",&s[i]);if(s[i]?)break;}for(int k1;k<i;k){if(s[k]>48&&s[k]<57){a;//数字}else if((s[k]>65&&s[k]<…

Altair Radioss碰撞 安全与冲击 衡祖仿真

Altair Radioss是解决瞬态加载工况下非线性问题的领先的结构分析求解器。其具备高扩展性、高品质、高鲁棒性&#xff0c;以及诸多功能&#xff1a;多域求解技术、高级材料功能(复合材料)等。Radioss求解器被广泛应用于汽车、航空航天、电子/家电、包装、轨道机车、生物医疗、能…

前端项目有关面试

目录 [TOC](目录) 1. MVC、MVP、MVVM2.大文件上传、多文件上传和断点续传的区别3. 前端存储4.什么是前端自适应5.浏览器原理5.1 从输入url到看到界面的过程5.2 跨域 1. MVC、MVP、MVVM MVC、MVP、MVVM 是常见的软件架构设计模式。MVVM&#xff1a;是一种软件架构设计模式&…

c语言实现链表

链表是一种常见的数据结构&#xff0c;用于存储一系列的元素。它由一系列的节点&#xff08;Node&#xff09;组成&#xff0c;每个节点包含数据和指向下一个节点的指针。不同于数组需要连续的内存空间来存储元素&#xff0c;链表使用指针将节点按照某种逻辑顺序连接起来。 每…

C 语言入门:如何编写 Hello World

C 语言简介 C 语言是由 Dennis Ritchie 于 1972 年在贝尔实验室创建的一种通用编程语言。尽管年代久远&#xff0c;它仍然是一款非常流行的语言。它之所以受欢迎的主要原因是它是计算机科学领域的基础语言之一。C 语言与 UNIX 紧密相连&#xff0c;因为它被用于编写 UNIX 操作…

Audio Signal (MATLAB) 代码学习1-常见问题

问题描述 使用MATLAB完成如下操作 加载音频文件,并存储到变量x中将x和一个频率为440Hz的正弦信号相加,用结果定义一个新的信号y绘制y信号的时域图,并正确定义时间轴利用Hann window(汉宁窗)从y中提取一个20ms的窗信号利用线性预测编码(阶数20)预测白化滤波器的参数。% …

讯飞星火认知大模型与软件测试结合,提升软件质量与效率

随着人工智能技术的不断发展&#xff0c;越来越多的企业开始将其应用于软件开发过程中。其中&#xff0c;讯飞星火认知大模型作为一种基于深度学习的自然语言处理技术&#xff0c;已经在语音识别、机器翻译、智能问答等领域取得了显著的成果。而在软件测试领域&#xff0c;讯飞…

设置bat工作目录

在执行bat脚本的时候&#xff0c;如果直接双击bat脚本&#xff0c;此时的工作路径一般为C:\Users\Administrator> 很多时候需要将工作路径设置为bat脚本所在的目录&#xff0c;可以在bat脚本内设置当前工作路径为bat文件所在目录&#xff0c; cd /d %~dp0cd:设置工作目录为…

【算法优选】 动态规划之路径问题——贰

文章目录 &#x1f38b;前言&#x1f332;[下降最小路径和](https://leetcode.cn/problems/minimum-path-sum/)&#x1f6a9;题目描述&#x1f6a9;算法思路&#xff1a;&#x1f6a9;代码实现 &#x1f38d;[最小路径和](https://leetcode.cn/problems/minimum-path-sum/)&…

viple与物理机器人(一):线控模拟

为了检测viple程序与物理机器人是否能顺利连接上 如果能顺利连接上&#xff0c;那么&#xff0c;可以通过内建事件从而控制物理机器人的前进、后退、左转、右转以及暂停。 如果不能连接上&#xff0c;首先&#xff0c;程序无法控制物理机器人&#xff0c;其次&#xff0c;当vip…

公交站间的距离

&#x1f388; 算法并不一定都是很难的题目&#xff0c;也有很多只是一些代码技巧&#xff0c;多进行一些算法题目的练习&#xff0c;可以帮助我们开阔解题思路&#xff0c;提升我们的逻辑思维能力&#xff0c;也可以将一些算法思维结合到业务代码的编写思考中。简而言之&#…

我的 CSDN 三周年创作纪念日:2020-12-12

本人大叔一枚&#xff0c;自1992年接触电脑&#xff0c;持续了30年的业余电脑发烧爱好者&#xff0c;2022年CSDN博客之星Top58&#xff0c;阿里云社区“乘风者计划”专家博主。自某不知名财校毕业后进入国有大行工作至今&#xff0c;先后任职于某分行信息科技部、电子银行部、金…

C语言面试之旅:掌握基础,探索深度(面试实战之单片机并行存储器扩展)

引言 在嵌入式系统和微控制器等应用中&#xff0c;存储器是至关重要的组成部分。单片机通常具有有限的内核存储器和外部接口&#xff0c;因此扩展存储器成为许多应用的必要步骤。本文将探讨单片机并行存储器扩展的各个方面。 1、单片机并行扩展总线 并行存储器扩展是一种将…