news 2026/6/15 16:02:55

「接口自动化测试」高频面试题!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
「接口自动化测试」高频面试题!

一、json和字典的区别?

  • json就是一个文本、字符串;有固定的格式,格式长的像python字典和列表的组合;以key-value的键值对形式来保存数据,结构清晰,。可以说是目前互联网项目开发中最常用的一种数据交互格式

  • 字典属于python里面的基本数据类型

  • json不属于python里面的基本数据类型

二、你做接口自动化测试时,测试数据放哪里?

  • 对于一些基础数据比如说数据库配置可以放到静态配置配置文件中(日志级别、请求头、请求url、账号密码)

  • 接口测试需要用到的数据可以放到数据库表,也可以放到excel文件中(请求方法、请求数据)

三、什么是数据驱动

  • 数据驱动就是通过excel来维护测试数据,通过相应的技术处理,拿到测试数据用于测试,从而实现测试数据与代码的解耦;

  • 数据驱动测试的本质就是高级的参数化。

四、excel中如何设计你的用例?

  • 所有的接口信息维护在一个excel文件中

  • 每个接口,用一个sheet表维护

  • 接口传递请求参数用data列,通过构造json格式的字符串即可解决多个传参的问题,同时提升了用例的可维护性

五、excel中的数据怎么拿出来?

  • 通过第三方库openpyxl来完成,项目只要引入第三方库,通过它提供的api即可完成对excel的操作,甚至于我们自己也可以做一些二次封装,封装一个读写excel中用例的方法,使得操作更方便。一行数据就是一个用例。

六、如果有些接口做了鉴权(需要鉴定权限),怎么实现这些接口的自动化测试?

  • 通过token来实现鉴权的,那么同样先调用完登录接口–》拿到它返回的这个数据–》存储起来(存储在动态环境变量Envdate中),后面再调用其他接口的时候直接带上这个数据过去就可以了。

  • 把token保存在动态环境变量Envdate中(因为token是可以变化的,一般不放到静态环境变量中)

七、什么是会话?

  • 所谓会话就是session,而session是一种服务器的缓存技术,由服务器端创建,用户登录了系统,一般就会把登录用户的信息保存到这个session对象中,然后把此会话对应的id(JSESSIONID)返回,因此大部分系统都会用到session机制来实现鉴权。Session保存数据方式也是以key-value的形式。

八、什么是token?

  • 所谓token其实就是服务器端返回的一个字符串(比较复杂,有点类似于xys73494954sdhcdr83435这么一串),基于JWT生成的token令牌,一般这个数据是唯一的,服务器每次返回的token都会不一样。

  • Token之所以可以用来做鉴权,原理如下:

    • 用户a调用了登录接口–》登录了系统b–》服务器端生成了一个唯一的token信息(假设为c),然后会拿用户的编号id(假设为d)做了一个映射:c-d,然后将这样的映射关系存到数据库或redis等缓存中,然后再返回这个token给客户端–》客户端再调用其他需要鉴权的接口时,只需要将缓存起来的这个token带过去验证–》服务器根据此token检查是否有登录用户信息来判断此请求是否是一个已登录授权的用户。(这里客户端怎么取到这个token,怎么存,再次请求时怎么带过去,上面接口鉴权部分已解释)

九、某个接口请求,参数依赖上个接口的返回数据,怎么处理(接口关联)?

  • 场景:b接口在调用的时候参数依赖于a接口的返回数据。

  • 处理方案:

    • a接口调用完–》从响应中取出b依赖的这个参数–》保存起来–》b调用的时候,取出这个信息–》当做参数传过去即可。

十、接口调用依赖第三方的接口b,而b接口还未提供给你,如何处理?

  • 通过mock框架搭建自己的mock系统/平台(其实就是自己开发接口),模拟这个第三方接口mock一个出来即可,这样就解决了这个依赖。

十一、你做接口自动化时怎么做的数据验证

  • 数据验证主要包括两个方面:

    • 接口响应报文的验证

      • 利用jsonpath取出响应数据(大多数情况是json)中的关键字段的值,通过AssertEqual断言期望值和实际结果是否符合预期。

    • 数据库表数据的验证

  • 做表数据验证要先明白两点:

    • 表数据验证首先得明白这个接口的基本业务,会影响到哪些表,哪些字段的数据,然后才能准备查询sql去有针对性的查数据。

    • 并不是所有用例的执行都会操作数据库,影响到表数据,因此只有影响到了表数据的用例,才准备查询脚本

十二、如何提升测试套件的执行效率(接口测试优化的地方)

  • 减少excel读写,减少不必要的io操作

  • excel读取测试数据,全部存储到静态变量中

  • excel数据回写,尽量通过批量方式去写。

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

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 11:53:49

Google Cloud零售API实战:构建下一代智能电商推荐引擎

Google Cloud零售API实战:构建下一代智能电商推荐引擎 【免费下载链接】python-docs-samples Code samples used on cloud.google.com 项目地址: https://gitcode.com/GitHub_Trending/py/python-docs-samples 在数字化转型浪潮中,零售企业面临着…

作者头像 李华
网站建设 2026/6/15 6:41:18

UniVRM完整指南:从零开始掌握虚拟角色导入导出

UniVRM完整指南:从零开始掌握虚拟角色导入导出 【免费下载链接】UniVRM UniVRM is a gltf-based VRM format implementation for Unity. English is here https://vrm.dev/en/ . 日本語 はこちら https://vrm.dev/ 项目地址: https://gitcode.com/gh_mirrors/un/U…

作者头像 李华
网站建设 2026/6/15 0:58:07

学生成绩分析和弱项辅助系统(11452)

项目演示视频 有需要的同学,源代码和配套文档领取,加文章最下方的名片哦 一、项目演示 二、资料介绍 完整源代码(前后端源代码SQL脚本)配套文档(LWPPT开题报告)远程调试控屏包运行 三、技术介绍 Java语…

作者头像 李华
网站建设 2026/6/14 22:15:44

【郑州大学主办,IEEE Fellow支持,可靠有保障 | IEEE出版 ,EI稳定检索,该出版社快至会后3个月检索】第二届图像处理、多媒体技术与机器学习国际学术会议(IPMML 2025)

往年已稳定EI检索!录用率高!支持latex和word双通道投稿 郑州大学主办,IEEE Fellow支持,可靠有保障! 第二届图像处理、多媒体技术与机器学习国际学术会议(IPMML 2025) 2025 2nd Internationa…

作者头像 李华
网站建设 2026/6/15 12:45:35

4张GPU搞定70B大模型训练!DeepSpeed SuperOffload实战全解析

4张GPU搞定70B大模型训练!DeepSpeed SuperOffload实战全解析 【免费下载链接】DeepSpeedExamples Example models using DeepSpeed 项目地址: https://gitcode.com/gh_mirrors/de/DeepSpeedExamples 还在为训练70B参数大模型的显存需求而发愁吗?D…

作者头像 李华
网站建设 2026/6/13 21:03:04

大模型知道自己在瞎说,却停不下来背后的原理是什么?

前言:作为长期和大语言模型打交道的技术从业者,你一定经历过这样的场景:让模型解答一个复杂问题,它开头逻辑清晰、步骤明确,但越往后越像在自言自语——反复重述观点、兜圈子解释、堆砌看似合理却毫无信息增量的句子。…

作者头像 李华