selenium+python面試題目總結


1. WebDriver原理

webDriver是按照client/server模式設計,client就是我們的測試代碼,發送請求,server就是打開的瀏覽器來打開client發出的請求並做出響應。

具體的工作流程:

·webdriver打開瀏覽器並綁定到指定端口。啟動的瀏覽器作為remote server.

·client通過commandExecuter發送httpRequest給remote server的的偵聽端口(the      webdriver wire control通信協議)

·Remote server根據原生的瀏覽器組件來轉化為瀏覽器的native調用。

備注:啟動瀏覽器的時候,使用的是http: hyper test transfer protocol

 

2. Selenium 特點和組成

Selenium是一個針對web應用的開源測試框架,它的測試用例可以用html table或者html 代碼或者編程語言進行開發,而且他能在幾乎所有的現在的瀏覽器上執行。Selenium可以被部署到windows.linux.mac平台上,支持的語言有java/python/ruby/.net/perl

特點:

·支持錄制回放

·多種方式對頁面元素進行定位並操作

·能夠及進行debug和設置斷點

·能夠把測試腳本保存成html/ruby或者其他語言

·支持user-extensions.js形式的用戶擴展

·能夠進行頁面的斷言

1) Selenium IDE: 是firefox的插件,可以錄制/回放/測試腳本

2) Selenium RC:支持程序語言(java/C#/python/ruby)編寫測試用例; selenium和其他測試框架集成,比如java環境下將selenium和Junit集成,利用selenium來書寫測試用例,用Junit來實現測試用例的自動化運行。

3) Selenium Core:是selenium的核心,是有js和html文件組成,它是selenium IDE和selenium RC的核心引擎。

4) Selenium Grid:是selenium的擴展,可以將一批selenium腳本分配到不同的測試機上同步運行。即selenium grid可以在不同的主機上建立主節點(hub)和分支節點(node), 可以使主節點上的測試用例在不同的分支節點上運行。對於不同的節點來說,可以搭建不同的測試環境(操作系統/瀏覽器)。

 

3. Selenium內部運行機制

 

4. 如何提高自動化腳本穩定性

找原因

1)網速原因,增加時間等待

2)函數原因,盡量少使用容易沖突的函數

3)配置testNG實現多線程,在編寫測試用例的時候,一定要實現松耦合,在服務器允許的情況下盡量設置多線程運行,提高執行速度。

 

5. 高質量自動化腳本特點

業務和代碼分離,封裝型好。

自動化用例耦合性低,獨立性強,易於擴展維護

 

6. 自動化測試缺陷

不穩定

可靠性不強

不易維護

成本與收益

 

7. 自動化用例的執行策略

根據自動化執行的目的來決定

(1)自動化測試用例執行用來監控,可以設置用例定時執行;

(2)用於回歸測試,可以把測試用例設置成觸發式執行;

(3)不需要經常執行的測試用例,可以由人工執行。

 

8. 提高selenium腳本的執行速度方式

1)減少操作步驟,減少不必要的操作;

2)中斷頁面加載,如果頁面加載內容過多並且加載的內容不影響我們測試,可以設置超時時間,中斷頁面加載;

3)設置等待時間的時候,可以sleep()固定的時間,檢測到元素出現后中斷等待也可以提高速度;

4) 配置testNG實現多線程,在編寫測試用例的時候,一定要實現松耦合,在服務器允許的情況下盡量設置多線程運行,提高執行速度。

 

9. 元素定位

1) Id定位

find_element_by_id(‘kw’)   //通過id屬性定位

2) Name定位

find_element_by_name(‘wd’)    //通過名字進行定位,名字一般不唯一,一般不能        通    過其定位

3) ClassName定位

find_element_by_class_name(‘cn’)   //通過類名進行定位

4) TagName定位

find_element_by_tag_name(‘input’)  //標簽,一般用於一類元素的定位

5) LinkText定位

find_element_by_link_text(‘新聞’)  //文本鏈接定位

