资深测试总结,Python接口自动化测试-数据依赖解决(详全)

news2025/1/12 0:50:07

目录:导读

    • 前言
    • 一、Python编程入门到精通
    • 二、接口自动化项目实战
    • 三、Web自动化项目实战
    • 四、App自动化项目实战
    • 五、一线大厂简历
    • 六、测试开发DevOps体系
    • 七、常用自动化测试工具
    • 八、JMeter性能测试
    • 九、总结(尾部小惊喜)


前言

Python自动化测试:https://www.bilibili.com/video/BV16G411x76E/

在实际的测试工作中,在做接口自动化测试时往往会遇到接口间数据依赖问题。

比如:API_03的请求参数来源于API_02的响应数据,API_02的请求参数又来源于API_01的响应数据。

因此通过自动化方式测试API_03接口时,需要预先请求API_02接口,获取到API_03的请求参数,而获取API_02的响应又需要预先对API_01发起请求,从响应中提取API_02的请求参数。

而下面的自动化框架设计便解决了这一问题:

用于数据驱动的Excel表格设计

请添加图片描述

框架代码实现逻辑

当测试 id 为 shop-03 的接口时,首先判断【是否运行】。如果为 ‘yes’ 则判断该接口请求类型, ‘POST’ OR ‘GET’ 走不同的逻辑分支。

POST请求的话判断是否有【case依赖】,【case依赖】为空则无依赖,不为空则获取依赖的case id。

上述表格中,shop-03的case依赖为shop-02,获取到依赖的id后,代码逻辑主动去判断shop-02接口的相关字段参数(【是否运行】/【请求类型】/【case依赖】),如果shop-02也存在依赖接口shop-01,则代码继续判断shop-01接口对应字段参数。

shop-01接口【case依赖】字段为空时,获取【请求数据】根据请求数据这个字段获取单独存储在字典中的完整的请求参数,发起请求,获得shop-01的响应后根据shop-01对应的【被依赖接口的返回数据】提取下游接口。

即shop-02的所需要的依赖参数,存入一个依赖参数列表中,shop-02接口把获取到的参数代入到请求参数中进行请求,获取到shop-02的响应后同样根据【被依赖接口的返回数据】提取下游接口shop-03所需要的依赖参数,存入依赖参数列表,shop-03接口从列表中获取这个参数代入请求参数,进入请求,获取响应,根据【实际结果取值字段】获取要断言的字段,并对比预期结果完成该接口的测试。

主逻辑模块部分代码示例:

# 主逻辑模块部分代码示例
'''判断是否有case依赖,如果有case依赖则执行depend_data.py中的depend_response_data(self,caseid)方法,该方法返回该接口发起请求的依赖参数'''
 elif method == 'Post':
                    if depend_caseid:
                        params_data_list = self.depend_result.depend_response_data(depend_caseid)
                        log_info('main_logic.requests_api::根据依赖的caseid={},'
                                 '调用depend_data.depend_response_data获取到的依赖数据为:{}'.format(depend_caseid, params_data_list))
                        for j in range(len(depend_key_list)):
                            params[depend_key_list[j]] = params_data_list[j][0]
                        header = rquests_headers()
                        log_info('main_logic.requests_api::执行的用例{}请求url为:{},入参为:{},请求头为:{}'.format(caseid,url,params,header))
                        response = self.post_requests(url, params, header)
                        # print(response)
                        self.results_list.append(response)
                    else:
                        header = rquests_headers()
                        response =self.post_requests(url, params, header)
                        # print(response)
                        self.results_list.append(response)

数据依赖模块部分代码示例:

