《一頭扎進》系列之Python+Selenium框架設計篇1- 價值好幾K的框架,不看別後悔,過時不候
- 2019 年 12 月 20 日
- 筆記
1. 什麼是自動化測試框架
在了解什麼是自動化測試框架之前,先了解一下什麼叫框架?框架是整個或部分系統的可重用設計,表現為一組抽象構件及構件實例間交互的方法;另一種定義認為,框架是可被應用開發者定製的應用骨架。前者是從應用方面,而後者是從目的方面給出的定
義。 從框架的定義可以了解,框架可以是被重用的基礎平台;框架也可以是組織架構類的東西。其實後者更為貼切,因為框和架本來就是組織和歸類所用的。
所以自動化測試框架的定義為:由一個或多個自動化測試基礎模塊、自動化測試管理模塊、自動化測試統計模塊等組成的工具集合。
按框架的定義來分,自動化測試框架可以分為:基礎功能測試框架、管理執行框架;按不同的測試類型來分,可以分為:功能自動化測試框架、性能自動化測試框架;按測試階段來分,可以分為:單元自動化測試框架、接口自動化測試框架、系統自動化測試框
架;按組成結構來分,可以分為:單一自動化測試框架、綜合自動化測試框架;按部署方式來分,可以分為:單機自動化測試框架、分佈式自動化測試框架。
在百度百科中是這樣定義的:自動化測試框架,即是應用於自動化測試所用的框架。按照框架的定義,自動化測試框架要麼是提供可重用的基礎自動化測試模塊,如:selenium [1] 、watir等,它們主要提供最基礎的自動化測試功能,比如打開一個程序,模擬鼠
標和鍵盤來點擊或操作被測試對象,最後驗證被測對象的屬性以判斷程序的正確性;要麼是可以提供自動化測試執行和管理功能的架構模塊,如:Phoenix Framework,robot [2] ,STAF [3] 等,它們本身不提供基礎的自動化測試支持,只是用於組織、管理和執
行那些獨立的自動化測試用例,測試完成後統計測試結果,通常這類框架一般都會集成一個基礎自動化測試模塊,如:robot框架就可以集成selenium [4] 框架,Phoenix Framework集成的也是selenium框架。
簡單來說,自動化測試框架就是由一些標準,協議,規則組成,提供腳本運行的環境。自動化測試框架能夠提供很多便利給用戶高效完成一些事情,例如,結構清晰開發腳本,多種方式、平台執行腳本,良好的報告去跟蹤腳本執行結果。
框架具有以下一些優點:
1)代碼復用
2)最大覆蓋率
3)很低成本維護
4)很少人工干預
5)簡單報告輸出
2. 為什麼要進行自動化測試?
①、黑盒測試回歸效率低
②、手動測試的偶然性和不確定性
③、回歸的覆蓋率不足
④、交付的產品質量無法保證,全靠評估
⑤、系統越複雜,問題越多
⑥、上線時間長、構件失敗率高導致的蝴蝶效應(迭代快,加班多)
3. 自動化測試能解決什麼問題?
①、提高出現問題後的響應速率
②、降低回歸成本
③、提高回歸覆蓋率
④、提高回歸效率
⑤、提高回歸的穩定性
4. 自動化測試的不足有哪些?
①、無法減少成本投入,而是為了加快測試結果反饋,提升測試質量
②、自動化適用於回歸和冒煙,而不是發現BUG
③、錄製回放功能是雞肋,可視化並不是一個很好的做法
④、不是所有所有系統所有功能都適合做自動化測試
5. 常見的測試框架分類
好多Selenium自動化測試開發人員是有QTP那邊轉過來的,所以,他們在早期設計的框架大致可分為以下幾類:
1)基於模塊的測試框架
2)基於庫(Library)結構測試框架
3)數據驅動測試框架,和QTP很像
4)關鍵字驅動測試框架,也是QTP過來的
5)混合測試框,3 4和綜合
6)行為驅動開發測試框架
這裡我們不一一介紹這些框架,字面意思可以想像一些這些框架的背景和組件,本文只是對框架有一個基本了解。
6. 框架基本組件
我們來思考下框架組成部分:
1)需要配置文件管理
2)業務邏輯代碼和測試腳本分離
3)報告和日誌文件輸出
4)自定義的庫的封裝
5)管理、執行腳本方式
6)第三方插件引入
7)持續集成
解釋:
我們需要一個配置文件去控制一些,環境信息,開關,配置文件可以是txt/xml/yaml/properties/ini,一般.properties使用較多在JAVA里,本文是Python系列,我可能會選擇ini文件。
業務邏輯代碼和測試腳本分離,不像我們剛開始學習Selenium那樣,代碼和腳本在一個類文件里演示。我們根本沒有用到代碼重構,復用。代碼和用例文件分離後,更加清晰,去多人開發腳本,方便調試。
報告和日誌文件輸出,你執行了多少case,case結果如何,這都需要報告來展示,一般採用第三方插件來實現這個功能,好多報告格式是html,簡單,明了的風格。日誌輸出也很重要,如果發生報錯,腳本執行失敗,通過日誌快速定位發生問題位置。
用戶自定義庫,這個很好理解,我們很多功能需要重複調用,這樣我們就寫成一個公用方法,放到工具包下,每次方便調用,例如瀏覽器引擎類和basepage.py的封裝。
管理和執行腳本的方式,例如Python中單元測試框架unittest使用率非常高。
第三方插件,有時候,我們一些功能,需要藉助第三方插件,能夠更好實現,例如AutoIT,來實現文件上傳和下載。還有利用第三方報告插件生成基於html格式的測試報告。
持續集成,git,svn,ant,maven,jenkins,我們會把這整合到jenkins,達到持續集成,一鍵執行測試腳本。
7. 自動化框架概要設計
根據以上的框架基本組件特點介紹,宏哥大致用以下圖來描述一下,一個簡單的自動化測試框架,可能包含配置文件、框架的主要代碼、產品業務頁面、測試腳本集合、日誌和報告和持續集成等等這些組成部分吧,目前想到的只有這麼多,如果後期想到宏哥再進一步完善它。

8. 自動化框架詳細設計
根據以上的框架概念設計的特點介紹,宏哥這裡詳細地用以下圖來描述一下,一個簡單而又實用的自動化測試框架,可能包含以下這些組成部分。宏哥目前細化到這裡,後期會將這個框架的代碼放到github上,歡迎有興趣和有能力的大佬給出建議或者完善這個自動化測試框架。

9. 小結
框架的簡單介紹就到這裡,有些人把框架想得太複雜了,框架無非就是一些軟件的集合,達到特定的目的。這裡我們上圖畫出來的框架,就是一個簡單的自動化測試框架,別笑,這確實是一個簡單但又包含必要的組件的自動化測試框架設計實例,如果你學會了這個設計思路和思想,那麼,你已經達到了自動化測試第二個階段的水平:能夠簡單設計自動化測試框架和維護框架的能力。
好了,今天的分享就到這裡吧!!!謝謝各位的耐心閱讀。