⾃动化测试⾯试题及答案
1、你会封装⾃动化测试框架吗?
这个问得最多,甚⾄有很多公司直接写在招聘要求中!
当然可以,⾃动化框架主要的核⼼框架就是分层+PO模式:分别为:基础封装层BasePage,PO页⾯对象层,TestCase测试⽤例层。然后再加上⽇志处理模块,ini配置⽂件读取模块,unittest+ddt数据驱动模块,jenkins持续集成模式组成。
2、如何把⾃动化测试在公司中实施并推⼴起来的?
1.项⽬组调研选择⾃动化⼯具并开会演⽰demo案例,我们主要是演⽰selenium和robotframework两种;
2.搭建⾃动化测试框架,在项⽬中逐步开展⾃动化;
3.把该项⽬的⾃动化流程、框架固化成⽂档;
4.推⼴到公司的其它项⽬组应⽤。
3、请描述⼀下⾃动化测试流程?
1.编写⾃动化测试计划;
2.设计⾃动化测试⽤例;
3.编写⾃动化测试框架和脚本;
4.调试并维护脚本;
c语言字符串与指针5.⽆⼈值守测试;
6.后期脚本维护(添加⽤例、开发更新版本)。
4、⾃动化测试⽤例如何编写?以下答案⼆选⼀即可:
1.⽤例是⾃动化测试⼯程师⾃⼰设计的,⼀般刚开始已基本业务流程为主(登录--完成⼀个业务--退出);
2.从系统测试⽤例中进⾏筛选或由业务⼯程师提供。
5、上⼀个项⽬中⾃动化测试的执⾏策略?
上⼀个项⽬中是定时执⾏的,设置的执⾏时间是晚上12点,执⾏完毕后会⾃动发送邮件通知
6、⾃动化测试发现BUG多吗?
不多,因为之前项⽬组是把已经测试通过的基本功能再进⾏⾃动化脚本编写和在后续版本执⾏⾃动化测试,它主要是保证已经测试通过的功能在新版本更新后没有问题。
7、你觉得⾃动化测试的价值在哪⾥?你们公司为什么要做⾃动化测试?
引⽤⾃动化测试之后,能代替⼤量繁琐的回归测试⼯作,把业务测试⼈员解放出来,既⽽让业务测试⼈员把精⼒集中在复杂的业务功能模块上,⾃动化测试⼀般是对稳定下来的功能进⾏⾃动化,保证不会因为产品的更新导致之前稳定下来的功能出现BUG。
8、⾃动化测试有误报过bug吗?产⽣误报怎么办?
有误报过,有时候⾃动化测试报告中显⽰发现了bug,实际去通过⼿⼯测试去确认⼜不存在该bug。
误报原因⼀般是:
1.元素定位不稳定,需要尽量提⾼脚本的稳定性;
2.开发更新了页⾯但是测试没有及时更新维护!
9、⾃动化测试过程中,你遇到了哪些问题,是如何解决的?
1.频繁地变更页⾯,经常要修改页⾯对象类⾥⾯的代码;
2.⾃动化测试偶尔出现过误报;
3.⾃动化测试结果出现覆盖的情况:Jenkins根据时间建⽴⽂件夹;
4.⾃动化测试代码维护⽐较⿇烦;
5.⾃动化测试进⾏数据库对⽐数据。
10、在上⼀家公司做⾃动化测试⽤的什么框架?
可以说出以下⾃⼰擅长的⼀种:
1.python+selenium+unittest+htmltestrunner
2.python+selenium+pytest+allure
3. robotframework+Selenium2Library
12、在selenium⾃动化测试中,你⼀般完成什么类型的测试?⾃动化覆盖率?
主要是冒烟测试和回归测试。回归测试主要写⼀些功能稳定的场景,通过⾃动化⼿段去实现,节约测试时间。因为⾃动化测试⽤例也是在不断的更新和迭代,没有刻意去统计,⼤概在30%-40%左右!
13、在执⾏脚本过程,如何实现当前元素⾼亮显⽰?
这个其实就是利⽤javaScript去修改当前元素的边框样式来到达⾼亮显⽰的效果。
14、如果⼀个元素⽆法定位,你⼀般会考虑哪些⽅⾯的原因?
1.页⾯加载元素过慢,加等待时间;
2.页⾯有frame框架页,需要先跳转⼊frame框架再定位;sqlserver创建唯一索引
3.可能该元素是动态元素,定位⽅式要优化,可以使⽤部分元素定位或通过⽗节点或兄弟节点定位;
4.可能识别了元素,但是不能操作,⽐如元素不可⽤,不可写等。需要使⽤js先把前置的操作完成。
15、元素定位⽅法你熟悉的有哪些?
pushed
id name classname link_text css xpath
16、遇到frame框架页⾯怎么处理?
先⽤driver.switch_to.frame()跳转进去frame,
然后再操作页⾯元素,
操作完后使⽤driver.swith_to.default_content()跳转出来。
17、遇到alert弹出窗如何处理?
使⽤driver.switch_to.alert⽅法先跳转到alert弹出窗⼝,
然后再通过accept点击确定按钮,通过dismiss点击取消难,通过text()获得弹出窗⼝的⽂本。
18、在selenium中如何处理多窗⼝?
这个多窗⼝之间跳转处理,我们在项⽬中也经常遇到。就是,当你点击⼀个链接,这个链接会在⼀个新的tab打开,然后你接下来要在新tab 打开的页⾯查元素,
index for index是什么意思1.我们在点击链接前使⽤driver.current_window_handle获得当前窗⼝句柄;
2.再点击链接。点击后通过driver.window_handles获得所有窗⼝的句柄;
3.然后再循环到新窗⼝的句柄,然后再通过driver.switch_to.window()⽅法跳转到新的窗⼝。
19、怎么验证元素是enable/disabled/checked状态?
定位元素后:分别通过isEnabled(),isSelected(),isDisplayed()三个⽅法进⾏判断。
20、如何处理下拉菜单?
在Selenium中有⼀个叫Select的类,这个类⽀持对下拉菜单进⾏操作。使⽤⽅法如下:
1.定位元素
2.把定位的元素转化成Select对象。
sel = Select(定位的元素对象)web前端基础面试题
3.通过下标或者值或者⽂本选中下拉框。
sel.select_by_index(index);
sel.select_by_value(value);
sel.select_by_visible_text(text);
21、在⽇历这种web 表单你是如何处理的?
⾸先要分析当前⽹页试⽤⽇历插件的前端代码,看看能不能通过元素定位,点击⽇期实现,如果不能,可能需要借助javascript。还有些⽇历控件⼀个⽂本输⼊框,可以直接sendKeys()⽅法来实现传⼊⼀个时间的数据。
22、举例⼀下说明⼀下你遇到过那些异常
常见的selenium异常有这些:
NoSuchElementException:没有该元素异常
TimeoutException :超时异常
ElementNotVisibleException :元素不可见异常
NoSuchAttributeException :没有这样属性异常
NoSuchFrameException :没有该frame异常
23、关闭浏览器中quit和close的区别
简单来说,两个都可以实现退出浏览器session功能,close是关闭你当前聚焦的tab页⾯,⽽quit是关闭全部浏览器tab页⾯,并退出浏览器session。知道这两个区别,我们就知道quit⼀般⽤在结束测试之前的操作,close⽤在执⾏⽤例过程中关闭某⼀个页⾯的操作。
24、在Selenium中如何实现截图,如何实现⽤例执⾏失败才截图?
在Selenium中提供了⼀个get_screenshot_as_file()的⽅法来截图的,⼀般结合try/except捕获异常时使⽤,进⾏错误截图。
25、如何实现⽂件上传?
定位元素后,直接使⽤send_keys()⽅法设置就⾏,参数为需要上传的⽂件的路径。
26、⾃动化中有哪三类等待?他们有什么特点?
1.线程等待(强制等待)如time.sleep(2):线程强制休眠2秒钟,2秒过后,再执⾏后续的代码。建议少⽤。
2.imlicitlyWait(隐式等待)会在指定的时间范围内不断的查元素,直到到元素或超时,特点是必须等待整个页⾯加载完成。
3.WebDriverWait(显式等待)通常是我们⾃定义的⼀个函数代码,这段代码⽤来等待某个元素加载完成,再继续执⾏后续的代码。
27、你写的测试脚本能在不同浏览器上运⾏吗?
当然可以,我写的⽤例可以在在IE,⽕狐和⾕歌这三种浏览器上运⾏。实现的思路是封装⼀个⽅法,分别传⼊⼀个浏览器的字符串,如果传⼊IE就使⽤IE,如果传⼊FireFox就使⽤FireFox,如果传⼊Chrome就使⽤Chrome浏览器,并且使⽤什么浏览器可以在总的ini配置⽂件中进⾏配置。需要注意的是每个浏览器使⽤的驱动不⼀样。
28、什么是PO模式,为什么要使⽤它?
PO是Page Object 模式的简称,它是⼀种设计思想,意思是,把⼀个页⾯,当做⼀个对象,页⾯的元素和元素之间操作⽅法就是页⾯对象的属性和⾏为,PO模式⼀般使⽤三层架构,分别为:基础封装层BasePage,PO页⾯对象层,TestCase测试⽤例层。
29.在Selenium中如何实现拖拽滚动条?
在Selenium中通过元素定位会⾃动帮你拖拽到对应位置,所以是没有⾃带的scoll⽅法。但是这个是有限制,例如当前页⾯⾼度太长,默认是页上半部分,你定位的元素在页尾,这个时候可能就会报元素不可见的异常。我们就需要利⽤javaScript来实现拖拽页⾯滚动条。
我们⼀般可以两个⽅法去拖拽,⼀个是根据拖拽的坐标(像素单位),另外⼀个是根据拖拽到⼀个参考元素附件。
代码举例(根据元素坐标拖拽):
JavascriptExecutor jse= (JavascriptExecutor)driver;
30.如何实现⿏标悬停,键盘事件和拖拽动作?
在Webdriver中,处理键盘事件和⿏标事件,⼀般使⽤Actions类提供的⽅法,包括⿏标悬停,拖拽和组合键输⼊。
这⾥介绍⼏个⽅法:
⽅法:clickAndHold()
使⽤场景:到⼀个元素,点击⿏标左键,不放⼿。⾃⼰可以点击⿏标不松开试试这个场景。
⽅法:contentClick()
使⽤场景:模拟⿏标右键点击,⼀般右键会带出菜单来。
⽅法:doubelClick()
使⽤场景:模拟⿏标双击
⽅法:dragAndDrop(source,target)
使⽤场景:模拟从source这个位置,拖拽⼀个元素到target位置
键盘事件⽅法:keyDown(keys.ALT), keyUp(keys.SHIFT)
使⽤场景:点击键盘事件,分为两个动作,⼀个点击键盘,第⼆个动作是释放点击(松开)
31.如何获取页⾯标题,悬浮⽂本和错误⽂本,并验证?
标题,我们可以通过Title()⽅法来得到⼀个字符串,然后使⽤字符串的containts⽅法或者equals⽅法去进⾏断⾔。
悬浮⽂本(tooltip),⼀般是利⽤Actions类,然后⿏标悬停⽅法,然后通过getText()⽅法来得到这个tooltip字符串。
错误信息,直接把这个错误字段先进⾏定位,然后通过getText()⽅法拿到错误⽂本,主要的断⾔有包含,相等,不相等,不包含,以什么开头等。
32.你是如何管理你的测试⽤例并执⾏?
写⽤例和管理并执⾏⽤例,我们都需要借助单元测试框架来实现,如果是Java语⾔⼀般有junit和TestNG,如果是python,常见的有
unittest。
就你实际情况,说⼀下。例如我使⽤TestNG⽐较多,需要配置l⽂件来实现测试⽤例的执⾏。有时候需要配置多个l去实现不同的任务场景。再展开,可能问你⼀下testng框架的知识点。例如,⽅法依赖,⽤例执⾏优先级,数据源驱动等。
33.关于⾃动化测试报告⽣成?
我个⼈⼀般⽤TestNG原⽣的测试报告,也有第三⽅叫reportNG的插件,不过我没有实际使⽤过。
34.什么是数据驱动框架?它与关键字驱动框架有什么不同?
keygen标签到底干嘛用的数据驱动框架。
在这个框架中,测试⽤例逻辑驻留在测试脚本中。测试数据被分离并保存在测试脚本之外。测试数据是从外部⽂件(Excel⽂件)中读取的,并被加载到测试脚本中的变量中。变量⽤于输⼊值和验证值。
关键字驱动。
关键字/表驱动框架需要开发数据表和关键字。它们独⽴于执⾏它们的测试⾃动化⼯具。可以使⽤或不使⽤应⽤程序来设计测试。在关键字驱动的测试中,被测试的应⽤程序的功能记录在⼀个表格中,以及每个测试的分步说明。
35.解释使⽤TestNG⽽不是JUnit框架的好处?
TestNG相较于Junit的优势:
在JUnit中,我们必须声明@BeforeClass和@AfterClass,这是JUnit中的⼀个约束,⽽在TestNG中没有像这样的约束。
TestNG提供了更多的setUp / tearDown级别。1.@ Before/AfterSuite 2.@Before/AfterTest 3.@Before/AfterGroup
TestNG中不需要扩展任何类。
TestNG中没有⽅法名称约束,就像JUnit⼀样。
在TestNG中,我们可以告诉测试⼀个⽅法依赖于另⼀个⽅法,⽽在JUnit中这是不可能的。
测试⽤例的分组在TestNG中可⽤,⽽JUnit中则不可⽤。执⾏可以基于组完成。例如,如果你已经定义了许多案例,并通过将2个组分别定义为“离职“与”回归”隔离。如果你只是想执⾏“理智”的情况,那就告诉TestNG执⾏“理智”。TestNG将⾃动执⾏属于“离职”组的案例。另
外,TestNG⽀持并⾏测试⽤例执⾏。
36.可以使⽤TestNG运⾏⼀组测试⽤例吗?
是的,TestNG框架⽀持在测试组的帮助下执⾏多个测试⽤例。
它提供了以下选项来运⾏特定组中的测试⽤例。
如果想基于回归测试或冒烟测试等其中⼀个组来执⾏测试⽤例,那么:
@Test(groups = {“regression-tests”, “smoke-tests”})
37.如何提⾼selenium脚本的执⾏速度?
1、优化等待时间,使⽤WebDriverWait智能等待代替线性等待sleep和隐式等待imlicitlyWait
2、减少不必要的操作
3、在服务器允许的情况下,使⽤多线程实现并发执⾏测试⽤例
以上⾯试题均整理⾃⽹络,待吸收后再继续更新....

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