面试真题 | 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);

}

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

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

相关推荐
雪落满地香1 小时前
css:圆角边框渐变色
前端·css
风无雨3 小时前
react antd 项目报错Warning: Each child in a list should have a unique “key“prop
前端·react.js·前端框架
人无远虑必有近忧!3 小时前
video标签播放mp4格式视频只有声音没有图像的问题
前端·video
无情白7 小时前
k8s运维面试总结(持续更新)
运维·面试·kubernetes
ylfhpy7 小时前
Java面试黄金宝典33
java·开发语言·数据结构·面试·职场和发展·排序算法
安分小尧8 小时前
React 文件上传新玩法:Aliyun OSS 加持的智能上传组件
前端·react.js·前端框架
编程社区管理员8 小时前
React安装使用教程
前端·react.js·前端框架
拉不动的猪8 小时前
vue自定义指令的几个注意点
前端·javascript·vue.js
yanyu-yaya8 小时前
react redux的学习,单个reducer
前端·javascript·react.js
skywalk81638 小时前
OpenRouter开源的AI大模型路由工具,统一API调用
服务器·前端·人工智能·openrouter