`

Selenium 处理 modal 对话框(转)

阅读更多
Selenium目前没有提供对IE模态对话框(即通过showModalDialog方法打开的弹出对话框)的处理。原因在于,模态对话框会将父页面的JS挂起,直至对话框处理完毕才会继续执行父页面JS。因为Selenium的底层实现是基于JS的,所以模态对话框会同时将selenium挂起,selenium无法选中模态对话框,直至超时。

但是很多系统往往有大量的模态对话框应用。这些应用分为两类:一类是选人、选业务类型等操作,这些操作的目的是填充父页面相应的字段,不会触发其他操作;另外一类比较特殊,例如工作流的派发,这类操作在模态对话框选人返回值后还会继续执行一系列的操作(即showModalDialog方法的调用被夹在一堆JS操作中间)。

对于第一种情况,可以在测试代码里建立相应的数据常量,通过直接赋值的方式避免调用showModalDialog方法;对于第二种情况,则只能hack。

在当前的测试用例里,采用以下的hack方法:
典型的模态对话框会在点击一个页面元素后打开(例如button),在第一次点击该页面元素时,我们对showModalDialog方法进行覆盖,改打开模态对话框为window.open打开网页,并将selenium选中该弹出网页:

Java代码 
1.public void clickAndSelectModalDialog(String locator){  
2.    clickForModalDialog(locator);  
3.     selenium.selectWindow(“name=modal”);  
4.}  
5. 
6.private void  clickForModalDialog(String locator){  
7.    String overrideShowModalDialogJs=="if(selenium.browserbot.getCurrentWindow().showModalDialog){";  
8. 
9.overrideShowModalDialogJs += "selenium.browserbot.getCurrentWindow().showModalDialog = function( sURL, vArguments, sFeatures)";  
10. 
11.overrideShowModalDialogJs +="selenium.browserbot.getCurrentWindow().open(sURL, 'modal', sFeatures);";  
12. 
13.overrideShowModalDialogJs += "};}";  
14.//showModalDialog方法进行覆盖  
15.selenium.getEval(overrideShowModalDialogJs);  
16.selenium.click(locator);  
17.selenium.openWindow(“”,”modal”);  
18.selenium.waitForPopUp(“modal”,”15000”);  
19. 
20.} 
public void clickAndSelectModalDialog(String locator){
    clickForModalDialog(locator);
     selenium.selectWindow(“name=modal”);
}

private void  clickForModalDialog(String locator){
    String overrideShowModalDialogJs=="if(selenium.browserbot.getCurrentWindow().showModalDialog){";

overrideShowModalDialogJs += "selenium.browserbot.getCurrentWindow().showModalDialog = function( sURL, vArguments, sFeatures)";

overrideShowModalDialogJs +="selenium.browserbot.getCurrentWindow().open(sURL, 'modal', sFeatures);";

overrideShowModalDialogJs += "};}";
//showModalDialog方法进行覆盖
selenium.getEval(overrideShowModalDialogJs);
selenium.click(locator);
selenium.openWindow(“”,”modal”);
selenium.waitForPopUp(“modal”,”15000”);




接下来就可以在弹出网页里进行操作,获取需要返回给父页面的值,这些值一般是一个数组。获取值后关闭弹出网页并返回父页面。在父页面里再次点击打开模态对话框的元素,对showModalDialog方法进行第二次覆盖,将上面获取的值直接返回。

Java代码 
1.public void  acceptModalValue(String locator,String[] values){  
2.    String overrideShowModalDialogJs=="if(selenium.browserbot.getCurrentWindow().showModalDialog){";  
3. 
4.overrideShowModalDialogJs += "selenium.browserbot.getCurrentWindow().showModalDialog = function( sURL, vArguments, sFeatures)";  
5. 
6.overrideShowModalDialogJs +="{ "+generateModalDialogReturnObject(values)+”return temp”;  
7. 
8.overrideShowModalDialogJs += "};}";  
9.//showModalDialog方法进行覆盖  
10.selenium.getEval(overrideShowModalDialogJs);  
11.selenium.click(locator);  
12.}  
13. 
14.private void  generateModalDialogReturnObject (String[] values){  
15.    StringBuffer returnObject=new StringBuffer();  
16.    returnObject.append(“var temp=new Array();”);  
17.    for(int i=0;i<values.length;i++){  
18.        returnObject.append(“temp[”+i+”]=’”+values[i]+”’;”);  
19.    }  
20.    return returnObject.toString();  
21.} 
public void  acceptModalValue(String locator,String[] values){
    String overrideShowModalDialogJs=="if(selenium.browserbot.getCurrentWindow().showModalDialog){";

overrideShowModalDialogJs += "selenium.browserbot.getCurrentWindow().showModalDialog = function( sURL, vArguments, sFeatures)";

overrideShowModalDialogJs +="{ "+generateModalDialogReturnObject(values)+”return temp”;

overrideShowModalDialogJs += "};}";
//showModalDialog方法进行覆盖
selenium.getEval(overrideShowModalDialogJs);
selenium.click(locator);
}

private void  generateModalDialogReturnObject (String[] values){
    StringBuffer returnObject=new StringBuffer();
    returnObject.append(“var temp=new Array();”);
    for(int i=0;i<values.length;i++){
        returnObject.append(“temp[”+i+”]=’”+values[i]+”’;”);
    }
    return returnObject.toString();



这样就完成了整个过程。看一个示例,该示例打开一个选部门的模态对话框,从部门树里选择部门,然后返回:

Java代码 
1.//点击后弹出部门选择框的图片  
2.String depChooseLocator=”…/img”;  
3.<SPAN style="COLOR: #000000">//点击并选中该弹出网页  
4.clickAndSelectModalDialog(depChooseLocator);</SPAN>  
5.//执行部门树的操作  
6.….  
7.//获取该对话框要返回给父页面的值  
8.String name=selenium.getEval(“window.seltree.GetAllCheckText();”);  
9.String id=selenium.getEval(“window.seltree.GetAllNodeId();”);  
10.<SPAN style="COLOR: #000000">//关闭部门选择对话框  
11.closeModalDialog();</SPAN>  
12.//返回父页面  
13.Selenium.selectWindow(“name=main95598”);  
14.//组装返回值  
15.String returnValues=new String[2];  
16.returnValues[0]=name;  
17.returnValues[1]=id;  
18.<SPAN style="COLOR: #000000">//父页面获取对话框返回值  
19.acceptModalValue(depChooseLocator, returnValues);</SPAN> 
//点击后弹出部门选择框的图片
String depChooseLocator=”…/img”;
//点击并选中该弹出网页
clickAndSelectModalDialog(depChooseLocator);
//执行部门树的操作
….
//获取该对话框要返回给父页面的值
String name=selenium.getEval(“window.seltree.GetAllCheckText();”);
String id=selenium.getEval(“window.seltree.GetAllNodeId();”);
//关闭部门选择对话框
closeModalDialog();
//返回父页面
Selenium.selectWindow(“name=main95598”);
//组装返回值
String returnValues=new String[2];
returnValues[0]=name;
returnValues[1]=id;
//父页面获取对话框返回值
acceptModalValue(depChooseLocator, returnValues); 


可以进一步抽象为模板回调方法,略。
分享到:
评论

相关推荐

    selenium处理模式对话框

    当我们谈论“selenium处理模式对话框”时,这里主要涉及的是如何通过Selenium来处理浏览器中出现的各种对话框,如警告、确认、输入等。 在Web应用程序中,有时会出现模态对话框,比如JavaScript弹出的确认框、警告...

    使用selenium测试showModalDialog模态对话框

    因此,当遇到类似问题时,建议评估其他自动化测试框架,如 Puppeteer 或 Cypress,它们可能提供更完善的对话框处理机制。同时,持续关注Selenium的更新,因为随着技术的发展,未来可能有更优的解决方案出现。

    selenium打印对话框操作函数

    通过此函数识别打印对话框“打印”按钮的位置,再通过 pyautogui.click(x,y)模拟点击即可操作打印对话框

    Selenium处理弹出窗口.docx

    分类:  对网页弹出窗口,如WIKI所述,若要保持脚本运行稳定,必须在... showModalDialog,同样实现的还有在文件selenium-browserbot.js函数BrowserBot.prototype._modifyWindow实现开始部分添加对ModalDialog的实现。

    java selenium操作弹出对话框示例讲解

    Java Selenium 是一个...总之,通过Java Selenium,我们可以有效地自动化处理Web应用中的JavaScript弹出对话框,模拟用户的各种交互行为,从而提高测试效率和质量。对于Web测试人员来说,掌握这些技能是至关重要的。

    搭建 springboot selenium 网页文件转图片环境的详细教程

    搭建 SpringBoot Selenium 网页文件转图片环境的详细教程 知识点1:环境准备 在搭建 SpringBoot Selenium 网页文件转图片环境前,需要准备好以下几个组件: * Chrome 浏览器:可以从官方网站下载,需要注意的是,...

    Selenium:Selenium处理弹出窗口与警告框.docx

    Selenium:Selenium处理弹出窗口与警告框.docx

    Selenium:使用Selenium处理表单与按钮的全面指南.docx

    Selenium:使用Selenium处理表单与按钮的全面指南.docx

    selenium-selenium-4.5.0.zip源码

    Selenium Server 主要用于处理浏览器的远程控制和代理功能,而 Selenium IDE 则是一个浏览器插件,用于录制和回放测试用例。 在 `selenium-selenium-4.5.0.zip` 源码中,我们可以深入理解 Selenium 的内部实现,...

    selenium selenium selenium selenium selenium selenium selenium selenium

    selenium selenium selenium selenium selenium selenium selenium selenium selenium selenium selenium selenium selenium selenium

    Selenium处理select标签的下拉框

    Selenium是一个开源的和便携式的自动化软件测试工具,用于测试Web应用程序有能力在不同的浏览器和操作系统运行。接下来通过本文给大家介绍Selenium处理select标签的下拉框,需要的朋友一起学习吧

    scrapy-selenium:Scrapy中间件使用Selenium处理javascript页面

    Scrapy中间件可使用Selenium处理javascript页面。 安装 $ pip install scrapy-selenium 您应该使用python&gt; = 3.6 。 您还将需要一种与Selenium。 配置 添加要使用的浏览器,驱动程序可执行文件的路径,以及将要传递...

    selenium 2.44.0 Build by Python

    6. **处理弹出框**:Selenium 支持处理警告对话框、确认对话框和输入对话框。 7. **并发测试**:通过多线程或分布式测试,可以同时在多个浏览器或多个机器上运行测试。 8. **支持多种浏览器**:除了常见浏览器,...

    Selenium知识总结

    7. **处理弹出对话框**:如果存在警告对话框,`selenium.isAlertPresent()`检查其是否存在,`selenium.getAlert()`获取对话框内容。 8. **处理子窗口**:`selenium.waitForPopUp("myPopupWindow", "30000")`等待子...

    Selenium_v2.5

    在Selenium_v2.5中,错误处理和异常机制得到了加强,使得测试脚本在遇到预期外的情况时能更优雅地处理错误,提供详细的错误报告,帮助定位问题。同时,这一版本可能还包含了性能优化,提升了测试执行的速度和效率。 ...

    Selenium

    ### Selenium 知识点详解 #### 一、Selenium 概述 Selenium 是一个用于自动化 Web 应用程序测试的工具集。它由 ThoughtWorks 公司开发,并且随着时间的发展已经成为一个开源项目,得到了广泛的社区支持。Selenium ...

    Selenium各种案例

    - 对于模态对话框和警告,可以使用`switch_to_alert()`方法来处理。 7. **表格操作** - 使用Selenium可以方便地遍历和操作表格中的数据,例如选择特定单元格,修改内容等。 8. **JavaScript交互** - `execute_...

    selenium-server-standalone和Selenium-java的jar包

    总结来说,selenium-server-standalone.jar是Selenium的核心,负责处理与浏览器的交互,而Selenium-java.jar提供了Java开发者的友好接口,简化了测试脚本的编写工作。理解并掌握这两个jar包的使用,对于进行Java+...

    python上selenium的弹框操作实现

    方法定位到 alert/confifirm/prompt对话框。 2,操作 1,页面弹框 页面弹框是属于HTML里面的元素,它是由用户在操作页面的时候在本页面弹出的。所以科研直接在页面上定位到 步骤: 1,用户操作后,弹出页面弹框 2,...

Global site tag (gtag.js) - Google Analytics