Web自動化測試框架 架構的設計
【生生不息原創】自己動手寫Web自動化測試框架7 - 框架架構的設計
上次我們分析了什麼是我們想要的自動化測試框架,這一次我們基於上一次的分析,來設計我們的自動化測試框架架構。
首先,我們需要一個類,去做幫助我們處理和IE相關的事情,幫助我們操縱IE,開啟和關閉IE。然後,我們需要一組的類,來描述網頁上的元素,比如TextBox和Button,去模擬他們的事件,去取得他們的狀態。總體來說就是封裝這些元素。
除此之外,我們還需要一些輔助的類來幫助我們做一些工作。
接下來我們就先去分析幫助我們操縱IE的類應該有那些功能。所以我們把這個類命名為WebBrowser。參考附帶的WebBrowser.cs檔案。
首先,我們需要一些內部的成員和輔助類,我們開啟的IE程序會用SHDocVw.InternetExplorer類來接受,我們可以把這個變數存在整個類的私有變數去。還有我們其實要取出的是這個網頁的HTMLDocument類,以供以後來使用。這裡我們直接寫成了internal,成員變數,其實可以封裝成一個屬性,看大家的用法了。除了這些,我們還需要一個Timer類,這個類幫助我們完成一些計時的工作。見附帶的timer.cs檔案。
其次,開啟IE程序這樣的事情應該是由這個類來做的,由於這次對WebBrowser的要求不高,我就在構造函數里面講IE程序初始化好,具體如何處理這些請參見《【生生不息原創】自己動手寫Web自動化測試框架2 - 開啟和操縱IE》。我們給這個類建構函式提供了一個帶有string引數的方法,目的是讓使用者可以方便的'傳入URL而開啟瀏覽器並且轉到我們要的頁面去。當我們沒有引數給建構函式時,使用者就會得到一個空的頁面。
再次,我們需要一個NavigateTo函式,來操縱瀏覽器轉到某一個地方去。這個函式不多說,就是我們以前的內容。
最後,我們在這裡添加了一個DoWait的函式,這個函式的主要目的是完成我們《【生生不息原創】自己動手寫Web自動化測試框架5 - 判斷瀏覽器是否載入完成》裡面所討論的等待瀏覽器載入完成。DoWait放在這裡的原因是我們需要在幾個地方判斷頁面載入完成:瀏覽器瀏覽到了新的頁面、使用者點選了某些按鈕或者連結、或者甚至使用者改變了控制元件的狀態,導致頁面回刷,這幾個地方會分別被WebBrowser和以後的Web控制元件類所使用,所以我們把這個DoWait放在WebBrowser裡面,以後的Web控制元件回去引用WebBrowser類的這個方法來判斷瀏覽器是否完成載入。
Notice注意,這裡把DoWait的程式碼寫在WebBrowser裡面是基於我們以上的頁面沒有Ajax和框架的假設做出的,如果頁面可能有Ajax,我們就不可能簡簡單單的用這個DoWait去等待載入完成。
我們以後會有對目前框架的改進文章,這些文章會討論這些問題。
這樣我們的WebBrowser就大概寫完了。下一次我們會講解一組類來實現Web控制元件。
[Web自動化測試框架 架構的設計]相關文章:
1.架構師面試題參考
2.軟體測試工程師