6) PartialLinkText定位

find_element_by_partial_link_text(‘一個很長的’) //文本鏈接的部分文字

7) 絕對路徑定位

   find_element_by_xpath(‘/html/body/div/div[2]/form/span/input[2]’) //絕對地址定位,                 利用層級定位

   find_element_by_xpath(‘//input[@name=’n’ and id=’kw’]’) //當前頁面某個目錄下                         name為n,id為kw的input標簽,利用元素屬性進行定位

   find_element_by_xpath(‘//*[@id=kw]’) //其中*表示任何屬性,表示id為kw的任何屬                 性的元素

   find_element_by_xpath(‘//span[@class=’c’]/input’) //層級和屬性結合進行定位

   find_element_by_xpath(‘//a[contains(href , ’test’)]’)

8) 相對路徑定位

相對路徑定位一般比絕對路徑定位快。

       find_element_by_css_selector(‘.class1’) // 類名定位 .class

   find_element_by_css_selector(‘#id’) //id定位 #id

   find_element_by_css_selector(‘input’) // 標簽名定位

   find_element_by_css_selector(‘[autocomplete=off]’) //屬性定位

   find_element_by_css_selector(‘span>input’) //標簽名為span的input子元素

9) 定位一組元素

Checkboxes = find_elements_by_tag_name(‘checkbox’)

for checkbox in Checkboxes:

checkbox.click()  # 通過for循環全選所有的checkbox

Checkboxes.pop().click()  #取消勾選一些checkbox,pop(-1)=pop()表示一組元素的最后一個;pop(0)      表示一組元素的第一個,pop(1)表示一組元素的第二個,以此類推

10) 父子/兄弟/相鄰節點的定位

·父->子

Find_element_by_id(‘parent’).find_element_by_tag_name(‘input’) 串聯尋找

Find_element_by_xpath(‘//input/div[@name=’n’]/span/input[1]’)  xpath的層級

Find_element_by_css_selector(‘div#b>input’) css selector的父子關系

·子->父

Find_element_by_xpath(‘//div[@id=’c’]/../..’) 其中//div[@id=’c’]的父親的父親

·哥哥->弟弟

Find_element_by_xpath(‘//div[@id=’c’’/../div[1]) 找到弟弟后找父親然后找哥哥

Find_element_by_css_selector(‘div#d+div’) 表示id=d的div后面緊跟着的div

Find_element_by_css_selector(‘div#d~div’) 表示id=d的div后面同一級所有div

11) 二次定位

Element1 = driver.find_element_by_id(‘ID1’)

Element2 = Element1.find_element_by_id(‘ID2’)

12) display: none 和hidden的區別

共同點:把網頁中的某個元素隱藏起來;他們在selenium中都是定位不到的。

區別:display:none不為隱藏的對象保留其物理空間,該對象在這個頁面上徹底消失,看不到/摸不到;hidden使對象在網頁上不可見,但該對象在網頁中依然占有空間,看不到/摸得到。

備注:isElementPresent()來判斷元素是否存在。

 

10. 常見控件使用

1) link/button:

element.click()

注:ajax不能使用clickAndWait()函數,因為cickAndWait函數會在click之后等待頁面重新加載完成,而ajax是部分刷新,所以這個頁面不能重新加載完成。

2) Textbox:

element.send_keys(‘test’)

 

3) Upload

Driver.find_element_by_id(‘id’).send_keys(‘D\test.txt’)

 

4) Mouse Event:

e1=driver.find_element_by_id(‘kw’)

ActionChains(driver).double_click()/.context_click()/.drag_and_drop()/.move_to_eleme        nt()/.perform()   # 雙擊/右擊/拖動/懸停/執行actionChains中的行為

 

5) Dropdown:

·<Select>標簽的下拉菜單

from selenium.webdriver.support.ui import Select

Select(driver.find_element_by_id(‘gender’)).select_by_index(1)

Select(driver.find_element_by_id(‘gender’)).select_by_value(“2”)

Select(driver.find_element_by_id(‘gender’)).select_by_visible_text(“Male”)

·非<Select>標簽的下拉菜單

Dropdown1 = driver.find_element_by_id(‘id’) #先定位到dropdown

Dropdown1.find_element_by_id(“li2_input_2”) #再定位到dropdown中的值

 

6) Alert:

