1、Appium自動化測試架構
Appium是一個C/S架構的自動化測試框架,Appium的核心其實是一個暴露了一系列REST API的Server
(服務)。(也就是Appium的核心是一個提供了一組REST API的Web服務器。)
這個Server
的功能其實很簡單:監聽一個端口,然后接收由client
(客戶端)發送來的command
(命令)。翻譯這些command
,把這些command
轉成移動設備可以理解的形式發送給移動設備,然后移動設備執行完這些command
后,把執行結果返回給Appium Server
,Appium Server
再把執行結果返回給client
。
在這里client
其實就是發起command
的設備,一般來說就是我們代碼執行的機器,執行Appium測試代碼的機器。狹義點理解,可以把client
理解成是代碼,這些代碼可以是java/ruby/python/js
等編寫的,只要它實現了WebDriver標准協議就可以。
這樣的設計思想帶來了一些好處:
- 可以帶來多語言的支持;
- 可以把
Server
放在任意機器上,哪怕是雲服務器都可以;(Appium和WebDriver天生適合雲測試)
2、Appium架構圖
如下圖所示:
3、Session說明
session
就是一個會話,在WebDriver/Appium
,你的所有工作永遠都是在session start
后才可以進行的。- 一般來說,通過
POST /session
這個URL,然后傳入Desired Capabilities
(一個JSON對象)就可以開啟session
了。 - 開啟
session
后,會返回一個全局唯一的session id
,以后幾乎所有的請求都必須帶上這個session id
,因為這個seesion id
代表了你所打開的瀏覽器或者是移動設備的模擬器。 - 進一步思考一下,由於
session id
是全局唯一,那么在同一台機器上啟動多個session
就變成了可能,這也就是selenium gird
所依賴的具體理論根據。
4、Desired Capabilities說明
Desired capabilities
是發送到Appium服務端的一組鍵和值(即映射或哈希),其中攜帶了一些配置信息。
從本質上講,這個東西是key-value
形式的對象。你可以理解成是Java里的Map
,Python里的字典,Ruby里的hash
以及JS里的json
對象。實際上Desired Capabilities
在傳輸時就是json
對象。
Desired Capabilities
最重要的作用是告訴Appium Server
本次測試的上下文。
- 這次是要進行瀏覽器測試還是移動端測試?
- 如果是移動端測試的話是測試Aandroid還是iOS?
- 如果測試Aandroid的話那么我們要測試哪個APP?
Appium server
的這些疑問Desired Capabilities
都必須給予解答,否則Appium Server
不買賬,自然就無法完成移動APP或者是瀏覽器的啟動。
具體說明如下:
For example, we might set the platformName capability to iOS to tell Appium that we want an iOS session, rather than an Android one. Or we might set the safariAllowPopupscapability to true in order to ensure that, during a Safari automation session, we’re allowed to use JavaScript to open up new windows. See the capabilities doc for the complete list of capabilities available for Appium
翻譯如下:
例如,我們可以將
platformName
功能設置為iOS,以告知Appium我們想要一個iOS會話,而不是Android會話。 或者,我們可以將safariAllowPopupscapability
設置為true,以確保在Safari自動化會話期間,允許我們使用JavaScript打開新窗口。 請參閱功能文檔以獲取可用於Appium的功能的完整列表。
5、Appium Server說明
這就是每次我們在命令行用Appium命令打開的東西。
Appium server
是用Node.js寫的。我們可以用源碼編譯或者從NPM直接安裝。
安裝方式
$ npm install -g Appium
$ Appium
說明:
- Appium服務端有很多語言庫
Java
、Ruby
、Python
、PHP
、JavaScript
和C#
,這些庫都實現了 Appium對WebDriver協議的擴展。- 當使用Appium的時候,你只需使用這些庫代替常規的WebDriver庫就可以了。
提示:我們不推薦使用這種方式進行安裝Appium,推薦使用下面
Appium Desktop
的方式進行安裝。
6、Appium Clients說明
由於原生的webdriver api
是為web端設計的,因此在移動端用起來會有點不倫不類。Appium官方提供了一套Appium client
,涵蓋多種語言ruby/java/python
等,在我看來ruby client
是實現最好的。
在測試的時候,一般要使用這些client
庫去替換原生的WebDriver庫。
這實際上不是替換,算是client
對原生WebDriver進行了一些移動端的擴展,加入了一些方便的方法,Appium client
讓我們可以更方便的寫出可讀性更好的測試用例。
Appium的客戶端庫下載地址:http://Appium.io/downloads.html
7、Appium Desktop說明
Appium Desktop
是在Appium Server
上封裝成一個有圖形界面的服務端,可以在任何平台下載安裝。
它與運行Appium Server
所需的所有內容捆綁在一起,因此不需要擔心Node環境。
它還附帶了一個檢查器,用來查看應用程序的層次結構等。在編寫測試時,這會派上用場。