菜鳥學自動化測試(七)----selenium RC 工作原理


 

 

關於selenium RC環境搭建(基於java語言),我在系統的學習selenium之前就已經做了,並在我的這個系列的文章中可以找到。那是照着一位前輩的視頻操作完成的,我詳細的記錄的操作步驟。

在這里我們一起了解一下selenium RC的工作原理。

 

簡介

那么之前學習的了selenium IDEselenium命令,那么是不是我們用selenium IDE就可以完成我們的所有自動化測試工作了呢?No !Selenium IDE 沒我們認為的那么強大,在實際的項目中會有各種復雜的操作,如條件判斷、循環、讀寫文件、查詢數據庫和Email郵寄測試報告。這些都不是selenium IDE簡單的錄制就能完成的。

Selenium RC可以適應更復雜的自動化測試需求,而不僅僅是簡單的瀏覽器操作和線性執行。Selenium RC 能夠充分利用編程語言來構建更復雜的自動化測試案例。

 

Selenium RC工作原理

 

那么Selenium RC組件是如何運轉的,以及他們在測試案例運行過程中扮演什么角色。

 

 

 

  

說明客戶端庫文件將命令傳遞給server。接着server使用selenium-CorejavaScript命令傳遞給瀏覽器,瀏覽器會使用自帶的javaScript翻譯器來執行selenium命令。這意味着測試腳本中的selenese操作和驗證將被執行。

 

 

* Selenium server

它負責啟動和關閉瀏覽器,解釋和運行從測試程序傳來的selenese命令,就像HTTP代理一樣,截取和驗證瀏覽器與待測應用(AUT)之間的HTTP消息。

 

在測試程序打開瀏覽器時(使用客戶端庫文件的API函數),RC server綁定 selenium Core並自動將它嵌入到瀏覽器中。selenium Core是一個javaScript程序,實際上市一系列javaScript函數,它們使用瀏覽器內置的javaScript翻譯器來翻譯和執行selenese命令。

* 客戶端文件

 

客戶端庫文件提供編程接口。允許你使用自己編寫的程序來運行selenese命令,對於不同的語言都有對應的客戶端庫文件。類似於數據庫方言包的概念,如果你想用java操作數據庫,對於不同的數據庫,需要導入不同的數據庫驅動jar文件,mysqlmysql的方言包,DBDB的方言包。

 

客戶端庫文件獲取一條selenise命令,並將它傳遞給selenium Server ,以便執行一個指定操作或者基於待測應用(AUT)進行測試。客戶端庫文件收到命令的執行結果,在將其傳給你的測試程序。程序接收到結果后,將它保存在變量中。接着報告成功還是失敗,如果結果是意料之外的失敗,還能有針對性地采取正確措施。

 

因此要創建測試程序,你只要使用客戶端庫文件的API來編寫程序,程序會去運行一系列selenium命令,當然selenium IDE錄制的內容生成selenese測試腳本,可以轉換成不同測語言腳本。

 

 

Selenium RC 架構

 

下面我們來了解隱藏在selenium RC背后的技術實現。要了解selenium RC Server 工作的細節,需要我們理解下面幾個概念。

 

1. 同源規則

Selenium面臨的主要限制就是同源規則,市場上的每一款瀏覽器都應用了這一安全限制。其目的是確保一個站點的內容不會被另一個站點的腳本所訪問。同源規則專注於確保瀏覽器加載的任何代碼,都只能在同一站點內部進行操作。假如你在一個瀏覽器的一個選項卡內打開了一個網上銀行的頁面(www.yinhang.com)。又在另選項卡上不小心打開了一個掛馬的頁面(www.guama.com),那么掛馬的頁面是不能操作網上銀行頁面的內容,因為引入了同源規則。所以,他們不能相互作用。如果不引入同源規則,我們可以想象用戶很生氣,后果很嚴重。

 

要在這一規則下工作,selenium Core必須與待測系統在同一源中。在歷史上,selenium Core被這一問題所限制,因為它是用javaScrpt實現的。但是selenium RC 沒有被同源規則所限制,它使用selenium Server作為單利來回避這一問題,“哄騙”瀏覽器,讓瀏覽器以為自己在server提供的單一站點上工作。

同源:相同的協議、端口、域名

 

感興趣的同學google“同源規則”和“XSS(跨站點執行腳本)”相關技術

 

2. 代理注入

 

selenium 用來規避同源規則的第一種方法是代理注入,在代理注入模式下,selenium Server 像客戶端配置的HTTP代理一樣工作,它位於瀏覽器和待測系統之間。接着其偽造待測系統的URL(集成selenium Core 和一系列測試案例並加以傳遞,它們就像同源一樣)

 

代理作為第三者,在雙方間傳遞信息,它表現的像一個“web服務器”,想瀏覽器傳遞待測系統。作為代理selenium Server ,它擁有篡改待測系統真實URL的能力。

 

瀏覽器啟動時,使用配置的profile,其中已經設置localhost:4444作為HTTP代理,這就是為什么任何來自瀏覽器的HTTP請求都會經過selenium Server,而且HTTP響應也來自selenium Server而非真實的服務器。

 

 

 

(1)客戶驅動與selenium RC Server之間建立起一個鏈接。

(2)Selenium RC Server 啟動瀏覽器,並在瀏覽器加載頁面中注入了Selenium Core javaScript

(3)客戶端驅動給Server傳遞一條Selenese命令

(4)客戶端驅動個Server解釋命令,並觸發對應的javaScript在瀏覽器中執行。

(5)Selenium Core指示瀏覽器執行第一條指令,例如打開一個待測系統頁面。

(6)瀏覽器接收到打開請求后,向Selenium RC Server(作為瀏覽器的HTTP代理),要求web站點內容。

(7)Selenium RC Serverweb服務器通信,請求頁面,並且一旦收到響應就將頁面傳遞給瀏覽器,但它會篡改源,是頁面看上去好像來自於與selenium Core同源的服務器。

(8)瀏覽器接收到web頁面后,就在保留的框架\窗口中展示頁面。

 

3. 提高瀏覽器權限

 

這一方式下的工作流與代理注入十分相似,區別在於瀏覽器以特殊模式-------“高特權模式”啟動。它允許瀏覽器做一些通常不被允許的事情,如XSS。通過這個瀏覽器模式,Selenium Core 可以直接帶卡待測系統,並讀取和操作其中的內容,而不需要通過Selenium RC Server來傳遞整個待測系統。

 

 

(1)客戶驅動與selenium RC Server之間建立起一個鏈接。

(2)Selenium RC Server啟動瀏覽器,其實用的URL會在頁面中加載 Selenium Core

(3)Selenium Core 從客戶端啟動得到第一條指令(通過Selenium RC Server

(4)Selenium Core 執行第一條指令。

(5)瀏覽器接到打開請求,向web服務器請求頁面,一旦瀏覽器接收到web頁面后,就在保留的框架\窗口中展示頁面。

===========================================================================

圖不優雅,但也是自己花費一個多小時畫的。

關於selenium RC 的工作原理。沒有hyddd將的好,也沒他理解的深入。但也算是自己小小的總結。

http://www.cnblogs.com/hyddd/archive/2009/05/30/1492536.html 歡迎參考hyddd的博客學習selenium


免責聲明!

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



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