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

}

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

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

相关推荐
吕彬-前端41 分钟前
使用vite+react+ts+Ant Design开发后台管理项目(五)
前端·javascript·react.js
学前端的小朱44 分钟前
Redux的简介及其在React中的应用
前端·javascript·react.js·redux·store
guai_guai_guai1 小时前
uniapp
前端·javascript·vue.js·uni-app
Tassel_YUE1 小时前
网络自动化04:python实现ACL匹配信息(主机与主机信息)
网络·python·自动化
bysking2 小时前
【前端-组件】定义行分组的表格表单实现-bysking
前端·react.js
独行soc2 小时前
#渗透测试#SRC漏洞挖掘#深入挖掘XSS漏洞02之测试流程
web安全·面试·渗透测试·xss·漏洞挖掘·1024程序员节
王哲晓2 小时前
第三十章 章节练习商品列表组件封装
前端·javascript·vue.js
fg_4112 小时前
无网络安装ionic和运行
前端·npm
理想不理想v2 小时前
‌Vue 3相比Vue 2的主要改进‌?
前端·javascript·vue.js·面试
酷酷的阿云2 小时前
不用ECharts!从0到1徒手撸一个Vue3柱状图
前端·javascript·vue.js