一、環(huán)境搭建
官網(wǎng)需要下載selenium對(duì)應(yīng)的jar包,谷歌瀏覽器及對(duì)應(yīng)的驅(qū)動(dòng)
官網(wǎng)下載地址:http://www.seleniumhq.org/download/
瀏覽器驅(qū)動(dòng):https://www.npmjs.com/package/selenium-webdriver
2、jdk環(huán)境變量
jdK下載地址:https://www.oracle.com/technetwork/java/javaee/downloads/index.html
環(huán)境變量配置參考:https://jingyan.baidu.com/article/6dad5075d1dc40a123e36ea3.html
3烟阐、maven中pom文件配置需要的jar包支持
如果是java Project,直接導(dǎo)入下載的jar包就行了
二、Selenium WebDriver運(yùn)行原理
使用eclipse打開WebDriver.class文件會(huì)發(fā)現(xiàn)里面支持許多方法的調(diào)用
三十酣、常見API用法
1.1打開瀏覽器
想要瀏覽器完成界面元素的操作,首頁要通過WebDriver打開瀏覽器际长,WebDriver為上面下載的
System.setProperty("webdriver.chrome.driver", "C:\\Users\\Administrator\\AppData\\Local\\Google\\Chrome\\chromedriver.exe");
webdriver=new ChromeDriver();
/*設(shè)置隱私等待讓瀏覽器正常運(yùn)行*/
webdriver.manage().timeouts().implicitlyWait(5, TimeUnit.SECONDS);
打開firefox瀏覽器:
? ? ? ? WebDriver driver = new FirefoxDriver();?
打開IE瀏覽器
? ? ? ? WebDriver driver = new InternetExplorerDriver ();
打開chrome瀏覽器
WebDriverdriver = new ChromeDriver();
1.2.1 ?最大化瀏覽器
WebDriver driver = new FirefoxDriver();
driver.manage().window().maximize();
1.2.3 關(guān)閉瀏覽器
WebDriver driver = new FirefoxDriver();
driver.close();
driver.quit();
1.3??打開測(cè)試頁面
driver.get("http://www.google.com");
1.4 ?頁面元素定位
Webdriver提供下面兩種方法來定位頁面元素耸采,參數(shù)是By對(duì)像,最常用是By.id和By.name查找工育。
findElement 定位某個(gè)元素虾宇,如果沒有找到元素會(huì)拋出異常:NoSuchElementException
findElements ? ? 定位一組元素
?例如需要定位如下元素:
<input class="input_class" type="text" name="passwd" id="passwd-id" />?
By.id:
WebElement element = driver.findElement(By.id("passwd-id"));
By.name:
WebElement element = driver.findElement(By.name("passwd"));
By.xpath:
WebElement element =driver.findElement(By.xpath("http://input[@id='passwd-id']"));?
By.className
WebElement element = driver.findElement(By.className("input_class"));
By.cssSelector
WebElement element = driver.findElement(By.cssSelector(".input_class"));
By.linkText:
//通俗點(diǎn)就是精確查詢
WebDriver driver = new FirefoxDriver();
driver.get("http://www.baidu.com/");?
WebElement element = driver.findElement(By.linkText("百科"));
By.partialLinkText:
//這個(gè)方法就是模糊查詢
WebDriver driver = new FirefoxDriver();
driver.get("http://www.baidu.com/");?
WebElement element = driver.findElement(By.partialLinkText("hao"));
By.tagName:
WebDriver driver = new FirefoxDriver();
driver.get("http://www.baidu.com/");
String test= driver.findElement(By.tagName("form")).getAttribute("name");
System.out.println(test);?
1.5??如何對(duì)頁面元素進(jìn)行操作
1.5.1 輸入框(text field or textarea)
WebElement element = driver.findElement(By.id("passwd-id"));
element.sendKeys(“test”);//在輸入框中輸入內(nèi)容:
element.clear(); ??//將輸入框清空
element.getText(); ??//獲取輸入框的文本內(nèi)容:?
1.5.2下拉選擇框(Select)
Select select = new Select(driver.findElement(By.id("select"))); ?
select.selectByVisibleText(“A”);
select.selectByValue(“1”);?
select.deselectAll();
select.deselectByValue(“1”);
select.deselectByVisibleText(“A”);
select.getAllSelectedOptions();
select.getFirstSelectedOption();?
1.5.3單選項(xiàng)(Radio Button)
WebElement radio=driver.findElement(By.id("BookMode"));
radio.click(); ? //選擇某個(gè)單選項(xiàng)
radio.clear(); ?//清空某個(gè)單選項(xiàng)
radio.isSelected(); //判斷某個(gè)單選項(xiàng)是否已經(jīng)被選擇
1.5.4多選項(xiàng)(checkbox)
WebElement checkbox = driver.findElement(By.id("myCheckbox."));
checkbox.click();
checkbox.clear();
checkbox.isSelected();
checkbox.isEnabled();
1.5.5按鈕(button)
WebElement btn= driver.findElement(By.id("save"));
btn.click(); //點(diǎn)擊按鈕
btn.isEnabled (); //判斷按鈕是否enable
1.5.7彈出對(duì)話框(Popup dialogs)
Alert alert = driver.switchTo().alert();
alert.accept(); //確定
alert.dismiss(); //取消
alert.getText(); //獲取文本
1.5.8表單(Form)
Form中的元素的操作和其它的元素操作一樣,對(duì)元素操作完成后對(duì)表單的提交可以:
WebElement approve = driver.findElement(By.id("approve"));
approve.click();
或
approve.submit();//只適合于表單的提交
1.5.9截圖保存圖片文件
1.6??WindowHandle和 Frames之間的切換
例如從登陸頁面跳轉(zhuǎn)到index頁面如绸,此時(shí)WindowHandle就會(huì)發(fā)生變化嘱朽,通過封裝webdriverde的getWindowsHandle方法就可解決該問題
再就是Frames的切換,后臺(tái)系統(tǒng)用的比較多
源碼就是這樣的怔接,套兩層frameset,里面放frame
<html>
<frameset rows="*" cols="150,*">
? <frame src="/example/html/frame_a.html" id="left">
? <frameset rows="50,*">
? <frame src="/example/html/frame_b.html" id="top">
? <frame src="/example/html/frame_c.html" id="main">
</frameset>
</frameset>
</html>
當(dāng)進(jìn)入到這個(gè)頁面時(shí)搪泳,driver停留在最大的frameset上,如果需要操作left頁面就需要使用
webdriver.switchTo().frame(left);
如果left頁面操作完需要操作top或者main的頁面時(shí)扼脐,需要先從frame返回到frameset再
到子frameset的frame中森书,思路如下
webdriver.switch_to_parent_frame();
webdriver.switchTo().frame(main);
從main返回到left時(shí)就需要
webdriver.switch_to_parent_frame();
webdriver.switch_to_parent_frame();
webdriver.switchTo().frame(main);
1.7??表格(Table)
先找到table,再找到對(duì)應(yīng)列或者行谎势,賦值給list凛膏,for循環(huán)取出值