driver.switch_to.alert.accept()//接受

driver.switch_to.alert.dismiss() //取消

Message=driver.switch_to.alert.text  //獲取彈窗的文本消息

driver.switch_to.alert.send_keys(‘hello’) //輸入值,這個在alert和confirm中不可用

 

7) Window

Driver.refresh() 刷新

Driver.back() 后退

Driver.forward() 前進

Driver.maximize_window() 最大化

Driver.set_window_size(100,200) 設置窗口大小

Driver.switch_to.window(searchwindow)

 

8) Frame

Driver.switch_to.frame(ReferenceFrame)

Driver.switch_to.parent_frame()  # frame需要一級一級切

Driver.switch_to.default_content()

 

11. 等待

1) 顯式等待

等待某個條件成立時繼續執行,每隔一段時間進行檢測,超出最大時間    則拋出異常(程序每隔X秒看一眼,如果條件成立,執行下一步,否則等待,超出最大    時間,拋出異常)

From selenium.webdriver.common.by import By

From selelnium.webdirver.support.ui import WebDriverWait

From selenium.webdriver.support import expected_conditions as EC

E = WebDriverWait(driver, 5,0.5).until(

EC.presence_of_element_located( (By.ID, ‘kw’) )

)

2) 隱式等待

隱式等待中的時間並非一個固定的等待時間,它並不影響腳本的執行速度。比如進行某元素的定位時,如果元素可以定位就繼續執行,如果目前定位不到就以輪詢的方式持續判斷該元素是否被定位到,如果超過規定的時間還沒定位到就拋出異常。(甲約乙去吃飯,甲在這里等着,等了10分鍾乙到達,則從10分鍾之后開始下一步,假如等了20分鍾,則20分鍾后開始下一步,如果到了最大時間30分鍾還沒到就拋異常)

driver.implicitly_wait(20)

3) 強制等待

From time import sleep

Sleep(2)

12. 截圖

driver.get_screenshot_as_file('E:\sc.jpg')

13. 線性測試

開發維護成本高

14. 模塊化驅動測試

將重復的操作獨立為公共模塊,盡量消除重復,提高測試用例的可維護性。

15. 數據驅動測試

數據參數化

1) 讀取txt文件

File= open(‘E:\wtest.txt’, ‘r’)

Lines = File.readlines()

For line in lines:

User = line.split(‘,’)[0]

Passw=line.split(‘,’)[1]

Print(User, Passw)

2) 讀取csv文件

UnicodeDecodeError (未找到解決方案)

3) 讀取xml文件

 

16. 關鍵字驅動測試

腳本/數據/業務 分離

 

17. page object設計模式

是將page對象封裝成一個HTML頁面,通過提供的應用程序特定的API來操作頁面元素,而不是在html中來搜尋對象,即提供一個易於編程的接口並隱藏窗口中底層的部件,對界面的交互細節進行封裝。

優點是:減少了代碼的重復/提高測試用例的可讀性/提高測試用例的可維護性(特別是UI頻繁變化的項目)

page object設置模式中,不需要在page里定位的方法中加上斷言(why)

 

18. Assert斷言

-斷言的英文是assertion,斷言檢查的英文是assertion checking。

-斷言是指定一個程序必須已經存在的狀態的一個邏輯表達式,或者一組程序變量在程序執行期間的某個點上必須滿足的條件。

Assert判斷如果出現錯誤,則會中斷整個測試;使用verify進行判斷如果出現錯誤仍會繼續執行直到結束。

 

19. Dsfdsadsaf

20. Dsaf倒數


免責聲明!

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



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