面试真题 | web自动化关闭浏览器,quit()和close()的区别

面试官问:在UI自动化中怎样进行浏览器的关闭操作?使用driver调用quit()和调用close()的区别是什么?

考察点

  • 是否用过Selenium框架

  • 是否编写过对应浏览器退出的测试用例

技术点

  • Selenium API

  • driver.quit()

  • driver.close()

总结

quit()
  • 退出当前所有的窗口;
close()
  • 关闭当前的标签页,其他窗口不退出

关闭所有的浏览器窗口,销毁driver操作,则需要使用的是quit方法;当打开了多个窗口,只想要关闭非最后一个窗口的时候,使用的是close方法。

演示代码

quit()

quit():所有的浏览器窗口退出

复制代码
python 复制代码
@Test

public void quit() throws InterruptedException {

WebDriver webDriver = WebDriverManager.chromedriver().create();

webDriver.get("https://www.baidu.com/");

webDriver.findElement(By.linkText("新闻")).click();

sleep(5000);

//输出当前的窗口

Set<String> windowHandles = webDriver.getWindowHandles();

System.out.println(windowHandles);

sleep(3000);

//切换到第一个窗口

webDriver.switchTo().window(windowHandles.stream().findFirst().get());


sleep(2000);

System.out.println(webDriver.getWindowHandle());

//Quits this driver, closing every associated window.

webDriver.quit();

sleep(6000);


}

close()

close():只关闭当前的浏览器标签页,如果当前浏览器标签页剩下最后一个,则所有标签页面退出

复制代码
python 复制代码
@Test

public void close() throws InterruptedException {

WebDriver webDriver = WebDriverManager.chromedriver().create();

webDriver.get("https://www.baidu.com/");

String mainHandle = webDriver.getWindowHandle();

webDriver.findElement(By.linkText("新闻")).click();

sleep(2000);

//切换到第一个窗口

webDriver.switchTo().window(mainHandle);

sleep(2000);

webDriver.findElement(By.linkText("图片")).click();

sleep(2000);

webDriver.close();//关闭第一个窗口

System.out.println("浏览器关闭第一个窗口");

sleep(6000);

//切换到最后一个窗口关闭

Set<String> handles = webDriver.getWindowHandles();

ArrayList<String> hanleList = new ArrayList<>(handles);

String endHandle = hanleList.get(hanleList.size() - 2);

webDriver.switchTo().window(endHandle);

sleep(2000);

webDriver.close();

System.out.println("浏览器关闭最后一个标签页");

sleep(6000);

}

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关推荐
J***Q29220 小时前
Vue数据可视化
前端·vue.js·信息可视化
ttod_qzstudio1 天前
深入理解 Vue 3 的 h 函数:构建动态 UI 的利器
前端·vue.js
_大龄1 天前
前端解析excel
前端·excel
喵手1 天前
AI在自动化与机器人技术中的前沿应用
人工智能·机器人·自动化
一叶茶1 天前
移动端平板打开的三种模式。
前端·javascript
前端大卫1 天前
一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】
前端
Want5951 天前
HTML音乐圣诞树
前端·html
老前端的功夫1 天前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
Running_slave1 天前
你应该了解的TCP滑窗
前端·网络协议·tcp/ip
程序员小寒1 天前
前端高频面试题之CSS篇(一)
前端·css·面试·css3