主頁 > 知識庫 > python 基于Appium控制多設(shè)備并行執(zhí)行

python 基于Appium控制多設(shè)備并行執(zhí)行

熱門標簽:硅谷的囚徒呼叫中心 語音系統(tǒng) 電話運營中心 百度AI接口 呼叫中心市場需求 Win7旗艦版 客戶服務(wù) 企業(yè)做大做強

前言:

    如何做到,控制多設(shè)備并行執(zhí)行測試用例呢。

思路篇

  我們?nèi)ハ胂?,我們可以獲取參數(shù)的信息,和設(shè)備的信息,那么​我們也可以針對每臺設(shè)備開啟不一樣的端口服務(wù)。那么每個服務(wù)都對應(yīng)的端口,我們在獲取設(shè)備列表的時候,要和 每個服務(wù)對應(yīng)起來,這樣,我們開啟一個進城池,我們在進程池里去控制設(shè)備,​每個進程池 控制不一樣的設(shè)備即可。

實現(xiàn)篇

  首先實現(xiàn)對應(yīng)的參數(shù)篇和對應(yīng)的設(shè)備端口,

def startdevicesApp():
    l_devices_list=[]
    port_list=[]
    alldevices=get_devices()
    if len(alldevices)>0:
        for item in alldevices:
            port=random.randint(1000,6000)
            port_list.append(port)
            desired_caps = {
                    'platformName': 'Android',
                    'deviceName': item,
                    'platformVersion': getPlatForm(item),
                    'appPackage': get_apkname(apk_path),  # 包名
                    'appActivity': get_apk_lautc(apk_path),  # apk的launcherActivity
                    'skipServerInstallation': True,
                "port":port
                }
            l_devices_list.append(desired_caps)
    return  l_devices_list,port_list

    ​接下來,我們?nèi)?#8203;寫一個端口開啟服務(wù)。

class RunServer(threading.Thread):#啟動服務(wù)的線程
 def __init__(self, cmd):
  threading.Thread.__init__(self)
  self.cmd = cmd
 def run(self):
  os.system(self.cmd)
def start(port_list:list):
 def __run(url):
  time.sleep(10)
  response = urllib.request.urlopen(url, timeout=5)
  if str(response.getcode()).startswith("2"):
   return True
 for i in range(0, len(port_list)):
  cmd = "appium -p %s " % (
   port_list[i])
  if platform.system() == "Windows": # windows下啟動server
   t1 =RunServer(cmd)
   p = Process(target=t1.start())
   p.start()
   while True:
    time.sleep(4)
    if __run("http://127.0.0.1:" + port_list[i]+ "/wd/hub/status"):
     break

​我們開啟服務(wù)了,接下來,我們怎樣根據(jù)​不同進程執(zhí)行測試用例。

def runcase(devics):
 #執(zhí)行測試用例
 pass
def run(deviceslist:list):
​
 pool = Pool(len(deviceslist))
 for i in deviceslist:
  pool.map(runcase, i)
 pool.close()
 pool.join()

  接下來,就是我們?nèi)ソM合形成最后的執(zhí)行的代碼。

    最終代碼展示

from appium import webdriver
from androguard.core.bytecodes.apk import APK
import os
import random
apk_path = "/Users/lileilei/Downloads/com.tencent.mobileqq_8.5.0_1596.apk"


def get_devices() -> list:
 all_devices = []
 cmd = "adb devices"
 reslut = os.popen(cmd).readlines()[1:]
 for item in reslut:
  if item != "\n":
   all_devices.append(str(item).split("\t")[0])
 return all_devices


def getPlatForm(dev: str) -> str:
 cmd = 'adb -s {} shell getprop ro.build.version.release'.format(dev)
 reslut = os.popen(cmd).readlines()[0]
 return str(reslut).split("\n")[0]


def get_apkname(apk):
 a = APK(apk, False, "r")
 return a.get_package()


def get_apk_lautc(apk):
 a = APK(apk, False, "r")
 return a.get_main_activity()

import platform
from multiprocessing import Process,Pool
import time,urllib.request
import threading
class RunServer(threading.Thread):#啟動服務(wù)的線程
 def __init__(self, cmd):
  threading.Thread.__init__(self)
  self.cmd = cmd
 def run(self):
  os.system(self.cmd)
def start(port_list:list):
 def __run(url):
  time.sleep(10)
  response = urllib.request.urlopen(url, timeout=5)
  if str(response.getcode()).startswith("2"):
   return True
 for i in range(0, len(port_list)):
  cmd = "appium -p %s " % (
   port_list[i])
  if platform.system() == "Windows": # windows下啟動server
   t1 =RunServer(cmd)
   p = Process(target=t1.start())
   p.start()
   while True:
    time.sleep(4)
    if __run("http://127.0.0.1:" + port_list[i]+ "/wd/hub/status"):
     break

def startdevicesApp():
 l_devices_list=[]
 port_list=[]
 alldevices=get_devices()
 if len(alldevices)>0:
  for item in alldevices:
   port=random.randint(1000,6000)
   port_list.append(port)
   desired_caps = {
     'platformName': 'Android',
     'deviceName': item,
     'platformVersion': getPlatForm(item),
     'appPackage': get_apkname(apk_path), # 包名
     'appActivity': get_apk_lautc(apk_path), # apk的launcherActivity
     'skipServerInstallation': True,
    "port":port
    }
   l_devices_list.append(desired_caps)
 return l_devices_list,port_list
def runcase(devics):
 #執(zhí)行測試用例
 pass
def run(deviceslist:list):

 pool = Pool(len(deviceslist))
 for devices in deviceslist:
  pool.map(runcase, devices)
 pool.close()
 pool.join()
if __name__=="__main__":
 l_devices_list,port_list=startdevicesApp()
 start(port_list)
 run(l_devices_list)

以上就是python 基于Appium控制多設(shè)備并行執(zhí)行的詳細內(nèi)容,更多關(guān)于Appium控制多設(shè)備并行執(zhí)行的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Python3+Appium安裝及Appium模擬微信登錄方法詳解
  • Python+Appium實現(xiàn)自動化清理微信僵尸好友的方法
  • appium+python自動化配置(adk、jdk、node.js)
  • Python+appium框架原生代碼實現(xiàn)App自動化測試詳解
  • Python+Appium新手教程

標簽:崇左 海南 安康 山西 濟南 喀什 山西 長沙

巨人網(wǎng)絡(luò)通訊聲明:本文標題《python 基于Appium控制多設(shè)備并行執(zhí)行》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266