selenium⾃动化测试⾯试题及答案
1、selenium中如何判断元素是否存在?
- isElementPresent
2、selenium中hidden或者是display = none的元素是否可以定位到?
- 不能
3、selenium中如何保证操作元素的成功率?也就是说如何保证我点击的元素⼀定是可以点击的?
- 添加元素智能等待时间 driver.implicitly_wait(30)
- try ⽅式进⾏ id,name,clas,x path, css selector 不同⽅式进⾏定位,如果第⼀种失败可以⾃动尝试第⼆种
-Selenium保证元素成功率是通过元素的定位,当然它的定位⽅法很多,⼀定能有合适的。但是在⾃动化⼯程的实施过程中,⾼质量的⾃动化测试不是只有测试⼈员保证的。需要开发⼈员规范开发习惯,如给页⾯元素加上唯⼀的name,id等,这样就能⼤⼤地提⾼元素定位的准确性。当然如果开发⼈员开发
不规范,我们在定位元素的时候尽量使⽤相对地址定位,这样能减少元素定位受页⾯变化的影响。只要我们元素定位准确,就能保证我的每⼀个操作符合我的预期
4、如何提⾼selenium脚本的执⾏速度?
- Selenium脚本的执⾏速度受多⽅⾯因素的影响,如⽹速,操作步骤的繁琐程度,页⾯加载的速度,以及我们在脚本中设置的等待时间,运⾏脚本的线程数等。所以不能单⽅⾯追求运⾏速度的,要确保稳定性,能稳定地实现回归测试才是关键。
我们可以从以下⼏个⽅⾯来提⾼速度:
⼀,减少操作步骤,如经过三四步才能打开我们要测试的页⾯的话,我们就可以直接通过⽹址来打开,减少不必要的操作。
⼆,中断页⾯加载,如果页⾯加载的内容过多,我们可以查看⼀下加载慢的原因,如果加载的内容不影响我们测试,就设置超时时间,中断页⾯加载。
三,在设置等待时间的时候,可以sleep固定的时间,也可以检测某个元素出现后中断等待也可以提⾼速度。
四,配置testNG实现多线程。在编写测试⽤例的时候,⼀定要实现松耦合,然后在服务器允许的情况下,尽量设置多线程运⾏,提⾼执⾏速度。新手用英语怎么读
5、⽤例在运⾏过程中经常会出现不稳定的情况,也就是说这次可以通过,下次就没办法通过了,如何去提升⽤例的稳定性?
- time.sleep( )
- driver.implicitly_wait(30)
- 多⽤ try 捕捉,处理异常
-此时我们要分析出不稳定的原因,然后有针对性的去解决问题。主要有以下⼏个⽅⾯ :
⼀,⽹速问题:有的时候⽹页加载的⽐较慢,在程序执⾏的时候要操作的元素没有显⽰出来。这种情况⽐较常见,运⾏⼀次⽹速好的时候通过了,再运⾏⼀次,页⾯没有打开,就不通过了。为了提⾼稳定性,我们只能牺牲运⾏时间了,在经常检测失败的元素前加上等待时间,等要操作的元素出现之后再执⾏下⾯的操作。
⼆,Selelnium的原因:Selenium1.0和2.0还是有区别的,有些⼉函数在2.0下运⾏确实有时⽽有效,时⾯⽆效。如果mouseover()函数,就是这种情况, 我们需要避免使⽤这类的函数。
三,多线程的时候,测试⽤例间相互影响。虽然多线程的时候运⾏速度⽐较快,但是如果⽤例之间的耦合性没有设计好,也会影响的,如果⽤例A先于⽤例B执⾏的时候,就会影响到⽤例B;反之则没有问题。这种情况,如果你的⾃动化测试⼯程打算多线程的时候,提前就要把测试⽤例测试的耦合度⽐较松,尽量没有任何关系,因为多线程的执⾏顺序是不受控制的。
6、你的⾃动化⽤例的执⾏策略是什么?
- ⾃动化测试⽤例的执⾏策略是要看⾃动化测试的⽬的,通常有如下⼏种策略:
⼀,⾃动化测试⽤例是⽤来监控的,在此⽬的下,我们就把⾃动化测试⽤例设置成定时执⾏的,如果每五分钟或是⼀个⼩时执⾏⼀次,在jenkins上创建⼀个定时任务即可。
⼆,必须回归的⽤例。有些⼉测试⽤例,如BVT测试⽤例,我们在公司产品任何变动上线之前都需要回归执⾏。那我们就把测试⽤例设置成触发式执⾏,在jenkins上将我们的⾃动化测试任务绑定到开发的build任务上。当开发⼈员在仿真环境上部代码的时候,我们的⾃动化测试⽤例就会被触发执⾏。
三,不需要经常执⾏的测试⽤例。像全量测试⽤例,我们没有必要⼀直回归执⾏,必竟还是有时间消耗的,有些⾮主要业务线也不需要时时回归。这类测试⽤例我们就采⽤⼈⼯执⾏,在jenkins创建⼀个任务,需要执⾏的时候⼈⼯去构建即可。
7、什么是持续集成?
- 持续集成源于极限编程(XP),是⼀种软件实践,软件开发过程中集成步骤是⼀个漫长并且⽆法预测的过程。集成过程中可能会爆发⼤量的问题,因此集成过程需要尽可能⼩⽽多,实际上持续集成讲的是不断的去做软件的集成⼯作。持续集成,最简单的形式是包括⼀个监控版本控制(SVN等等)变化的⼯具。当变化被发觉时,这个⼯具可以⾃动的编译并测试你的应⽤。
8、⾃动化测试的时候是不是需要连接数据库做数据校验?
- UI⾃动化不需要
- 接⼝测试会需要
9、id,name,class,xpath, css selector这些属性,你最偏爱哪⼀种,为什么?
- css 、xpath ⼏乎所有的元素都可以定位到
10、如何去定位页⾯上动态加载的元素?
- 触发动态加载元素的事件,直⾄动态元素出现,进⾏定位
11、如何去定位属性动态变化的元素?
- xpath或者css通过同级、⽗级、⼦级进⾏定位
12、点击链接以后,selenium是否会⾃动等待该页⾯加载完毕?
- 会的
13、webdriver client的原理是什么?
通过研究selenium-webdriver的源码,笔者发现其实webdriver的实现原理并不⾼深莫测⽆法揣度。在这⾥以webdriver ruby binding的firefox-webdriver实现为例,简单介绍⼀下webdriver的⼯作原理。
这就是webdriver的⼯作流程,看起来很复杂实际上当了解了webdriver的实现原理后,理解上述问题应该⽐较简单。
webdriver是按照server – client的经典设计模式设计的。
server端就是remote server,可以是任意的浏览器。当我们的脚本启动浏览器后,该浏览器就是remote server,它的职责就是等待client发送请求并做出相应;
client端简单说来就是我们的测试代码,我们测试代码中的⼀些⾏为,⽐如打开浏览器,转跳到特定的url等操作是以http请求的⽅式发送给被 测试浏览器,也就是remote server;remote server接受请求,并执⾏相应操作,并在response中返回执⾏状态、返回值等信息;
mysql面试题基础知识14、webdriver的协议是什么?
-The WebDriver Wire Protocol
15、启动浏览器的时候⽤到的是哪个webdriver协议?
-http
16、怎样去选择⼀个下拉框中的value=xx的option?
-⼆次定位
17、如何在定位元素后⾼亮元素(以调试为⽬的)?
-重置元素属性,给定位的元素加背景、边框
18、什么是断⾔?
-断⾔的英⽂是assertion,断⾔检查的英⽂是assertion checking。
-断⾔是指定⼀个程序必须已经存在的状态的⼀个逻辑表达式,或者⼀组程序变量在程序执⾏期间的某个点上必须满⾜的条件。
19、page object设置模式中,是否需要在page⾥定位的⽅法中加上断⾔?
-不需要
20、⾃动化测试⽤例从哪⾥来?
-⼿⼯⽤例中抽取
-可以参考⾃动化⽤例的执⾏策略
21、你觉得⾃动化测试最⼤的缺陷是什么?
-不稳定
-可靠性
-不易维护
-成本与收益
22、公司内⼀直在使⽤的测试系统(B/S架构)突然不能访问了,需要你进⾏排查并恢复,说出你的检查⽅法
答:⼀、⽹站输⼊域名直接⽆法访问,⽹站之前还正常,突然就⽆法访问
1. 测试FTP是否正常可以登录,不能登录的直接问空间商那是空间商的问题直接联系他们。
2. 空间赠送的三级域名是否能够访问⽹站打开⽹站(空间都赠送三级域名),如果也不能访问应该是空间问题。
3. 在电脑的开始菜单运⾏中输⼊cmd,在弹出的⿊框中输⼊:ping 你的域名;然后回车,如果看不到I
P或IP地址与你的主机地址不符,则说明域名解析有误,是域名的问题得重新解析域名。
4、访问报404错误(⽆法到该页)。说明是⽹站内容都正常是程序出现问题,看看程序是否完整。
5、访问⽹站出现MySQL Server Error 这个是数据库链接错误,查看数据库连接⽂件和数据库是不是错误。
6、访问⽹站出现500错误。
(1) 请登录FTP查看是否多了异常⽂件或丢失⽂件,说明⽹站被侵⼊了,马上联系⽹站制作进⾏进⾏排查故障。
(2) 如果空间且FTP程序⽬录没有缺失⽂件或刚刚安装就出现500错误,请确认空间已开启scandir()函数,查看是不是禁⽌了这个函数。
1、selenium中如何判断元素是否存在?
- isElementPresent汇编语言程序设计of
2、selenium中hidden或者是display = none的元素是否可以定位到?
-
不能
3、selenium中如何保证操作元素的成功率?也就是说如何保证我点击的元素⼀定是可以点击的?
sqlyog出现错误号码1045- 添加元素智能等待时间 driver.implicitly_wait(30)
- try ⽅式进⾏ id,name,clas,x path, css selector 不同⽅式进⾏定位,如果第⼀种失败可以⾃动尝试第⼆种
-Selenium保证元素成功率是通过元素的定位,当然它的定位⽅法很多,⼀定能有合适的。但是在⾃动化⼯程的实施过程中,⾼质量的⾃动化测试不是只有测试⼈员保证的。需要开发⼈员规范开发习惯,如给页⾯元素加上唯⼀的name,id等,这样就能⼤⼤地提⾼元素定位的准确性。当然如果开发⼈员开发不规范,我们在定位元素的时候尽量使⽤相对地址定位,这样能减少元素定位受页⾯变化的影响。只要我们元素定位准确,就能保证我的每⼀个操作符合我的预期
4、如何提⾼selenium脚本的执⾏速度?
- Selenium脚本的执⾏速度受多⽅⾯因素的影响,如⽹速,操作步骤的繁琐程度,页⾯加载的速度,以及我们在脚本中设置的等待时间,运⾏脚本的线程数等。所以不能单⽅⾯追求运⾏速度的,要确保稳定性,能稳定地实现回归测试才是关键。
我们可以从以下⼏个⽅⾯来提⾼速度:
⼀,减少操作步骤,如经过三四步才能打开我们要测试的页⾯的话,我们就可以直接通过⽹址来打开,减少不必要的操作。
undergraduate前面加a还是an
⼆,中断页⾯加载,如果页⾯加载的内容过多,我们可以查看⼀下加载慢的原因,如果加载的内容不影响我们测试,就设置超时时间,中断
页⾯加载。
三,在设置等待时间的时候,可以sleep固定的时间,也可以检测某个元素出现后中断等待也可以提⾼速度。
四,配置testNG实现多线程。在编写测试⽤例的时候,⼀定要实现松耦合,然后在服务器允许的情况下,尽量设置多线程运⾏,提⾼执⾏速度。
5、⽤例在运⾏过程中经常会出现不稳定的情况,也就是说这次可以通过,下次就没办法通过了,如何去提升⽤例的稳定性?
- time.sleep( )
- driver.implicitly_wait(30)
- 多⽤ try 捕捉,处理异常
-此时我们要分析出不稳定的原因,然后有针对性的去解决问题。主要有以下⼏个⽅⾯ :
⼀,⽹速问题:有的时候⽹页加载的⽐较慢,在程序执⾏的时候要操作的元素没有显⽰出来。这种情况⽐较常见,运⾏⼀次⽹速好的时候通过了,再运⾏⼀次,页⾯没有打开,就不通过了。为了提⾼稳定性,我们只能牺牲运⾏时间了,在经常检测失败的元素前加上等待时间,等要操作的元素出现之后再执⾏下⾯的操作。
⼆,Selelnium的原因:Selenium1.0和2.0还是有区别的,有些⼉函数在2.0下运⾏确实有时⽽有效,时⾯⽆效。如果mouseover()函数,就是这种情况, 我们需要避免使⽤这类的函数。
三,多线程的时候,测试⽤例间相互影响。虽然多线程的时候运⾏速度⽐较快,但是如果⽤例之间的耦合性没有设计好,也会影响的,如果⽤例A先于⽤例B执⾏的时候,就会影响到⽤例B;反之则没有问题。这种情况,如果你的⾃动化测试⼯程打算多线程的时候,提前就要把测试⽤例测试的耦合度⽐较松,尽量没有任何关系,因为多线程的执⾏顺序是不受控制的。
6、你的⾃动化⽤例的执⾏策略是什么?
- ⾃动化测试⽤例的执⾏策略是要看⾃动化测试的⽬的,通常有如下⼏种策略:
⼀,⾃动化测试⽤例是⽤来监控的,在此⽬的下,我们就把⾃动化测试⽤例设置成定时执⾏的,如果每五分钟或是⼀个⼩时执⾏⼀次,在jenkins上创建⼀个定时任务即可。
drop if exist⼆,必须回归的⽤例。有些⼉测试⽤例,如BVT测试⽤例,我们在公司产品任何变动上线之前都需要回归执⾏。那我们就把测试⽤例设置成触发式执⾏,在jenkins上将我们的⾃动化测试任务绑定到开发的build任务上。当开发⼈员在仿真环境上部代码的时候,我们的⾃动化测试⽤例就会被触发执⾏。
三,不需要经常执⾏的测试⽤例。像全量测试⽤例,我们没有必要⼀直回归执⾏,必竟还是有时间消耗的,有些⾮主要业务线也不需要时时回归。这类测试⽤例我们就采⽤⼈⼯执⾏,在jenkins创建⼀个任务,需要执⾏的时候⼈⼯去构建即可。
7、什么是持续集成?
- 持续集成源于极限编程(XP),是⼀种软件实践,软件开发过程中集成步骤是⼀个漫长并且⽆法预测的过程。集成过程中可能会爆发⼤量的问题,因此集成过程需要尽可能⼩⽽多,实际上持续集成讲的是不断的去做软件的集成⼯作。持续集成,最简单的形式是包括⼀个监控版本控制(SVN等等)变化的⼯具。当变化被发觉时,这个⼯具可以⾃动的编译并测试你的应⽤。
8、⾃动化测试的时候是不是需要连接数据库做数据校验?
- UI⾃动化不需要
- 接⼝测试会需要
9、id,name,class,xpath, css selector这些属性,你最偏爱哪⼀种,为什么?
- css 、xpath ⼏乎所有的元素都可以定位到
10、如何去定位页⾯上动态加载的元素?

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。