1. 程式人生 > >用命令方式啟動、停止appium服務和app

用命令方式啟動、停止appium服務和app

conf from 改名 設備 nor 啟動命令 服務啟動 logger man

啟動appium服務並監聽一個端口命令:

命令command==>  appium -a {ip} -p {port} -U {deviceName} -g {log}

以shell命令方式執行命令,並輸入日誌到log文件:用subprocess需導入

subprocess.Popen(command, stdout=open(LOG_PATH, ‘a+‘), stderr=subprocess.PIPE, shell=True)  #相當於再cmd窗口輸入上面的命令command

根據端口號查詢是否已經啟動服務:

subprocess.getoutput(‘netstat -ano | findstr %s‘%self.port)   #如果找到以啟動端口包含port,則會返回對應信息,

netstat -ano | findstr 1111   查詢端口號1111的進程信息,從中可以獲得pid

啟動模擬器或手機,訪問服務監聽的那個端口:

webdriver.Remote(‘http://127.0.0.1:4723/wd/hub‘,dic)  #dic是模擬器或手機的設備信息和app信息

根據pid查詢進程信息,第一列就是進程名稱

tasklist | findstr 2472

根據進程名稱殺死改名成對應的所有進程:

taskkill /F /IM node.exe /t   #node.exe是進程名

根據pid殺死進程

taskkill /pid 2472 -t -f  #2472是pid

例子:

yaml文件格式如下:內容為手機信息和app信息

device_type: android
tester:
  resetKeyboard: true
  appActivity: com.tencent.mobileqq.activity.SplashActivity
  appPackage: com.tencent.mobileqq
#  appPackage: com.android.browser
#  appActivity: .BrowserActivity
  noReset: False
  unicodeKeyboard: true
devices:
  android:
    
- port: 9009 platformName: Android udid: emulator-5554 platformVersion: 5.1.1 name: 雷電a ip: 127.0.0.2 deviceName: emulator-5554

啟動服務、測試服務是否啟動、啟動app

from lib.tool import Tool
from conf.setting import LOG_PATH
from lib.log import logger
from appium import webdriver
import subprocess
class Controller(object):
def __init__(self):#初始化函數主要是對設備和app信息的獲取
self.tool=Tool()#tool類中寫的有獲取設備文件yaml數據的方法
self.yml=self.tool.app_data#獲取到yaml文件中的設備信息
self.device_type=self.yml.get(‘device_type‘)
self.device_name=self.yml.get(‘devices‘).get(self.device_type)[0].get(‘deviceName‘)
self.devices=self.yml.get(‘devices‘)
self.port=self.devices.get(self.device_type)[0].get(‘port‘)
self.tester=self.yml.get(‘tester‘)
# print(self.device_name)




#taskkill -PID 4152 -F
# 每次啟動前都要kill掉所有的進程taskkill /F /IM node.exe /t

def kill_server(self):

#taskkill /F /IM node.exe /t 我們開啟的appium進程名是node.exe
logger.debug(‘執行[KILL SERVER]操作:%s‘ % subprocess.getoutput("taskkill /F /IM node.exe /t"))
logger.debug(‘重啟ADB服務!%s‘ % subprocess.getoutput("adb kill-server"))

def start_server(self):#啟動server
device=self.devices.get(self.device_type)[0]

#命令字符串
command="appium -a {ip} -p {port} -U {deviceName} -g {log}".format(
ip=device.get(‘ip‘),
port=device.get(‘port‘),
deviceName=device.get(‘deviceName‘),
log=LOG_PATH.replace(‘app_log.log‘,device.get(‘name‘)+‘.log‘)

)
print(command)
logger.debug(‘服務啟動命令:%s‘%command)

#執行命令
subprocess.Popen(command, stdout=open(LOG_PATH, ‘a+‘), stderr=subprocess.PIPE, shell=True)

def test_server(self):
while True:
#查詢是否端口已啟動,即服務啟動
c=subprocess.getoutput(‘netstat -ano | findstr %s‘%self.port)
if c:

logger.debug(‘啟動成功。。。。‘)
break
else:
logger.debug(‘啟動失敗,5s後重試‘)
import time
time.sleep(5)
return True

def start_driver(self):
device=self.devices.get(self.device_type)[0]
self.tester.update(device)
# print(self.tester)
driver=webdriver.Remote(‘http://{ip}:{port}/wd/hub‘.format(
ip=device.get(‘ip‘),
port=device.get(‘port‘)

),self.tester)


if __name__==‘__main__‘:
controller=Controller()
print(controller.device_name)
controller.kill_server()
controller.start_server()
if controller.test_server():
controller.start_driver()

 

用命令方式啟動、停止appium服務和app