VOL 209
23
2021-02
今天距2022年311天
这是ITester软件测试小栈第209次推文
本文2877字,阅读约需7分钟
Hello,大家好。春节过后,有的人盼望升职加薪,有的人立了新的Flag,有跳槽计划的该提上日程了。为解大伙的燃眉之急,今天分享自动化面试题预热一波,欢迎留言区补充评论✍️。
一
请描述一下自动化测试流程?
自动化测试流程一般可以分为以下七步:
- 编写自动化测试计划;
- 设计自动化测试用例;
- 编写自动化测试框架和脚本;
- 调试并维护脚本;
- 无人值守测试;
- 后期脚本维护(添加用例、开发更新版本)。
二
自动化测试有误报过bug吗?产生误报怎么办?
有误报过,有时候自动化测试报告中显示发现了bug,实际去通过手工测试去确认又不存在该bug。
误报原因一般是:
- 元素定位不稳定,需要尽量提高脚本的稳定性;
- 开发更新了页面但是测试没有及时更新维护。
三
什么是PO模式?
全称:page object model 简称:POM/PO,PO
模式最核心的思想是分层,实现松耦合,实现脚本重复使用及脚本易维护性。
PO模式主要分三
层:
1.基础层BasePage:封装一些最基础的selenium的原生的api方法,元素定位,框架跳转等。
2.PO层:元素定位、获得元素对象,页面动作
3.测试用例层:业务逻辑,数据驱动。
三者的关系:PO层继承基础层,测试用例层调用PO层。
po模式和非po模式区别?
非PO模式 | PO模式 |
---|---|
面向过程的线性脚本 | POM把页面元素定位和业务操作流程分开,实现松耦合。 |
复用性差 | UI元素的改变不需要修改业务逻辑代码。只需要找到对应的PO页修改定位即可,数据代码分离。 |
维护性差 | PO能使我们的测试代码提高代码的可读性,高复用性,可维护性。 |
四
怎么对含有验证码的功能进行自动化测试?
对有验证码的功能模块进行自动化测试,可以通过以下方式:
- 让开发去掉验证码。未上线前,让开发去掉验证码验证,方便做自动化测试;
- 设置一个万能的验证码。未上线前,让开发生成固定的验证码,方便做自动化测试。
- 通过 cookie 绕过登录。
- 自动识别技术识别验证码。第一种是:OCR 自动识别技术,第二种是:通过第三方打码平台的接口来识别。
五
如何提高脚本的稳定性?
提高脚本的稳定性,可以通过以下方式:
- 不要右键复制 xpath(绝对路径很不稳定),自己写相对路径;
- 定位没问题,第二个影响因素那就是等待了,sleep 等待尽量少用(影响执行时间);
- 定位元素方法重新封装,结合 WebDriverWait 和 expected_conditions 判断元素方法,自己封装一套定位元素方法;
六
如果一个元素无法定位,你一般会考虑哪些方面的原因?
一个元素无法定位,可能的原因有:
- 页面加载元素过慢,加等待时间;
- 页面有frame框架页,需要先跳转入frame框架再定位;
- 可能该元素是动态元素,定位方式要优化,可以使用部分元素定位或通过父节点或兄弟节点定位;
- 可能识别了元素,但是不能操作,比如元素不可用,不可写等。需要使用js先把前置的操作完成。
七
你的自动化用例的执行策略是什么?
自动化用例的执行策略的含义:
- 自动化测试用例是用来监控的。集成到
Jenkins
,创建定时任务定时执行; - 有些用例在产品上线前必须回归。Jenkins上将任务绑定到开发的build任务上,触发执行;
- 有些用例不需要经常执行。Jenkins创建一个任务,需要执行的时候人工构建即可。
八
编写自动化用例的原则?
编写自动化用例的原则包括以下几个方面:
- 一个用例是一个完整的场景。
- 一个用例只验证一个功能点。
- 用例与用例之间尽量避免产生依赖。
- 一条用例完成测试之后需要对测试场景进行还原,以免影响其它用例的执行。
- 脚本编写好了之后,需要反复执行,不断调试,直到运行正常为止。脚本的编写和命名要符合管理规范,以便统一管理和维护。
九
selenium工作原理?
Selenium的工作原理可以概括为以下5个方面:
- selenium client(Python等语言编写的自动化测试脚本)初始化一个service服务,通过
webdriver
启动浏览器驱动程序chromedriver.exe; - 通过RemoteWebDriver向浏览器驱动程序发送HTTP请求,浏览器驱动程序解析请求,打开浏览器,并获得
sessionid
,如果再对浏览器操作需携带此sessionid; - 打开浏览器后,所有的selenium的操作(访问地址,查找元素)均通过RemoteConnection链接到remote server,然后使用execute方法调用request方法通过urlib3向remote server请求;
- 浏览器通过请求的内容执行对应动作;
- 浏览器再把执行的动作结果通过浏览器驱动程序返回给测试脚本。
十
你的自动化框架结构是怎么样的?
搭建的自动化测试框架采用分层设计模型框架,主要分为以下几个模块:
- common:一些基础的底层方法类,例如:测试报告类、数据配置读取类、日志类、封装webdriver类、数据库连接类、发送邮件类、公共方法类,只要是我们想要实现的一些功能,可以把基础方法的实现放在common文件夹。
- config:配置文件放在这里,比如:账号密码、数据库连接地址等。
- log:运行用例后,日志的存储文件夹。
- report:运行用例后,测试报告的存储文件夹。
- page:在POM设计模式下,关于具体UI页面操作的方法。
- test_case:具体存放编写的测试用例。
- run_all:用来批量运行测试用例。
以上
That‘s all