前言
本文主要通过一个简单的例子,来讨论以下两个问题:- 使用Selenium对由Ajax动态加载的页面进行测试
- 测试含有iframe标签的网页
本文不是Selenium2的简单介绍或者入门内容,目标读者是至少使用过Selenium2进行测试的各位朋友。准备工作
假设你有一项业务,需要在用户进行输入的时候用Ajax弹出辅助输入的窗口,然后再将这些值传回主窗口。
为了叙述简便,这里使用一个简单的iframe标签对弹出窗口进行简化。
首先需要两个网页,一个是主页面main.html:
接着是被弹出的窗口SubPage.html12345678910111213141516171819202122232425<HTML><HEAD><TITLE>寸木的Selenium+Ajax测试</TITLE><SCRIPTlanguage="javascript">function loadFrame() {// 取得DIV对象var divElement = document.getElementById("TestDiv");// 插入iFrame元素divElement.innerHTML = "<iframeid='TestFrame'style='width:200px;height:250px;'/>";// 取得动态插入的iFrame元素var frameElement = document.getElementById("TestFrame");frameElement.src = "SubPage.html";}</SCRIPT><metahttp-equiv="Content-Type"content="text/html; charset=UTF-8"/></HEAD><BODY><H1>主页面</H1>下面的区域是测试用的Frame。<divid="TestDiv"style="width:200px;height:250px;border:solid 1px #000000;"> </div><br/><inputtype="button"value="Load Frame"onclick="loadFrame();"id="btnLoad"/><br/>接收到的信息:<labelid="lblMsg">Waiting mesage</label></BODY></HTML>
1234567891011121314151617181920212223242526272829<HTML><HEAD><TITLE>寸木的Selenium+Ajax测试</TITLE><SCRIPTlanguage="javascript">function removeDefaultInfo(webElement) {var strDefalutInfo = "请输入信息...";if(webElement.value == strDefalutInfo) {webElement.value = "";}}function setDefaultInfo(webElement) {var strDefalutInfo = "请输入信息...";if(webElement.value == "") {webElement.value = strDefalutInfo;}}function sendToMainPage() {parent.document.getElementById("lblMsg").innerHTML = document.getElementById("frameText").value;}</SCRIPT><metahttp-equiv="Content-Type"content="text/html; charset=UTF-8"/></HEAD><BODYstyle="background-color:#009900;"><H1>子页面</H1>Hi, 这里是子页面,为了和主页面加以区别,我被标注成了绿色。<br/ ><inputtype="text"id="frameText"value="请输入信息..."onfocus="removeDefaultInfo(this);"onblur="setDefaultInfo(this);"/><inputtype="button"value="传送到主窗口"onclick="sendToMainPage();"id="btnSendBack"/></BODY></HTML>关键问题
我们的目标是用Java编写一段能够自动测试这一完整业务逻辑的测试代码。因此,我们首先想到的可能会是类似下面的代码
12345678910111213141516171819202122232425262728293031323334353637383940414243444546/****/packagecom.cnblogs.www.hexin0614;importorg.openqa.selenium.By;importorg.openqa.selenium.WebDriver;importorg.openqa.selenium.firefox.FirefoxDriver;/*** @author hexin**/publicclassTestSa {/*** @param args* @throws Exception*/publicstaticvoidmain(String[] args)throwsException {// DeclareWebDriver driver =newFirefoxDriver();// Load pageThread.sleep(15000);// Load subpagedriver.findElement(By.id("btnLoad")).click();// Input messagedriver.findElement(By.id("frameText")).sendKeys("Message from Selenium.");// Send message back to main pagedriver.findElement(By.id("btnSendBack")).click();Thread.sleep(2000);// Go back to main frameSystem.out.println(driver.findElement(By.id("lblMsg")).getText());driver.close();}}
实际运行的时候会报告找不到"frameText"元素的错误。这是怎么回事呢?
原来Selenium2在使用get()方法打开一个网页的时候,是不会继续加载里面的iframe中的内容的(这一点与Selenium有所区别)。
那么,我们就需要人为的要求Selenium2对iframe中的内容进行加载。
12// Step into the subpagedriver.switchTo().frame("TestFrame");
这样就可以找到id为"frameText"的元素了。
重新运行,发现还是有错,这一次报告的是"lblMsg"元素找不到?奇怪吗?
不奇怪,因为我们通过上面的switchTo()方法已经切换到了iframe的内部,而subpage中是不存在id为"lblMsg"对象的。
怎么办?只有重新回到Mainpage上来。
根据Selenium2的在线文档,有很多方法可以切换回MainPage。(别告诉我你没有耐心的去读那些文档)
笔者经过摸索发现了一个比较简单的方法:利用getWindowHandle()方法可以快速的进行切换。该方法的JavaDoc如下
1Return an opaque handle to this window that uniquely identifies it within this driver instance.This can be used to switch to this window at a later date
看来只要在切换至iframe内部的时候,提前记录下Mainpage的句柄就可以在将来的任何时候回到主窗口了。于是我们追加下面两行代码。
1234567// Back up main page's handlerString strMainHandler = driver.getWindowHandle();// ........// Go back to main framedriver.switchTo().window(strMainHandler);
好了,问题解决了,是不是很简单?最后送出完整的Java代码。
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253/** Test*/package com.cnblogs.www.hexin0614;import org.openqa.selenium.By;import org.openqa.selenium.WebDriver;import org.openqa.selenium.firefox.FirefoxDriver;/*** @author hexin**/public class TestSa {/*** @param args* @throws Exception*/publicstaticvoidmain(String[] args)throwsException {// DeclareWebDriver driver =newFirefoxDriver();// Load pageThread.sleep(15000);// Load subpagedriver.findElement(By.id("btnLoad")).click();// Back up main page's handlerString strMainHandler = driver.getWindowHandle();// Step into the subpagedriver.switchTo().frame("TestFrame");// Input messagedriver.findElement(By.id("frameText")).sendKeys("Message from Selenium.");// Send message back to main pagedriver.findElement(By.id("btnSendBack")).click();Thread.sleep(2000);// Go back to main framedriver.switchTo().window(strMainHandler);System.out.println(driver.findElement(By.id("lblMsg")).getText());driver.close();}}
本文提供了一种方法,通过使用Selenium测试含有iframe标签的动态加载页面,详细介绍了如何解决在测试过程中遇到的问题,包括切换iframe、处理主窗口与子窗口之间的信息传递,最终实现自动化测试。
496

被折叠的 条评论
为什么被折叠?