#数据依赖模块部分代码示例
'''通过excel表中【case依赖】字段一层层向上游接口请求,结果储存在一个结果列表中供下游接口调用,最后返回测试接口所需要的依赖数据'''    
def depend_response_data(self,caseid):
        depend_caseid_t = self.excel_case_data.get_depend_caseid(caseid)
        depend_caseid_list = []
        #如果case依赖字段不为空
        if depend_caseid_t:
            #获取接口串联依赖caseid列表
            while depend_caseid_t:
                depend_caseid_list.append(depend_caseid_t)
                depend_caseid_t = self.excel_case_data.get_depend_caseid(depend_caseid_t)
            depend_caseid_list.reverse()
            depend_caseid_list.append(caseid)
            march_result_list = []
            num_caseid = len(depend_caseid_list)
            #迭代获取列表中的caseid
            for i in range(num_caseid):
                depend_caseid_s = self.excel_case_data.get_depend_caseid(depend_caseid_list[i])
                depend_key_list = self.excel_case_data.get_depend_key(depend_caseid_list[i]).split(",")
                params_key = self.excel_case_data.get_request_key(depend_caseid_list[i])
                params = self.requests_data[params_key]
                url = self.excel_case_data.get_url(depend_caseid_list[i])
                #判断该caseid的测试用例中case依赖是否为空
                if depend_caseid_s:
                    #获取上一个依赖接口返回的依赖参数
                    params_data_list = march_result_list[i-1]
                    #根据该caseid数据依赖字段构造该接口的传参
                    for k in range(len(depend_key_list)):
                        params[depend_key_list[k]] = params_data_list[k][0]
                    #对该接口发起请求
                    header = rquests_headers()
                    result = post_requests(url, params, header)
                    getdata = GetExcelDate()
                    is_depend_response = getdata.get_depend_response(depend_caseid_list[i])
                    #判断该接口是否需要为下一接口返回依赖参数
                    if is_depend_response:
                        depend_response_list = is_depend_response.split(",")
                        results = result
                        matchlist = depend_response_list
                        matchparams = match_params(results, matchlist)
                        march_result_list.append(matchparams)
                    else:
                        print("caseid={}不需要返回被依赖的字段".format(depend_caseid_list[i]))
                #当该caseid测试用例中case依赖为空时直接请求该接口,返回匹配到的下一关联接口的请求参数
                else:
                    result = self.depend_response(depend_caseid_list[i])
                    getdata = GetExcelDate()
                    is_depend_response = getdata.get_depend_response(depend_caseid_list[i])
                    if is_depend_response:
                        depend_response_list = is_depend_response.split(",")
                        results = result
                        matchlist = depend_response_list
                        matchparams = match_params(results, matchlist)
                        march_result_list.append(matchparams)
                    else:
                        print("caseid={}不需要返回被依赖的字段".format(depend_caseid_list[i]))
            return matchparams

下面说一些高频接口自动化的面试题:

1、你写了多少接口自动化用例?

自动化用例,也没有具体数过,当时我负责的所有模块的接口的自动用例都是我这边独立完成的,有模块的用例会多一点,有些会少一点,这具体看接口的参数有多少,参数多限制条件多的,一般用例会比较多一点,我负责的模块大概有100多条用例是有的。

2、比如说你接口的请求参数需要加密处理的,你们用的是什么加密方式,你加密怎么处理的?

这个是有做过的,就拿当我们那个项目的登录接口来讲吧,那个登录的密码是需要进行加密。

加密之后再进行传输。这里需要问开发要加密算法,我们会把它封装成一个函数,调用这个加密函数对密码加密,之后再进行传递。我们公司的加密算法,大部分用的都是MD5的加密算法(base64)

3、你查询出来返回结果是密文,密文你怎么测试

这里首先要搞清楚用的是什么加密算法,问开发要解密算法,对返回的数据进行解密,解密完成之后在与预期结果对比,去进行断言。

4、requests中如何进行动态关联?

如果返回的是 cookies值,可以直接返回接口的 r.cookies;

返回的是str类型数据,可以导入re模块进行正则表达式提取返回数据格式是json格式,导入json,把json数据格式转化 python对象

json.dumps 将 Python对象编码成JSON字符串
json.loads 将已编码的JSON字符串解码为 Python对象

5、你们 python接口自动化怎么去处理 cookie, session的?

对于 cookie,session的处理一般有三种方式:

第一种就是先获取登录请求的 cookie值,然后发送其他请求的时候,在 requests提供的
两个方法get或post方法中有一个 cookies参数,我们可以通过这个参数来传递 cookies值

第二种就是通过订制请求头,然后把获取到的coookies放在请求头中,通过请求头来进行传递

