运行时错误76未找到路径怎么解决_自动化测试解决竞争问题?等待一下就行了~...
由于WebDriver和瀏覽器分別運行在自己的進程中,所以WebDriver無法實時追蹤到瀏覽器中頁面DOM樹的渲染情況,也就是在WebDriver的執(zhí)行和瀏覽器的渲染間存在一個競爭問題(race condition)。
問題實例
我們將用一個實例來展示W(wǎng)ebDriver和瀏覽器間存在的競爭問題,用到的測試html文件內(nèi)容如下(race_condition.html):
<meta charset=utf-8><title>Race Condition Exampletitle><script> window.addEventListener("load", function () { setTimeout(() => { var newElement = document.createElement("p"); newElement.textContent = "Hello from JavaScript!"; document.body.appendChild(newElement); }, 1000); // 模擬元素的延遲加載 setTimeout(() => { var newElement = document.createElement("a"); newElement.textContent = "Hello from JavaScript again!"; document.body.appendChild(newElement); }, 3000); });script>代碼如下:
const { Builder, By} = require('selenium-webdriver');const assert = require('assert');(async function myFunction() { // 創(chuàng)建一個driver實例 let driver = await new Builder().forBrowser('chrome').build(); try { let url = `file://${__dirname}/race_condition.html`; await driver.get(url); const element = await driver.findElement(By.css('p')); assert.strictEqual(await element.getText(), 'Hello from JavaScript!'); } catch (error) { console.error(error.message); } finally { // 關(guān)閉瀏覽器 await driver.quit(); }})()代碼看起來沒什么問題,但是運行起來會報元素未找到錯誤:
no?such?element:?Unable?to?locate?element:?{"method":"css?selector","selector":"p"}為什么呢?首先需要弄清楚代碼和瀏覽器的執(zhí)行流程,如下:
如何解決上述競爭問題呢?Selenium提供了一個種方案-等待(Waits),共分為三種:
顯性等待(Explicit wait):在設(shè)置條件和等待時長后,會暫停WebDriver后續(xù)代碼的執(zhí)行,不斷輪詢直到條件滿足或等待超時,然后繼續(xù)執(zhí)行后續(xù)代碼。
隱性等待(Implicit wait):默認查找元素的等待時長,在元素找不到時默認不斷輪詢直到找到元素或超時,后再執(zhí)行后續(xù)代碼,作用于整個session生命周期。
流暢等待(Fluent wait):跟顯性等待類似,不同的是可以設(shè)置輪詢間隔和超時后的錯誤消息,更加友好。
下面對上述三種等待方法進行詳細介紹。
顯性等待(Explicit wait)
語法:
this.wait<T>(?condition,?timeout,?message?)?→?(IThenable<T>|WebElementPromise)支持的條件包括:元素是否存在,元素的屬性檢查以及自定義條件等。
如下示例:
// 自定義的條件const customizedCondtion= () =>false;await driver.wait(customizedCondtion, 10000);// 檢測元素是否存在await?driver.wait(until.elementLocated(By.css('p')),?10000);因此針對剛開始時元素未找到的問題,使用顯性等待來解決的代碼如下:
const { Builder, By, until } = require('selenium-webdriver');const assert = require('assert');(async function myFunction() { // 創(chuàng)建一個driver實例 let driver = await new Builder().forBrowser('chrome').build(); try { let url = `file://${__dirname}/race_condition.html`; await driver.get(url); let element = await driver.wait(until.elementLocated(By.css('p')), 10000); // 使用顯性等待,超時時間為10秒 assert.strictEqual(await element.getText(), 'Hello from JavaScript!'); } catch (error) { console.error(error.message); } finally { // 關(guān)閉瀏覽器 await driver.quit(); }})()隱性等待(Implicit wait)
隱性等待的設(shè)置方法如下示例:
// 設(shè)置10秒超時時間await driver.manage().setTimeouts( { implicit: 10000 } );await driver.get('http://somedomain/url_that_delays_loading');// 會暫停代碼直到元素被找到或超時let?webElement?=?driver.findElement(By.id("myDynamicElement"));針對剛開始時元素未找到的問題,使用隱性等待來解決的代碼如下:
const { Builder, By, until } = require('selenium-webdriver');const assert = require('assert');(async function myFunction() { // 創(chuàng)建一個driver實例 let driver = await new Builder().forBrowser('chrome').build(); try { let url = `file://${__dirname}/race_condition.html`; await driver.get(url); // 設(shè)置10秒超時時間 await driver.manage().setTimeouts({ implicit: 10000 }); // 用普通的方式定位元素 // 要等待1秒左右才能找到元素 let pElement = await driver.findElement(By.css('p')); assert.strictEqual(await pElement.getText(), 'Hello from JavaScript!') // 要等待2秒左右才能找到元素(前面已經(jīng)等待了1秒) let aElement= await driver.findElement(By.css('a')); assert.strictEqual(await aElement.getText(), 'Hello from JavaScript again!') } catch (error) { console.error(error.message); } finally { // 關(guān)閉瀏覽器 await driver.quit(); }})()流暢等待(Fluent wait)
在JavaScript版本的類庫中,流暢等待的語法和顯性等待是一樣的,不同的是方法簽名中多了兩個參數(shù),如下示例:
// 前兩個參數(shù)和顯性等待一致// 后兩個參數(shù)分別為超時后的錯誤消息和輪詢的間隔時間let?foo?=?await?driver.wait(until.elementLocated(By.id('foo')),?30000,?'Timed?out?after?30?seconds',?5000);針對剛開始時元素未找到的問題,使用流暢等待來解決的代碼如下:
const { Builder, By, until } = require('selenium-webdriver');const assert = require('assert');(async function myFunction() { // 創(chuàng)建一個driver實例 let driver = await new Builder().forBrowser('chrome').build(); try { let url = `file://${__dirname}/race_condition.html`; await driver.get(url); // 設(shè)置30秒的超時時間和5秒的輪詢間隔時間 // 要等待5秒左右才能找到元素 let element = await driver.wait(until.elementLocated(By.css('p')), 30000, 'Timed out after 30 seconds', 5000); assert.strictEqual(await element.getText(), 'Hello from JavaScript!') } catch (error) { console.error(error.message); } finally { // 關(guān)閉瀏覽器 await driver.quit(); }})()總結(jié)
本文先介紹了使用Selenium進行Web自動化測試中WebDriver和瀏覽器間因為執(zhí)行機制的不同而存在的競爭問題(race condition), 從而導致的可能的元素找不到問題。
接著用一個實例問題引入Selenium提供的該問題的解決方案-Waits,包括顯性等待,隱性等待以及流暢等待三個具體方法,并分別用代碼展示如何用這些方法來解決前文提到實例問題。
當然,該問題還有其它的解決方案,比如各語言自帶的等待方法,如Python和Java的sleep函數(shù)等。
END各位小伙伴都有哪些心儀的公司?或者還想知道什么哪家公司的面試經(jīng)歷,可以在評論區(qū)分享給其他小伙伴和小編,大家可以一起幫你參謀哦~
加入51Testing測試交流群,
每日干貨分享+技術(shù)交流~
掃碼后,備注【測試圈】即可~
鏈接:https://juejin.im/post/6868578613416067085本文為51Testing經(jīng)授權(quán)轉(zhuǎn)載,轉(zhuǎn)載文章所包含的文字來源于作者。如因內(nèi)容或版權(quán)等問題,請聯(lián)系51Testing進行刪除推薦閱讀點擊閱讀?手工測試工作量大!還不會自動化是想加班么?
點擊閱讀?搭建接口自動化測試環(huán)境,這3個工具就夠了
點擊閱讀?作為測試行業(yè)發(fā)展趨勢,自動化一點也不難啊!
點擊閱讀?安裝、配置2步走,自動化測試報告就生成了
點擊閱讀?如何使用Fiddler實現(xiàn)自動化測試錄制回放,看完這個你就懂了
戳 《新程序員》:云原生和全面數(shù)字化實踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的运行时错误76未找到路径怎么解决_自动化测试解决竞争问题?等待一下就行了~...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 列出5个python标准库_Python
- 下一篇: linux c语言文件拷贝_linux