Appium+Python app自動化測試之腳本啟動和停止Appium服務
研究了一段時間的Appium android app的自動化測試,工作中需要連接多台手機終端同時執行測試用例,我實現的方式是獲取用例中需要執行用例的設備id個數以及實際連接到的設備數(通過adb devices獲取),然后啟動相應數量的Appium 服務,以便每個設備執行時並發進行並且互不影響。當然也可以通過selenium grid來實現,只是目前還在學習研究中,還是先把目前啟動多個appium服務實現的方式記錄下來。
一、Windows下啟動單個appium服務
需要啟動多個appium服務,那必須為每個服務指定端口。
appium -a 127.0.0.1 -p 4726 --bootstrap-port 4780 --session-override --log "E:/appium" --command-timeout 600
通過該命令啟動一個端口為4726,bootstrap端口為4780,Appium log存放路徑為E盤,session可以覆蓋並且命令超時為600s Appium服務,訪問的URL地址為:http://127.0.0.1:4726/wd/hub。
為什么在這里指定bootstrap端口呢?當不指定bootstrap端口時,啟動的appium服務默認的bootstrap端口為4724。當我們同時啟動兩個或多個appium服務,不指定bootstrap端口,那么所有服務bootstrap端口默認都為4723,當連接多個手機設備啟動driver時,部分手機不執行用例,為了穩定起見,在這里分別指定bootstrap端口。
二、python腳本啟動appium服務
為了根據連接設備的個數啟動相應數量的appium服務,直接將appium服務的啟動放在python腳本中運行。實現的方式是通過python腳本執行上面的cmd命令行。
1 def start_Appium(self, host, port, bootstrap_port, appium_log_path): #device_uid, 2 #appium -p 4723 -bp 4724 -U 22238e79 --command-timeout 600 3 errormsg = "" 4 appium_server_url ="" 5 try: 6 if self.port_is_free(host,port): 7 cmd ='start /b appium -a '+ host +' -p '+ str(port)+ ' --bootstrap-port '+ str(bootstrap_port) + ' --session-override --log '+ '"'+appium_log_path + '" --command-timeout 600' #' -U '+ device_uid+ 8 print cmd 9 #p = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) #stdout=PIPE, stderr=PIPE) 10 p = subprocess.call(cmd, shell=True,stdout=open('E:/logs.log','w'),stderr=subprocess.STDOUT) 11 print p 12 appium_server_url = 'http://' + host +':' + str(port) +'/wd/hub' 13 print appium_server_url 14 else: 15 print "port:%d is used!"%(port) 16 except Exception, msg: 17 errormsg = str(msg) 18 return appium_server_url, errormsg
當然這里返回appium url后需要去驗證是否真正啟動了該appium服務(可以通過requests訪問啟動的url或者根據netstat查看端口)。
注意:代碼中cmd使用了"start /b",主要是用於讓cmd命令在后台執行,不影響python腳本的執行。如果不加“start /b”的話,啟動appium服務后就停留在Appium日志狀態,將不會返回執行后續的python腳本。
三、停止Appium服務
當用例執行完畢后,關閉當前的appium服務。實現方式是python腳本調用bat關閉Appium服務。python腳本將appium server的端口傳入到bat中,bat腳本根據端口號獲取其進程pid,然后獲取應用名並通過taskkill關閉。
StopAppium.bat腳本如下:
1
2
3
4
5
6
7
8
9
10
|
@
echo
off
setlocal enabledelayedexpansion
rem %1傳入端口號
for
/f
"delims= tokens=1"
%%i
in
(
'netstat -aon ^| findstr %1 '
)
do
(
set
a=%%i
goto js
)
:js
taskkill
/f
/pid
"!a:~71,5!"
rem pause>nul
|
python腳本執行如下:
1 def stop_Appium(self, Appium_url): 2 cmd = 'StopAppium.bat %s'%(self.get_port(Appium_url)) 3 #print cmd 4 p = os.popen(cmd) 5 print p.read()
其中Appium_url為之前啟動的Appium服務的URL地址,通過get_port方法是獲取URL中的port。