第三种就是通过创建一个 session会话对象,后期所有的请求发送都通过调用这个 session会话对象来进行发请求,如果是登录请求,它会自动保存 cookies值,然后其他需要用到cookies值的请求,也通过 session对象来发送,它会自动把 cookies发送出去,对于 cookies, session的处理,我们差不多都是通过以上三种方式来实现的。

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

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

每一个人都有自己的天赋和潜力,但成功只属于那些敢于追求、不断努力的人。不要害怕失败,因为失败是成功的垫脚石;不要停下脚步,因为前方总会有更美好的风景。

在奋斗的路上,不怕起点低,不怕路途远,只要一直坚持下去,你就会发现成功的彼岸。所以,不要轻易放弃,不要随便沉溺,不要忘了初心,你的努力终将得到回报。

人生路漫漫,不要被困难压垮,也不要被成功冲昏头脑。要学会坚韧不拔,要保持谦虚和进取心,因为每一个努力的瞬间,都会让你变得更加出色。

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

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

相关文章

MyBatis学习 (一) 配置文件解析流程

MyBatis源码学习 最近在学习MyBatis的代码。记录下 首先下载下源码: https://github.com/mybatis/parent https://github.com/mybatis/mybatis-3 parent为父控依赖。也需要下载。 入口 InputStream inputStream null; try {// 获取配置文件inputStream Reso…

Java经典笔试题—day06

Java经典笔试题—day06 🔎选择题🔎编程题🥝不要二🥝把字符串转换成整数 🔎结尾 🔎选择题 (1)关于抽象类与最终类,下列说法错误的是? A. 抽象类能被继承,最终类只能被实…

Python、Pytest、Allure、Selenium和Jenkins实现自动化测试集成实例

下方查看历史精选文章 重磅发布 - 自动化框架基础指南pdfv1.1大数据测试过程、策略及挑战 测试框架原理,构建成功的基石 在自动化测试工作之前,你应该知道的10条建议 在自动化测试中,重要的不是工具 本文将介绍如何使用Python、Pytest、Allur…

燃气巡检系统

燃气管网检查是整个管网可靠运行的重要保证,尤其是加强天然气管道巡检管理更是重中之重。要做好管网维护工作,必须认真把握好每个环节,每个过程,每个细节,认真落实管网巡维制度等,而通过凡尔码管理系统可使…

程序员痛心流涕自述:“因为把自己代码给了别人,我亲手断送了自己的前程”

在求职的过程中,一般都会有投递简历、笔试、面试以及背调的环节,而在这几个环节中折戟沉沙的人也着实不少。 不少人觉得,在求职时简历需要优化,背调不能有瞒报、捏造的情况,而笔试面试则是纯纯的要靠硬实力。 虽然说…

MySQL基础(二十六)索引的创建与设计原则

1. 索引的声明与使用 1. 1 索引的分类 MySQL的索引包括普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。 从功能逻辑上说,索引主要有 4 种,分别是普通索引、唯一索引、主键索引、全文索引。 按照物理实现方式,索引可以分…

【Linux】shell编程之循环语句

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、循环语句二、for循环语句1.for 语句的结构2.for语句应用示例 三、while 循环语句1.while 循环语句结构2.while语句应用示例 四、until 循环五、跳出循环六、死循…

【Linux】信号的保存

信号的小细节真的很多~ 文章目录 前言一、信号的保存总结 前言 首先我们先引出一个新的概念,叫核心转储。linux系统提供了一种能力,操作系统可以将一个进程在异常的时候将核心代码部分进行核心转储,将内存中进程的相关数据全部dump到磁盘中&…

新版ripro全站美化子主题美化包使用说明手册

前言: 安装 Ripro 前,首先是需要先安装好 WordPress 主程序,因为 Ripro和美化包只是 WordPress 的一枚主题而已! 如何安装 WordPress 并不在本教程范围内,建议百度 如何安装好 WordPress ,但是还是想建议一下,尽量选择 Linux+php+nginx 的机器来安装 WordPress! 安装…

win部署CAS服务并使用

