测试开发面试题

简述自动化测试的三大等待

  • 强制等待。直接使用time.sleep()方法让程序暂停指定的时间。优点是实现简单,缺点是不够灵活,可能会导致不必要的等待时间浪费。
  • 隐式等待。设置一个固定的等待时间,在这个时间内不断尝试去查找元素,如果能找到,则继续执;如果找不到,则抛出异常。在浏览器对象的整个生命周期起作用,优点是能够适应页面加载速度,缺点就是隐式等待会对整个webDriver期间全局生效,意味着不需要等待的场景下,也会有潜在的延迟,无形中延长了整体测试执行时间。一般都是使用driver.implicitly_wait()实现
  • 显式等待。他是触发式等待策略,能够支持测试脚本中某个特定条件变成真之后再继续执行。使用的是webDriverWait类

你对 selenium 二次封装的关键字,是怎么封装的?以等待元素的关键字举例,设计了哪些参数?

主要就是对一些繁琐的操作抽象成简单易懂的函数或方法。

以等待元素的关键字举例,需要设计:

  • 元素定位方式、定位表达式。根据id还是xpath等
  • 超时时间。如果超过超市时间还没有满足条件,则抛出异常
  • 轮训时长。设置多久检查一次是否满足条件。
  • 异常处理。能够自定义超市或条件不符合的处理例如,比如打印错误日志,截图等。

做WebUI自动化遇到过那些问题,如何解决的?

元素定位不稳定。使用XPATH可以减少这种情况

元素异步加载问题。等待元素加载即可

上述都是一些常规的问题,在我实际工作中,使用UI自动化测试过实时渲染的表格,这种表格前端使用的是Canvas,也就是对图形进行实时渲染,这种情况下F12抓取DOM树只能抓到这个canvas这个标签,测试这种情况,我当时使用的是图像对比。

(如果继续问图像对比是如何实现的,则)可以继续说,使用PIL库进行比较。先截取当前页面,和预设的图片去做比对,可以使用工具去标注不同的像素区域。

如果你做接口测试,接口返回成功,但实际数据库没有相应数据,可能存在什么问题?如何定位?

  • 最开始,我会考虑是否数据库链接错了,那数据库肯定是没有相应数据的
  • 如果数据库正确的,简单的考虑就是网络不好,没有加载出来,多刷新一下等下,也会尝试直接使用sql语句去查询;复杂一点的考虑,可能就是后端的代码问题,也许还没提交事务,就先返回了响应,那肯定也是没有数据的
  • 最后还会找后端开发协助排查,尝试复现,或者到服务器上面翻日志

性能测试了解吗?(应该就是说会关注那些性能指标)

你是如何设计测试方案吗?是如何测试的?

安全测试了解吗?

Webdriver的原理(应该是和WebUI相关的)

相关推荐
星火开发设计2 分钟前
二叉树详解及C++实现
java·数据结构·c++·学习·二叉树·知识·期末考试
xiaoxiaoxiaolll12 分钟前
《Light: Science & Applications》超表面偏振态与偏振度完全独立控制新范式
学习
sww_102642 分钟前
JVM基础学习
jvm·学习·测试工具
num_killer1 小时前
小白的Jenkins学习
运维·python·学习·jenkins
Every exam must be1 小时前
12.2 vue学习02
学习
sunfove1 小时前
照度 (E) 与亮度 (L) 的关系
学习
HL_风神2 小时前
设计原则之单一职责原则
c++·学习·设计模式·单一职责原则
CS创新实验室2 小时前
正态分布的深入学习:从数学发现到自然法则的演变
学习·数据挖掘·数据分析·统计学·正态分布
半夏知半秋2 小时前
rust学习-Option与Result
开发语言·笔记·后端·学习·rust
王夏奇2 小时前
Python库学习-标准库
学习