2024UI自动化面试题汇总【建议收藏】

1110 篇文章 11 订阅
394 篇文章 7 订阅

1.你是如何搭建ui自动化框架的?

  在搭建ui自动化框架,使用的是po设计模式,也就是把每一个页面所需要

  操作的元素和步骤都封装成一个页面类中。然后使用selenium+unittest搭建

  四层框架实现数据、脚本、业务逻辑分离(关键字驱动)。其中四层框架包括

  基础层(BasePage)、业务逻辑层(Pages)、数据层(Data)、测试用例层(Testcase)

  1.基础层(BasePage)

  设计一个基本的Page类,所有页面皆继承该类。提供一个页面需要实现的基本功能及公共方法。

  2.业务逻辑层(Pages)

  按照PO设计模式,将每个页面抽象为一个类,放在Pages包里面,每个页面继承Basepage,可调用Data层数据,包括页面所有的操作对象属性和实现的功能

  3.数据层(Data)

  该层存放相关数据,例如:用户数据和密码。在测试用例可通过调用数层的数据来进行操作。

  4.测试用例层(Testcases)

  每一个测试用例testcase都对应Pages里面的一个页面,继承unnitest.TestCase类

  通过调用对应页面类的方法,数据层的数据、增加断言(assert)来验证功能的正确性。

  此外通过Jenkins自动执行测试、代码质量检测和部署到测试服务器、部署到生产服务器上

2.UI自动化测试中定位方式有哪些,哪些是你常用的?

  By ID

  By Class Name

  By Tag Name

  By Name

  By Link Text

  By Partial Link Textzhi

  By CSS Seletor

  By XPath

3.UI自动化测试有哪些缺点?如何改进?

  不稳定,页面经常变,不好定位,不适合业务复杂和频繁变动的项目

  改进:在项目中尽量使用显示等待

4.请你描述一下在UI自动化运用的等待机制区别?

  sleep()强制等待,设置固定休眠时间,执行sleep()后线程休眠

  而另外两种线程不休眠

  隐式等待,是设置的全局等待

  显示等待,是针对于某个特定的元素设置的等待时间

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】

5.PO设计模式的原理?哪些地方能够改善?

  原理:

  PO模式,全称 Page object ,页面对象模型。

  将页面的元素定位和元素行为封装成一个 page 类。

  实现页面对象和测试用例分离。

  改善:

  其中对对象库层、逻辑层、业务层进行了一系列封装

6.Unittest框架有什么缺点?

  1 不够灵活,比如进行 ui 自动化设计时,会多次打开浏览器,增加脚本运行时间

  2 测试报告不够全面,没有 pytest 的 allure 测试报告清晰美观

7.Webdriver的原理

  由于客户端脚本(java, python, ruby)不能直接与浏览器通信,这时候可以把Webdriver 当做一个翻译器,它可以把客户端代码翻译成浏览器可以识别的代码(比如js).客户端(也就是测试脚本)创建 1 个 session,在该 session 中通过 http 请求向Webdriver 发送请求,Webdriver 翻译成浏览器懂得脚本传给浏览器,浏览器把执行的结果返回给 Webdriver,Webdriver 把返回的结果做了一些封装(一般都是 json 格式),然后返回给客户端,根据返回值就能判断对浏览器的操作是不是执行成功。

8.selenium 中 hidden 或者是 display = none 的元素是否可以定位到?

  不能

9.如何提高 selenium 脚本的执行速度?

  1减少操作步骤,减少脚本用例不必要的步骤

  2设置等待时间的时候,可以

  sleep 固定的时间,也可以检测某个元素出现后中断等待也可

  以提高速度

  3实现多线程。在编写测试用例的时候,一定要实现松耦合,然后在服务器允许的情况下,

  尽量设置多线程运行,提高执行速度。

 10.如何实现多线程?

  先写一个run的函数

  保证for循环能跑的通

  在run函数上加个装饰器 @threads(n),n是线程数

 11.说一下XPATH定位的原理?

  基于HTML的文档目录结构进行定位元素

 12.selenium中如何判断元素一定存在?

  Presense_of_element_located

  强制等待、隐性等待、显性等待

  1.强制等待--固定等待一段时间,即使设置一定的等待时间,也不能确保一定能够定位到元素,因为你无法知道页面加载的时间,而且这种方法通常比较浪费脚本执行时间,效率低

  2.隐性等待--设置最长的等待时间,在这个时间内,当元素被加载出现在dom树中且页面被完全加载完成之后,才执行下一步操作,保证了脚本的稳定性,但执行效率相对较低,因为往往我们只需要目标元素出现即可,并不需要挣个页面加载完成,而隐性等待要等待挣个页面加载完才能执行下一步,浪费一定时间,那么为了解决这种弊端又引入了显示等待。

  3.显示等待--显示等待实现方式通过判断某一个条件是否成立,如果成立就立即执行下一步操作,不需要等待页面加载完成,执行效率高,脚本的稳定性也相对较高

selenium原理

  我们使用Selenium实现自动化测试,主要需要3个东西

  1.测试脚本,可以是python,java编写的脚本程序(也可以叫做client端)

  2.浏览器驱动,这个驱动是根据不同的浏览器开发的,不同的浏览器使用不同的webdriver驱动程序且需要对应相应的浏览器版本

  3.浏览器,目前selenium支持市面上大多数浏览器,不同的浏览器使用不同的webdriver驱动程序且需要对应的浏览器版本

selenium工作过程

  1.selenium client(python等语言编写的自动化测试脚本)初始化一个service服务,通过webdriver启动浏览器驱动程序chromedriver.exe

  2.通过RemoteWebDriver向浏览器驱动程序发送HTTP请求,浏览器驱动程序解析请求,打开浏览器,并获得sessionid,如果再对浏览器操作需携带此id

  3.打开浏览器后,所有的selenium的操作(访问地址,查找元素)均通过RemoteConection链接到remote server,

  然后使用execute方法调用request方法通过urlib3向remote server请求

  4.浏览器通过请求的内容执行对应动作

  5.浏览器再把执行的动作结果通过浏览器驱动程序返回给测试脚本

下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

最后: 可以在公众号:程序员小濠 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值