软件测试_接口测试面试题_1.6

68031971ddd76e697a54da435b25490f.png

接口测试是软件测试中的重要环节,它主要验证系统不同模块之间的通信和数据交互是否正常。在软件开发过程中,各个模块之间的接口是实现功能的关键要素,因此对接口进行全面而准确的测试是确保系统稳定性和可靠性的关键步骤。

接口测试的核心目标是确保系统在不同模块之间的数据传输和交互的正确性。通过对接口的输入和输出进行验证,我们可以确保系统在实际运行中能够正常工作,并且符合预期的需求。在接口测试中,我们需要关注接口的功能、性能、安全性和可靠性等方面,以保证系统的高质量和稳定性。

在进行接口测试时,我们需要根据系统的设计和需求文档,设计合适的测试用例,对接口的各种情况进行全面的覆盖。同时,我们还需要使用各种工具和技术来模拟不同的测试场景,以确保系统在各种情况下都能正常运行。通过接口测试,我们可以发现并解决系统中的潜在问题,提高系统的可靠性和稳定性。

总之,接口测试是保证系统正常运行的重要环节,它能够帮助我们发现并解决系统中的问题,确保系统的高质量和稳定性。通过全面而准确的接口测试,我们可以提高系统的可靠性和可用性,满足用户的需求,并为软件开发和维护工作提供有效的支持。

上一篇:软件测试_接口测试面试题_1.5

01. 怎么设计接口测试用例?

通常,设计接口测试用例需要考虑以下几个方面:

①是否满足前提条件

有些接口需要满足前提,才可成功获取数据。常见的,需要登录Token

逆向用例:针对是否满足前置条件(假设为n个条件),设计0~n条用例

②是否携带默认值参数

正向用例:带默认值的参数都不填写、不传参,必填参数都填写正确且存在的“常规”值,其他不填写,设计1条用例

③业务规则、功能需求

这里根据时间情况,结合接口参数说明,可能需要设计N条正向用例和逆向用例

④参数是否必填

逆向用例:针对每个必填参数,都设计1条参数值为空的逆向用例

⑤参数之间是否存在关联

有些参数彼此之间存在相互制约的关系

⑥参数数据类型限制

逆向用例:针对每个参数都设计1条参数值类型不符的逆向用例

⑦参数数据类型自身的数据范围值限制

正向用例:针对所有参数,设计1条每个参数的参数值在数据范围内为最大值的正向用例

02. 你做接口测试,测什么?

可用性测试: 根据约定的协议、方法、格式内容,传输数据到接口经处理后返回期望的结果:

接口功能是否正确实现:返回值测试 - 返回值除了内容要正确,类型也要正确,保证调用方能够正确地解析;参数值边界值、等价类测试;

错误和异常处理测试:输入异常值(空值、特殊字符、超过约定长度等),接口能正确处理,且按预期响应;输入错误的参数,接口能正确处理,并按预期响应;多输入、少输入参数,接口能正确处理,且按预期响应;错误传输数据格式(如json格式写成form格式)测试;安全性测试,主要指传输数据的安全性:

敏感数据(如密码、秘钥)等是否加密传输:返回数据是否含有敏感数据,如用户密码、完整的用户银行账号信息等;接口是否对传入的数据做安全校验,如身份ID加token类似校验;接口是否防止恶意请求(如大量伪造请求接口致使服务器崩溃);

性能测试:如接口的响应时间、并发处理能力、压测处理情况;并发请求相同的接口(特别为POST请求),接口的处理情况(如插入了相同的记录导致数据出错,引发系统故障);接口响应时长在用户可忍受的范围内;对于请求量大的接口做压测,确定最大的瓶颈点是否满足当前业务需要;

03. 平常用什么工具测接口的?

常用http协议接口测试工具,如:postman、fiddler、jmeter;webService接口用SoapUI、jmeter等

04. 没有接口文档,如果做接口测试?

用抓包工具把接口抓取处理,然后针对性进行测试;接口中字段信息不清楚的,找时间集中寻求开发解答。(常用抓包工具Fiddler、Charles等)

05. 在手工接口测试或者自动化接口测试的过程中,上下游接口有数据依赖如何处理?

用一个全局变量来处理依赖的数据,比如登录后返回token,其它接口都需要这个token,那用全局变量来传token参数

06. 依赖于第三方数据的接口如何进行测试?

mock:接着面试官会问你,如果mock的,然后你就顺着坑继续挖,搭建mock服务

07. 接口测试中,依赖登录状态的接口如何测试?

依赖登录状态的接口的本质上是在每次发送请求时需要带上session或者cookie才能发送成功,在构建POST请求时添加必要的session或者cookie

08. 如何模拟弱网做测试?

Fiddler和charles都可以模拟弱网测试,平常说的模拟丢包,也是模拟弱网测试。

09. 你平常做接口测试的过程中发现过哪些bug?

常规错误,接口没实现,没按约定返回结果,边界值处理出错等。

输入异常值(空值、特殊字符、超过约定长度等),接口抛错,没做封装处理;

输入错误的参数、多输入、少输入参数,接口可能出现的错误;

安全性问题,如明文传输、返回结果含有敏感信息,没对用户身份信息做校验,没做恶意请求拦截等;

性能问题,如接口并发插入多条相同操作,响应时间过长,接口压测出现瓶颈等;

10. 当一个接口出现异常时候,你是如何分析异常的?

先抓包,用fiddler(charles)工具抓包,或者浏览器上F12调试工具;APP上的话,那就用Fiddler做代理,通过手机设置代理去看请求和返回报文;

查看后端日志,如Linux系统通过xhell连上服务器,查看接口日志,查看是否有报错信息(命令:tail -f 日志文件);

11. 如何分析一个bug是前端还是后端的?

平常提bug的时候,前端开发和后端开发总是扯皮,不承认是对方的bug。

这种情况很容易判断,先抓包看请求报文,对着接口文档,看请求报文有没问题,有问题就是前端发的数据不对;

请求报文没问题,那就看返回报文,返回的数据不对,那就是后端开发的问题咯。

12. 你们做接口测试自动化吗?

答:现在针对大量应用,普遍推崇做接口测试自动化,维护成本低、收益高。常用的工具有许多,如Jmeter、Robot Framework、pytest等

总结

接口测试是软件测试中一个至关重要的环节。通过验证系统各个模块之间的通信和数据交互是否正常,接口测试确保了系统的稳定性和可靠性。在接口测试中,我们需要关注功能、性能、安全性和可靠性等方面,以保证系统的高质量。通过设计合适的测试用例和使用适当的工具和技术,我们可以发现并解决系统中的潜在问题,提高系统的可靠性和稳定性。接口测试不仅能够满足用户的需求,还为软件开发和维护提供了有效的支持。因此,我们应该高度重视接口测试的工作,并不断优化和完善它,以确保系统能够正常运行,并满足用户的期望。

历史推文:

面试题_软件测试岗_UI自动化篇_1.4

面试题_软件测试岗_自动化篇_1.3

重磅推荐:《测试开发面试宝典》重磅推荐!

8993b4504152d82f7fcd00a781ec1dd9.jpeg

如果觉得有用,就请关注、点赞、在看、分享到朋友圈吧!

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值