啟動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()