前提描述:通过本次了解cas是个什么东西,并使用它。 cas为oss(单点登录)的一种实现方案。要实现cas单点登录,首先需要部署cas的server服务。 CAS是Central Authentication Service的缩写,中央认证服务,。 一、安装CAS…

若依管理系统RuoYi-Vue:权限系统设计详解

文章目录 摘要数据库表结构设计菜单管理目录、菜单和按钮的区别菜单权限 api接口权限配置方法PreAuthorize注解介绍数据权限 前端vue权限拦截菜单权限按钮权限 摘要 若依(RuoYi)是一款基于Spring Boot和Vue.js开发的快速开发平台,它的权限管…

今天面了个阿里拿25k出来的小哥,让我见识到了什么是测试天花板

2022年堪称大学生就业最难的一年,应届毕业生人数是1076万。失业率超50%! 但是我观察到一个数据,那就是已经就业的毕业生中,计算机通信等行业最受毕业生欢迎! 计算机IT行业薪资高,平均薪资是文科其他岗位的…

优秀CRM系统的四个条件

如今,构建“以客户为中心”的经营模式,是许多企业提升竞争力的核心战略。CRM系统能够管理客户关系,提高销售线索转化率,帮助企业实现业绩增长。那么众多品牌中,CRM系统哪家公司做得更好? CRM做得好有哪几个…

Vue换肤主题

拷贝颜色选择组件 **ThemePicker <template><!-- navabar的换肤组件 --><el-color-pickerv-model="theme":predefine="[#409EFF,

智慧校园水电节能监管系统

现阶段各高校用电设备量多范围广&#xff0c;包含寝室、办公室、教室、会议厅、试验室、公共图书馆、运动场馆、饭堂、路面、园林绿化等地方&#xff0c;能耗极大。而且大多数节能意识薄弱&#xff0c;欠缺科学合理、科学合理的规章制度开展监管&#xff0c;造成电力能源很多消…

达索的全面的三维设计和产品开发工具CATIA V5-6R 2020版本下载与安装配置教程

目录 前言一、CATIA 安装二、CATIA更新包安装三、使用配置四、帮助文档安装&#xff08;非必要&#xff09;总结 前言 Dassault Systemes公司的CATIA软件是一种基于计算机辅助设计&#xff08;CAD&#xff09;和计算机辅助制造&#xff08;CAM&#xff09;的软件&#xff0c;用…

Vue(组件间通信:props、自定义事件、全局事件总线、消息订阅与发布)

一、props props不仅可以实现父给子传递信息&#xff0c;还可以进行子给父传递信息 1.父给子传递信息&#xff1a; 父组件中给子组件实例传递信息 子组件利用props进行接收组件传递信息&#xff08;接收方式有三种&#xff1a;数组、对象、配置对象&#xff09; 2.子给父传递…

【表面缺陷检测】基于yolov5的布匹表面缺陷检测(附代码和数据集)

写在前面: 首先感谢兄弟们的订阅,让我有创作的动力,在创作过程我会尽最大能力,保证作品的质量,如果有问题,可以私信我,让我们携手共进,共创辉煌。 路虽远,行则将至;事虽难,做则必成。只要有愚公移山的志气、滴水穿石的毅力,脚踏实地,埋头苦干,积跬步以至千里,就…

Mybatis Plus 入门 简单的CRUD 使用详解 条件查询 分页查询 DML操作 MP代码生成器

Mybatis Plus入门 MP是 MybatisPlus&#xff0c;简称MP&#xff0c;是一个 Mybatis 的增强工具&#xff0c;在 Mybatis 的基础上只做增强不做改变。MP为简化开发、提高效率而生。 它已经封装好了单表curd方法&#xff0c;我们直接调用这些方法就能实现单表CURD。 注意&#xf…

一分钟图情论文:《AIGC驱动的智慧图书馆转型:框架、路径与挑战》

一分钟图情论文&#xff1a;《AIGC驱动的智慧图书馆转型&#xff1a;框架、路径与挑战》 AIGC&#xff08;Artificial Intelligence Generated Content&#xff09;是一种全新的生产方式&#xff0c;利用人工智能技术自动生成文本、图片、语音、视频甚至虚拟现实等各种形式的数…