上節(jié)我們已經(jīng)介紹了幾個(gè)常用的控件操作方法,理論上已經(jīng)可以操作絕大多數(shù)控件,同樣WebDriver提供了一些特殊方法,用于操作一些特殊情況。
下拉框操作
下拉框操作除了通過(guò)兩次點(diǎn)擊(1.點(diǎn)擊下拉框,2.點(diǎn)擊下拉框選項(xiàng))外,JAVA版本的WebDriver還提供了Select 類用來(lái)專門處理下拉框元素。
HTML常見如下:
<select name="select">
<option value="chrome">Chrome</option>
<option value="ie">IE</option>
<option value="firefox">Firefox</option>
<option value="safari">Safari</option>
</select>
選取下拉選擇,代碼示例:
@Test
public void selectTest() throws InterruptedException {
// 打開測(cè)試頁(yè)面
driver.get("file:///D:/html/index.html");
// 定位下拉框
WebElement selectHtml = driver.findElement(By.name("select"));
// 實(shí)例化Select
Select select = new Select(selectHtml);
// 為了看效果,線程等待2S
Thread.sleep(2000);
// 通過(guò)下拉框文本值選取
select.selectByVisibleText("IE");
// 為了看效果,線程等待2S
Thread.sleep(2000);
// 通過(guò)下拉框索引選取
select.selectByIndex(2);
// 為了看效果,線程等待2S
Thread.sleep(2000);
// 通過(guò) value 屬性值選取
select.selectByValue("chrome");
}
說(shuō)明:
- Select 類只能用于被<select></select>標(biāo)簽包圍的元素中,也就是必須是標(biāo)準(zhǔn)下拉控件
- selectByVisibleText()傳入的參數(shù)是option標(biāo)簽的text值
- selectByIndex() 傳入的參數(shù)是option標(biāo)簽的索引值
- selectByValue() 傳入的參數(shù)是option標(biāo)簽的value屬性值
獲取下拉框文本值,代碼示例:
@Test
public void getOptionsTest(){
// 打開測(cè)試頁(yè)面
driver.get("file:///D:/html/index.html");
// 定位下拉框
WebElement selectHtml = driver.findElement(By.name("select"));
// 實(shí)例化Select
Select select = new Select(selectHtml);
// 獲取第一個(gè)選擇選項(xiàng)
WebElement element = select.getFirstSelectedOption();
// 獲取第一選項(xiàng)的Text
String text = element.getText();
System.out.println(text);
// 獲取所有的選項(xiàng)
List<WebElement> optionsList= select.getOptions();
// 循環(huán)輸出所有選項(xiàng)的Text
for(WebElement option:optionsList){
String optionText = option.getText();
System.out.println(optionText);
}
}
說(shuō)明:
- getFirstSelectedOption()常用與獲取當(dāng)前選項(xiàng)或者默認(rèn)選項(xiàng)文本
- getOptions()用于獲取所有的下拉選項(xiàng),返回List
Alert的操作
測(cè)試用例:
1. 打開“UI自動(dòng)化測(cè)試”主頁(yè)
2. 點(diǎn)擊Alert按鈕
3. 在alert警告框點(diǎn)擊確定按鈕
代碼實(shí)現(xiàn):
@Test
public void alertTest() throws InterruptedException {
driver.get("file:///C:/selenium_html/index.html");
driver.findElement(By.className("alert")).click();
Thread.sleep(3000);
// 把控制權(quán)轉(zhuǎn)交給 alert
Alert alert = driver.switchTo().alert();
// 獲取警告框的文本值
String text = alert.getText();
System.out.println(text);
// 點(diǎn)擊警告窗確定按鈕
alert.accept();
}
說(shuō)明:
Alert警告窗無(wú)法通過(guò)正常元素那樣去定位警告窗,所以自然就無(wú)法直接調(diào)用click()方法去點(diǎn)擊確定按鈕。所以想要處理alert警告窗我們需要把driver控制權(quán)轉(zhuǎn)移給alert類型,然后調(diào)用alert的getText()的方法獲取警告窗文本,調(diào)用accept()方法去模擬點(diǎn)擊確定按鈕。
Confirm的操作
測(cè)試用例:
1. 打開“UI自動(dòng)化測(cè)試”主頁(yè)
2. 點(diǎn)擊Confirm按鈕
3. 在Confirm警告框點(diǎn)擊確定\取消按鈕
代碼實(shí)現(xiàn):
@Test
public void confirmTest() throws InterruptedException {
driver.get("file:///C:/selenium_html/index.html");
driver.findElement(By.className("confirm")).click();
Thread.sleep(3000);
// driver控制權(quán)轉(zhuǎn)交給 alert
Alert alert = driver.switchTo().alert();
// 點(diǎn)擊取消
alert.dismiss();
Thread.sleep(3000);
// 點(diǎn)擊確定
alert.accept();
}
說(shuō)明:
confirm彈窗類似alert,但是多了個(gè)取消按鈕,如果想模擬點(diǎn)擊取消按鈕操作,我們需要調(diào)用dismiss()方法實(shí)現(xiàn)。
Prompt的操作
測(cè)試用例:
1. 打開“UI自動(dòng)化測(cè)試”主頁(yè)
2. 點(diǎn)擊Prompt按鈕
3. 在Prompt 彈窗中,輸入“這個(gè)是Prompt”
4. 點(diǎn)擊確定\取消按鈕
代碼實(shí)現(xiàn):
@Test
public void promptTest() throws InterruptedException {
driver.get("file:///C:/selenium_html/index.html");
driver.findElement(By.className("prompt")).click();
Thread.sleep(3000);
// driver控制權(quán)轉(zhuǎn)交給 alert
Alert alert = driver.switchTo().alert();
// 往彈窗輸入 文本
alert.sendKeys("這個(gè)是Prompt");
Thread.sleep(2000);
alert.accept();
Thread.sleep(3000);
alert.accept();
Thread.sleep(3000);
}
說(shuō)明:
操作基本同以上兩鐘警告窗,但是prompt彈窗多了可輸入的文本框,同樣無(wú)法定位,所以要操作文本框可以調(diào)用alert的sendKeys()方法實(shí)現(xiàn)。
iFrame 的操作
思路:
1. 定位iFrame
2. driver控制權(quán)交給iFrame
3. 操作iFrame里面的元素
4. 操作完成把driver控制權(quán)交回原頁(yè)面
測(cè)試用例:
1. 打開“UI自動(dòng)化測(cè)試”主頁(yè)
2. 在frame:input 輸入框輸入文本
代碼實(shí)現(xiàn):
@Test
public void iframeTest() throws InterruptedException {
driver.get("file:///C:/selenium_html/index.html");
// 通過(guò) ID 或者 name 方式 轉(zhuǎn)交控制權(quán)
//driver.switchTo().frame("aa");
WebElement iframe = driver.findElement(By.tagName("iframe"));
// 通過(guò)webelement 方式轉(zhuǎn)交driver控制權(quán)
driver.switchTo().frame(iframe);
driver.findElement(By.linkText("baidu")).click();
Thread.sleep(3000);
// driver 控制權(quán)轉(zhuǎn)交給原來(lái)界面
driver.switchTo().defaultContent();
driver.findElement(By.linkText("登陸界面")).click();
}
說(shuō)明:
driver.switchTo().frame("aa")中“aa”默認(rèn)為frame元素的id或者name的屬性值。如果frame元素沒有id也沒有name那么我們完全可以用其它定位到frame然后傳入一個(gè)WebElemet元素便可。
多窗口操作
思路:
- 獲取當(dāng)前窗口的handle值
- 獲取所有窗口的handle值
- 循環(huán)判斷所有的窗口的handle值,如果不為第一步獲取的值,則跳轉(zhuǎn)
測(cè)試用例:
- 打開“UI自動(dòng)化測(cè)試”頁(yè)面
- 點(diǎn)擊“Open new window”
- 在新開的界面iframe:input 文本框輸入文本
- 關(guān)閉新開的窗口
- 再原來(lái)的界面文本框輸入文本
代碼實(shí)現(xiàn):
@Test
public void testWin() throws InterruptedException {
driver.get("file:///C:/selenium_html/index.html");
// 當(dāng)前driver所在的頁(yè)面的 句柄值
String handle1 = driver.getWindowHandle();
driver.findElement(By.linkText("Open new window")).click();
Thread.sleep(3000);
// For 循環(huán)判斷 獲取到的handles是否等于handle1
for (String handles : driver.getWindowHandles()) {
if (handles.equals(handle1)) {
continue;
}
driver.switchTo().window(handles);
}
driver.findElement(By.linkText("baidu")).click();
// driver 控制權(quán)交回第一個(gè)窗口
driver.switchTo().window(handle1);
}
上傳文件的處理
上傳文件操作需要彈出我們的win窗口,而win窗口我們是無(wú)法通過(guò)WebDriver去識(shí)別元素做操作,那是不是意味著上傳文件我們WebDriver就無(wú)法完成呢?
其實(shí)相反,上傳文件操作非常容易,我們還是可以通過(guò)已經(jīng)學(xué)過(guò)的sendKeys()方法完成。
思路:
1. 定位上傳控件
2. 使用sendKeys()方法,并傳入文件路徑
測(cè)試用例:
1. 打開“UI 測(cè)試頁(yè)面”
2. 實(shí)現(xiàn)上傳操作
代碼實(shí)現(xiàn):
@Test
public void uploadTest() {
driver.get("file:///C:/selenium_html/index.html");
// 定位上傳控件,傳入本地文件路徑
driver.findElement(By.id("load")).sendKeys("c:\\a.html");
}