面試——selenium常見面試題及答案(java)


自動化測試面試——selenium基礎篇

目的:考察求職者對自動化測試崗位的selenium工具的熟悉程度

1.怎么判斷元素是否存在?

判斷元素是否存在和是否出現不同, 判斷是否存在意味着如果這個元素壓根就不存在, 就會拋出NoSuchElementException

這樣就可以使用try catch,如果catch到NoSuchElementException 就返回false。通常在項目中會把這個功能封裝在isElementPresent方法中。

2.如何判斷元素是否出現?

判斷元素是否出現,存在兩種情況,一種是該元素壓根就沒有,自然不會出現;另外一種是有這樣的元素,但是是hidden狀態

可以通過先判斷是否存在,如果不存在返回false;如果存在再去判斷是否displayed。

3.selenium中hidden或者是display = none的元素是否可以定位到?

不能,想點擊的話,可以用js去掉dispalay=none的屬性。

4. selenium中如何保證操作元素的成功率?也就是說如何保證我點擊的元素一定是可以點擊的?

1.通過封裝find方法實現waitforEmelentPresent,這樣在對元素進行操作之前保證元素被找到,進而提高成功率

2.在對元素操作之前,比如click,如果該元素未display(非hidden),就需要先滾動到該元素,然后進行click操作;為啥使用滾動? 因為如果頁面沒有完全顯示,element如果是在下拉之后才能顯示出來,只能先滾動到該元素才能進行click,否則是不能click操作

1
2
3
JavascriptExecutor js=(JavascriptExecutor)driver;
         // roll down and keep the element to the center of browser
         js.executeScript( "arguments[0].scrollIntoViewIfNeeded(true);" , download);

3.不同方式進行定位,與expectedConditions判斷方法封裝,循環判斷頁面元素出現后再操作;

4.開發人員規范開發習慣,如給頁面元素加上唯一的name,id等。

5. 如何去定位頁面上動態加載的元素?

    觸發動態事件,然后findElemnt

    如果是動態菜單,需要一級一級find(JS實現)

6.如何去定位屬性動態變化的元素?

  屬性動態變化是指該element沒有固定的屬性值,所以只能通過相對位置定位

    比如通過xpath的軸, parent/following-sibling/precent-sibling等

    另外也可以嘗試findbyelements遍歷

7.點擊鏈接以后,selenium是否會自動等待該頁面加載完畢?

不會的。所以有的時候,當selenium並未加載完一個頁面時再請求頁面資源,則會誤報不存在此元素。所以首先我們應該考慮判斷,selenium是否加載完此頁面。其次再通過函數查找該元素。

8.自動化測試的時候是否需要連接數據庫做數據校驗?

一般來說1、 UI自動化不需要(很少需要);2、接口測試會需要:從數據庫層面來進行數據校驗可以更方便驗證系統的數據處理方面是否正確;

9.有幾種元素常用定位方式,分別是?你最偏愛哪一種,為什么?

8種:id、name、class name、tag name、link text、partial link text、xpath、css selector 偏愛哪一種?答:

我最常用的是xpath(或CssSelector)因為很多情況下,html標簽的屬性不夠規范,無法通過單一的屬性定位,這個時候就只能使用xpath可以去重實現定位唯一element

事實上定位最快的是Id,因為id是唯一的,然而大多數開發並沒有設置id。

10.怎么提高selenium腳本的自動化執行效率?

1.優化測試用例,盡可不使用 sleep,減少使用ImplicitlyWait

2.多使用selenium的WebDriverWait/FluentWait,這樣可以優化等待時間

3.減少不必要的操作步驟,如經過三四步才能打開我們要測試的頁面的話,我們就可以直接通過網址來打開,減少不必要的操作。

4.中斷頁面加載,如果頁面加載的內容過多,我們可以查看一下加載慢的原因,如果加載的內容不影響我們測試,就設置超時時間,中斷頁面加載。

5.使用性能好的電腦

11.用例在運行過程中經常會出現不穩定的情況,也就是這次可以通過,下次無法通過了,如何提高用例的穩定性?

1,查找元素前先做判斷:ExpectedConditions里面的各種方法;
2,顯式等待:多使用WebDriverWait,加上顯式等待時間,等要操作的元素出現之后再執行下面的操作;
3、多用try catch捕獲異常;
4,多線程的時候,減少測試用例耦合度,因為多線程的執行順序是不受控制的;
5,盡量使用測試專用環境,避免其他類型的測試同時進行,對數據造成干擾。

12.你的自動化用例的執行策略是什么?

1.自動化測試用例是用來監控的。集成到jenkins,創建定時任務定時執行;
2.有些用例在產品上線前必須回歸。jenkins上將任務綁定到開發的build任務上,觸發執行;
3.有些用例不需要經常執行。jenkins創建一個任務,需要執行的時候人工構建即可。

13.什么是持續集成?

頻繁的將代碼集成到主干,持續性的進行項目的構架,以便能能夠快速發現錯誤,防止分支大幅度偏離主干

14.webdriver client的原理是什么?

在selenium啟動以后,driver充當了服務器的角色,跟client和瀏覽器通信,client根據webdriver協議發送請求給driver。driver解析請求,並在瀏覽器上執行相應的操作,並把執行結果返回給client.

15.webdriver的協議是什么?

The Wire Protocol

16.啟動瀏覽器的時候用到的是哪個webdriver協議

http

17. 什么PO模式,什么是page factory?

    PO模式是page object model的縮寫,顧名思義, 是一種設計模式,把每個頁面當成一個頁面對象,頁面層寫定位元素方法和頁面操作方法,實現腳本的page和真實的網站頁面Map起來,一一對應起來。這樣能測試框架更容易維護。 比如一個登陸頁面,使用PO模式后,會創建一個LoginPage的class,該class會定義用戶名輸入框,密碼輸入框,登陸按鈕的webElenent;用例層從頁面層調用操作方法,寫成用例,這種模式可以做到定位元素與腳本分離。所以這樣的設計理念就是PO模式。 而PageFactory隸屬PO模式,是用來初始化每個PO模式實現的Page Class,初始化對象庫。

18.怎樣去選擇一個下拉框中的value=xx的option?

1.select類里面提供的方法:selectByValue(“xxx”)
2.xpath的語法也可以定位到

19.如何在定位元素后高亮元素?

重置元素屬性,給定位的元素加背景、邊框

20. 如何設計高質量自動化腳本

1. 使用四層結構實現業務邏輯、腳本、數據分離。

2. 使用PO設計模式,將一個頁面用到的元素和操作步驟封裝在一個頁面類中。如果一個元素定位發生了改變,我們只用修改這個頁面的元素屬性。

3. 對於頁面類的方法,我們盡量從客戶的正向邏輯去分析,方法中是一個獨立場景,例如:登錄到退出,而且不要想着把所有的步驟都封裝在一個方法中。

4. 測試用例設計中,減少測試用例之間的耦合度。

21.get和post 的區別?

1、GET請求:請求的數據會附加在URL之后,以?分割URL和傳輸數據,多個參數用&連接。
   POST請求:POST請求會把請求的數據放置在HTTP請求包的包體中。
2、傳輸數據的大小
使用GET請求時,傳輸數據會受到URL長度的限制。
對於POST,理論上是不會受限制的
3、安全性。POST的安全性比GET的高

先到此為止,后續接着總結.....

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM