當(dāng)前位置:首頁(yè) > IT技術(shù) > Windows編程 > 正文

selenium 4.0新特性及新舊api對(duì)比
2021-12-13 17:45:22

眾所周知,java語(yǔ)言版本的selenium一般被認(rèn)為是最正宗的selenium版本,今天我們以java語(yǔ)言為例,來(lái)看看selenium 4.0的各種新特性以及新舊api的對(duì)比。

Capabilities

如果你需要對(duì)瀏覽器進(jìn)行一些全局設(shè)置,那么使用Capabilities是唯一的選擇。說(shuō)實(shí)話,舊的Capabilities有點(diǎn)不太符合直覺,具體用法如下。

DesiredCapabilities?capabilities?=?DesiredCapabilities.chrome();
capabilities.setCapability("platform",?"Mac?OS?X");
capabilities.setCapability("version",?"94");
driver?=?new?RemoteWebDriver(capabilities);

在新版本中,我們直接設(shè)置options就可以了,語(yǔ)義上顯得更為自然。

ChromeOptions?options?=?new?ChromeOptions();
options.setBrowserVersion("94");
options.setPlatformName("Mac?OS?X");
driver?=?new?ChromeDriver(options);

Waits

在之前的版本里,我們實(shí)例化各種wait對(duì)象時(shí)候需要傳入2個(gè)參數(shù):time以及type of time,在新版本里我們只需要使用Duration類就可以了。

這是之前的做法

driver.manage().timeouts().implicitlyWait(10,?TimeUnit.SECONDS);
driver.manage().timeouts().pageLoadTimeout(10,?TimeUnit.SECONDS);
driver.manage().timeouts().setScriptTimeout(10,?TimeUnit.SECONDS);

新的方式

driver.manage().timeouts().implicitlyWait(Duration.ofSeconds(10));
driver.manage().timeouts().pageLoadTimeout(Duration.ofMinutes(3));
driver.manage().timeouts().setScriptTimeout(Duration.ofHours(1));

當(dāng)然,現(xiàn)在支持各式各樣的Duration了,需要注意的是這里接受的是long型的參數(shù)。

Duration.ofNanos(long?nanos);
Duration.ofMillis(long?millis);
Duration.ofSeconds(long?seconds);
Duration.ofMinutes(long?minutes);
Duration.ofHours(long?hours);
Duration.ofDays(long?days);

當(dāng)然,我們還可以直接設(shè)置瀏覽器的各種全局等待時(shí)間,代碼上看觀感好了不少。

ChromeOptions?options?=?new?ChromeOptions();
options.setImplicitWaitTimeout(Duration.ofSeconds(10));
options.setScriptTimeout(Duration.ofSeconds(10));
options.setPageLoadTimeout(Duration.ofSeconds(10));

相對(duì)定位器

一些哲學(xué)流派告訴我們,世界是變化的,相對(duì)的,沒有絕對(duì)的靜,也沒有絕對(duì)的動(dòng),物體總是相對(duì)著其他物體進(jìn)行著運(yùn)動(dòng)。

在之前的selenium版本里,我們大部分情況下只能通過(guò)絕對(duì)定位器來(lái)定位元素,比如

  • 定位一個(gè)id=xxx的元素
  • 定位所有class=yyy的元素
  • 定位所有的tag那么=zzz的元素

當(dāng)然,還是有例外的,我們可以通過(guò)xpath或者css來(lái)不那么絕對(duì)的定位元素。比如

  • .nav > li:定位class為nav的元素下所有的直接li子元素
  • #nav .item:定位id是nav下面所有的class為item的元素

這也是我推薦用css定位的原因,更靈活更簡(jiǎn)潔,同時(shí)可以跟前端的技術(shù)棧保持相對(duì)統(tǒng)一,xpath的定位能力更強(qiáng)一些,同時(shí)也帶來(lái)了給多的復(fù)雜性和學(xué)習(xí)成本。

在selenium 4.0中,相對(duì)定位器終于千呼萬(wàn)喚始出來(lái),我們可以省去相對(duì)復(fù)雜的xpath表達(dá)式,用更加直觀的方式來(lái)定位元素了,舉個(gè)例子,下面是一個(gè)登錄頁(yè)面。

?

?

?

其html代碼如下:

<div?class="row">
????<div?class="large-6?small-12?columns">
????????<label?for="password">Password</label>
????????<input?type="password"?name="password"?id="password">
????</div>
</div>

