菜鳥學(xué)自動化測試(七)----selenium RC 工作原理
關(guān)于selenium RC環(huán)境搭建(基于java語言),我在系統(tǒng)的學(xué)習(xí)selenium之前已經(jīng)做了,并在我的這個系列的文章中可以找到。那是照著一位前輩的視頻操作完成的,我詳細的記錄的操作步驟。
在這里我們一起了解一下selenium RC的工作原理。
簡介
那么之前學(xué)習(xí)的了selenium IDE與selenium命令,那么是不是我們用selenium IDE可以完成我們的所有自動化測試工作了呢?No !Selenium IDE 沒我們認為的那么強大,在實際的項目中會有各種復(fù)雜的操作,如條件判斷、循環(huán)、讀寫文件、查詢數(shù)據(jù)庫和E—mail郵寄測試報告。這些都不是selenium IDE簡單的錄制能完成的。
Selenium RC可以適應(yīng)更復(fù)雜的自動化測試需求,而不僅僅是簡單的瀏覽器操作和線性執(zhí)行。Selenium RC 能夠充分利用編程語言來構(gòu)建更復(fù)雜的自動化測試案例。
Selenium RC工作原理
那么Selenium RC組件是如何運轉(zhuǎn)的,以及他們在測試案例運行過程中扮演什么角色。
說明客戶端庫文件將命令傳遞給server。接著server使用selenium-Core的javaScript命令傳遞給瀏覽器,瀏覽器會使用自帶的javaScript翻譯器來執(zhí)行selenium命令。這意味著測試腳本中的selenese操作和驗證將被執(zhí)行。
* Selenium server
它負責(zé)啟動和關(guān)閉瀏覽器,解釋和運行從測試程序傳來的selenese命令,像HTTP代理一樣,截取和驗證瀏覽器與待測應(yīng)用(AUT)之間的HTTP消息。
在測試程序打開瀏覽器時(使用客戶端庫文件的API函數(shù)),RC server綁定 selenium Core并自動將它嵌入到瀏覽器中。selenium Core是一個javaScript程序,實際上市一系列javaScript函數(shù),它們使用瀏覽器內(nèi)置的javaScript翻譯器來翻譯和執(zhí)行selenese命令。
* 客戶端文件
客戶端庫文件提供編程接口。允許你使用自己編寫的程序來運行selenese命令,對于不同的語言都有對應(yīng)的客戶端庫文件。類似于數(shù)據(jù)庫方言包的概念,如果你想用java操作數(shù)據(jù)庫,對于不同的數(shù)據(jù)庫,需要導(dǎo)入不同的數(shù)據(jù)庫驅(qū)動jar文件,mysql有mysql的方言包,DB有DB的方言包。
客戶端庫文件獲取一條selenise命令,并將它傳遞給selenium Server ,以便執(zhí)行一個指定操作或者基于待測應(yīng)用(AUT)進行測試?蛻舳藥煳募盏矫畹膱(zhí)行結(jié)果,在將其傳給你的測試程序。程序接收到結(jié)果后,將它保存在變量中。接著報告成功還是失敗,如果結(jié)果是意料之外的失敗,還能有針對性地采取正確措施。
因此要創(chuàng)建測試程序,你只要使用客戶端庫文件的API來編寫程序,程序會去運行一系列selenium命令,當(dāng)然selenium IDE錄制的內(nèi)容生成selenese測試腳本,可以轉(zhuǎn)換成不同測語言腳本。
Selenium RC 架構(gòu)
下面我們來了解隱藏在selenium RC背后的技術(shù)實現(xiàn)。要了解selenium RC Server 工作的細節(jié),需要我們理解下面幾個概念。
1. 同源規(guī)則
Selenium面臨的主要限制是同源規(guī)則,市場上的每一款瀏覽器都應(yīng)用了這一安全限制。其目的是確保一個站點的內(nèi)容不會被另一個站點的腳本所訪問。同源規(guī)則專注于確保瀏覽器加載的任何代碼,都只能在同一站點內(nèi)部進行操作。假如你在一個瀏覽器的一個選項卡內(nèi)打開了一個網(wǎng)上銀行的頁面(www.yinhang.com)。又在另選項卡上不小心打開了一個掛馬的頁面(www.guama.com),那么掛馬的頁面是不能操作網(wǎng)上銀行頁面的內(nèi)容,因為引入了同源規(guī)則。所以,他們不能相互作用。如果不引入同源規(guī)則,我們可以想象用戶很生氣,后果很嚴重。
要在這一規(guī)則下工作,selenium Core必須與待測系統(tǒng)在同一源中。在歷史上,selenium Core被這一問題所限制,因為它是用javaScrpt實現(xiàn)的。但是selenium RC 沒有被同源規(guī)則所限制,它使用selenium Server作為單利來回避這一問題,“哄騙”瀏覽器,讓瀏覽器以為自己在server提供的單一站點上工作。
同源:相同的協(xié)議、端口、域名
感興趣的同學(xué)google“同源規(guī)則”和“XSS(跨站點執(zhí)行腳本)”相關(guān)技術(shù)
2. 代理注入
selenium 用來規(guī)避同源規(guī)則的第一種方法是代理注入,在代理注入模式下,selenium Server 像客戶端配置的HTTP代理一樣工作,它位于瀏覽器和待測系統(tǒng)之間。接著其偽造待測系統(tǒng)的URL(集成selenium Core 和一系列測試案例并加以傳遞,它們像同源一樣)
代理作為第三者,在雙方間傳遞信息,它表現(xiàn)的像一個“web服務(wù)器”,想瀏覽器傳遞待測系統(tǒng)。作為代理selenium Server ,它擁有篡改待測系統(tǒng)真實URL的能力。
瀏覽器啟動時,使用配置的profile,其中已經(jīng)設(shè)置localhost:4444作為HTTP代理,這是為什么任何來自瀏覽器的HTTP請求都會經(jīng)過selenium Server,而且HTTP響應(yīng)也來自selenium Server而非真實的服務(wù)器。
(1)客戶驅(qū)動與selenium RC Server之間建立起一個鏈接。
(2)Selenium RC Server 啟動瀏覽器,并在瀏覽器加載頁面中注入了Selenium Core 的javaScript
(3)客戶端驅(qū)動給Server傳遞一條Selenese命令
(4)客戶端驅(qū)動個Server解釋命令,并觸發(fā)對應(yīng)的javaScript在瀏覽器中執(zhí)行。
(5)Selenium Core指示瀏覽器執(zhí)行第一條指令,例如打開一個待測系統(tǒng)頁面。
(6)瀏覽器接收到打開請求后,向Selenium RC Server(作為瀏覽器的HTTP代理),要求web站點內(nèi)容。
(7)Selenium RC Server與web服務(wù)器通信,請求頁面,并且一旦收到響應(yīng)將頁面?zhèn)鬟f給瀏覽器,但它會篡改源,是頁面看上去好像來自于與selenium Core同源的服務(wù)器。
(8)瀏覽器接收到web頁面后,在保留的框架窗口中展示頁面。
3. 提高瀏覽器權(quán)限
這一方式下的工作流與代理注入十分相似,區(qū)別在于瀏覽器以特殊模式-------“高特權(quán)模式”啟動。它允許瀏覽器做一些通常不被允許的事情,如XSS。通過這個瀏覽器模式,Selenium Core 可以直接帶卡待測系統(tǒng),并讀取和操作其中的內(nèi)容,而不需要通過Selenium RC Server來傳遞整個待測系統(tǒng)。
(1)客戶驅(qū)動與selenium RC Server之間建立起一個鏈接。
(2)Selenium RC Server啟動瀏覽器,其實用的URL會在頁面中加載 Selenium Core
(3)Selenium Core 從客戶端啟動得到第一條指令(通過Selenium RC Server)
(4)Selenium Core 執(zhí)行第一條指令。
(5)瀏覽器接到打開請求,向web服務(wù)器請求頁面,一旦瀏覽器接收到web頁面后,在保留的框架窗口中展示頁面。
===========================================================================
圖不優(yōu)雅,但也是自己花費一個多小時畫的。
關(guān)于selenium RC 的工作原理。沒有hyddd將的好,也沒他理解的深入。但也算是自己小小的總結(jié)。