列举web自动化中常见的元素定位方式?
-
id:根据id来获取元素,返回单个元素,id值一般是唯一的;文章源自玩技e族-https://www.playezu.com/79750.html
-
name:根据元素的name属性定位;文章源自玩技e族-https://www.playezu.com/79750.html
-
tagname:根据元素的标签名定位;文章源自玩技e族-https://www.playezu.com/79750.html
-
classname:根据元素的样式class值定位;文章源自玩技e族-https://www.playezu.com/79750.html
-
linktext:根据超链接的文本值定位;文章源自玩技e族-https://www.playezu.com/79750.html
-
partiallinktext:根据超链接的部分文本值定位;文章源自玩技e族-https://www.playezu.com/79750.html
-
cssselector:css选择器定位;文章源自玩技e族-https://www.playezu.com/79750.html
-
xpath:通过元素的路径来定位;文章源自玩技e族-https://www.playezu.com/79750.html
简述你所知道的延时等待方式?
强制等待:也叫线程等待, 通过线程休眠的方式完成的等待,如等待5秒: thread sleep(5000),一般情况下不太使用强制等待,主要应用的场景在于不同系统交互的地方。文章源自玩技e族-https://www.playezu.com/79750.html
隐式等待:通过implicitly wait完成的延时等待,注意这种是针对全局设置的等待,如设置超时时间为10秒,使用了implicitlywait后,如果第一次没有找到元素,会在10秒之内不断循环去找元素,如果超过10秒还没有找到,则抛出异常,硬式等待比较智能,它可以通过全局配置,但是只能用于元素定位。文章源自玩技e族-https://www.playezu.com/79750.html
显式等待:也称为智能等待,针对指定元素定位指定等待时间,在指定时间范围内进行元素查找,找到元素则直接返回,如果在超时还没有找到元素,则抛出异常,显示等待是 selenium 当中比较灵活的一种等待方式,他的实现原理其实是通过 while 循环不停的尝试需要进行的操作。文章源自玩技e族-https://www.playezu.com/79750.html
如何模拟浏览器的前进和后退、刷新?
driver.navigate().forward();//前进
driver.navigate().refresh();//刷新
如果是input元素的文件上传,可以通过 selenium 当中的 send_keys 方式进行传递,但是这种方式局限性比较大,如果遇到像通过 js 调用的组件会有一些问题;这个时候就需要通过一些和系统交互的方式去完成上传操作,比如通过autoit,pywinauto 或者是pyautogui这些第三方库进行操作。文章源自玩技e族-https://www.playezu.com/79750.html
ui自动化测试用例如何设计?
ui自动化测试用例是从手工测试用例中提取出来的,跟手工测试用例相比,自动化测试用例更加注重用例的严谨性,选择用例的时候遵循以下原则:文章源自玩技e族-https://www.playezu.com/79750.html
-
优先选取覆盖产品核心功能的用例;文章源自玩技e族-https://www.playezu.com/79750.html
-
从成本考量,不要选择流程过于复杂的用例;文章源自玩技e族-https://www.playezu.com/79750.html
-
选取的用例可以是重复执行,繁琐的部分,比如字段验证、提示信息验证;文章源自玩技e族-https://www.playezu.com/79750.html
-
优先实现正向的测试用例,反向用例一般情况复杂、数量多;文章源自玩技e族-https://www.playezu.com/79750.html
什么是po模式?
po模式,全称为page object model ,简称pom,是页面对象模式。对页面进行抽象或者说建模的过程,是把一个具体的页面转化为编程语言当中的一个对象,页面特性转化成对象属性,页面操作转化为对象方法。把页面的一个个的web元素设计为页面对象的属性,把页面上的操作(如点击、输入等)设计为页面对象的行为。在自动化测试当中,主要用来实现对页面操作和测试逻辑的一个分离,这样做的好处是业务和实现分开,使自动化测试脚本具备更高的可维护性。文章源自玩技e族-https://www.playezu.com/79750.html
你认为po模式的封装原则有哪些?
-
公共方法表示页面提供的一个服务,比如我们可以把登录封装成一个 login 方法,把搜索方法封装成一个设施方法,把注册操作封装成一个 register 的方法;文章源自玩技e族-https://www.playezu.com/79750.html
-
尽量不要暴露页面的内部,比如一个html的页面还有一个页面的上下结构;文章源自玩技e族-https://www.playezu.com/79750.html
-
在 po 当中一般不做断言,会做到页面逻辑和测试逻辑的分离;文章源自玩技e族-https://www.playezu.com/79750.html
-
po 一般里面的方法返回 self 或者是其他的 page object ,也可以是一个元素属性;文章源自玩技e族-https://www.playezu.com/79750.html
-
整个 po 不需要封装整个页面的行为,用到什么逻辑就封装什么;文章源自玩技e族-https://www.playezu.com/79750.html
-
对于统一操作,如果出现不同的结果,可以把用不同的方法来表示,比如说登录成功有跳转,登录失败有报错,如果登录还有一种会授权的状况,那么可以封装成三个单独的方法:login success、login error、login invalid。文章源自玩技e族-https://www.playezu.com/79750.html
你怎么提高ui自动化脚本的稳定性?
-
尽量用相对路径的xpath表达式;文章源自玩技e族-https://www.playezu.com/79750.html
-
查找元素优先用显示等待;文章源自玩技e族-https://www.playezu.com/79750.html
-
用例与用例之间尽量避免产生依赖,用例可以独立执行;文章源自玩技e族-https://www.playezu.com/79750.html
-
用例执行结束后对测试场景进行还原,避免影响其他用例的执行;文章源自玩技e族-https://www.playezu.com/79750.html
-
脚本执行失败后加入重试机制,提升用例的稳定性;文章源自玩技e族-https://www.playezu.com/79750.html
-
尽量保证单独的测试环境,避免其他的测试同步进行;文章源自玩技e族-https://www.playezu.com/79750.html
基于web端如何做自动化测试,谈谈你的思路和方向?
ui 自动化测试中,如何做集群?
-
selenium grid,分布式执行用例; -
appium 使用 stf 管理多设备; -
docker k8s 管理集群;
免责声明:本文内容来自用户上传并发布或网络新闻客户端自媒体,玩技博客仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系删除。
评论