我們?cè)囍ザㄎ籭nput之前的那個(gè)label,經(jīng)驗(yàn)豐富的你可以想象到頁(yè)面上會(huì)有非常多l(xiāng)abel,所以用tagname的方式應(yīng)該不可??;另外這個(gè)label還沒有其他更加獨(dú)特的屬性可以利用。不過(guò)我們可以發(fā)現(xiàn),睡在他下鋪的兄弟input有id屬性,定位起來(lái)相對(duì)簡(jiǎn)單,很自然的會(huì)想到能不能利用input來(lái)定位label呢?現(xiàn)在都2021年了,這類的相對(duì)定位方式已經(jīng)被支持了的。

WebElement?passwordArea?=?driver.findElement(By.id("password"));
WebElement?labelOfPass?=?driver.findElement(with(By.tagName("label")).above(passwordArea));
System.out.println(labelOfPass.getText());

大家可以猜一猜上面代碼的輸出是什么?

toLeftOf/toRightOf/near

除了上面所展示的above方式以外,selenium 4.0還支持below,toLeftOf/toRightOf/near等方式,舉個(gè)簡(jiǎn)單的例子。

<tr>
????<td?class="name">itest.info</td>
????<td?class="website">itest.info</td>
????<td?class="actions">
????????<a?href="#edit">Edit</a>
????????<a?href="#delete">Delete</a>
????</td>
</tr>

如果我們要定位上面的delete按鈕,我們可以用下面的相對(duì)定位方式

WebElement?website?=?driver.findElement(By.xpath("(//td[text()='itest.info'])"));
driver.findElement(with(By.linkText("Delete")).toRightOf(website)).click();

//?or
driver.findElement(with(By.linkText("Delete")).near(website)).click();

打開新窗口或者新標(biāo)簽頁(yè)

在之前的selenium版本中,我們?nèi)绻蜷_新窗口或者是新標(biāo)簽頁(yè)的話,我們需要先實(shí)例化1個(gè)driver對(duì)象,然后使用window handler來(lái)進(jìn)行下一步的操作;在4.0以后,我們可以直接使用switchTo()方法來(lái)打開新窗口。下面是具體的例子:

WebDriver?driver?=?Driver.get();
driver.get("http://www.itest.info/");
????????
driver.switchTo().newWindow(WindowType.WINDOW);
driver.get("https://qq.com");

打開新標(biāo)簽頁(yè)也很好辦,我們只需要修改WindowType就好了。

WebDriver?driver?=?Driver.get();
driver.get("http://www.itest.info/");
????????
driver.switchTo().newWindow(WindowType.TAB);
driver.get("https://qq.com");

DevTools協(xié)議

在4.0之后我們可以直接使用chrome的開發(fā)者工具接口來(lái)獲取網(wǎng)絡(luò)情況或者是性能數(shù)據(jù)了。下面的例子展示了如何使用devtools來(lái)設(shè)置自己的地理位置,自動(dòng)化打卡簽到有希望了。

WebDriver?driver?=?new?ChromeDriver();
DevTools?devTools?=?((HasDevTools)driver).getDevTools();
devTools.createSession();
devTools.send(Emulation.setGeolocationOverride(Optional.of(38.89511),
????????????????Optional.of(-77.03637),
????????????????Optional.of(1)));
driver.get("https://my-location.org/");

總結(jié)

selenium 4.0并沒有帶來(lái)特別多令人嘖嘖稱奇的特性,不過(guò)從api的設(shè)計(jì)以及語(yǔ)義上,元素的定位上都有了不同程度的優(yōu)化和提升,這也是selenium成熟的體現(xiàn)。作為1個(gè)從selenium rc時(shí)代就使用selenium的老用戶,對(duì)這次大的版本更新我竟然覺得有一絲絲的感動(dòng),畢竟是一個(gè)開源項(xiàng)目,大家都有自己的工作和生活,能十幾年如一日的維護(hù)和更新selenium本來(lái)就是一件不容易的事情,維護(hù)者們?yōu)榱藟?mèng)想和情懷還在努力,我們不妨也一起加油吧,學(xué)無(wú)止境,我獨(dú)自邁步向前,讓舉步不前的人自己卷自己吧。

?

原文鏈接

https://mp.weixin.qq.com/s/xeuKSPCg7M3-pWzv-Dl-og

本文摘自 :https://www.cnblogs.com/

開通會(huì)員,享受整站包年服務(wù)立即開通 >