python 基于Appium控制多设备并行执行

 更新时间:2021年03月15日 11:25:53   作者:北漂的雷子  
这篇文章主要介绍了python 如何基于Appium控制多设备并行执行,帮助大家更好的理解和学习使用python,感兴趣的朋友可以了解下

前言:

    如何做到,控制多设备并行执行测试用例呢。

思路篇

  我们去想下,我们可以获取参数的信息,和设备的信息,那么​我们也可以针对每台设备开启不一样的端口服务。那么每个服务都对应的端口,我们在获取设备列表的时候,要和 每个服务对应起来,这样,我们开启一个进城池,我们在进程池里去控制设备,​每个进程池 控制不一样的设备即可。

实现篇

  首先实现对应的参数篇和对应的设备端口,

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

    ​接下来,我们去​写一个端口开启服务。

class RunServer(threading.Thread):#启动服务的线程
 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 runcase(devics):
 #执行测试用例
 pass
def run(deviceslist:list):
​
 pool = Pool(len(deviceslist))
 for i in deviceslist:
  pool.map(runcase, i)
 pool.close()
 pool.join()

  接下来,就是我们去组合形成最后的执行的代码。

    最终代码展示

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):#启动服务的线程
 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):
 #执行测试用例
 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控制多设备并行执行的详细内容,更多关于Appium控制多设备并行执行的资料请关注脚本之家其它相关文章!

相关文章

  • Python生成元组和字典的方法

    Python生成元组和字典的方法

    本文主要介绍了Python生成元组和字典的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • pyqt5中动画的使用详解

    pyqt5中动画的使用详解

    这篇文章主要介绍了pyqt5中动画的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Python实现滑块拼图验证码详解

    Python实现滑块拼图验证码详解

    验证码作为一种自然人的机器人的判别工具,被广泛的用于各种防止程序做自动化的场景中。传统的字符型验证安全性已经名存实亡的情况下,各种新型的验证码如雨后春笋般涌现,今天给大家分享一篇Python实现滑块验证码
    2022-05-05
  • python实现批量文件重命名

    python实现批量文件重命名

    这篇文章主要介绍了python实现批量文件重命名,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • Python随机生成一个6位的验证码代码分享

    Python随机生成一个6位的验证码代码分享

    这篇文章主要介绍了Python随机生成一个6位的验证码代码分享,本文直接给出代码实例,需要的朋友可以参考下
    2015-03-03
  • anaconda虚拟环境默认路径的更改图文教程

    anaconda虚拟环境默认路径的更改图文教程

    在Anaconda中如果没有指定路径,虚拟环境会默认安装在anaconda所安装的目录下,这篇文章主要给大家介绍了关于anaconda虚拟环境默认路径更改的相关资料,需要的朋友可以参考下
    2023-10-10
  • pytorch简单实现神经网络功能

    pytorch简单实现神经网络功能

    这篇文章主要介绍了pytorch简单实现神经网络,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09
  • 使用python 写一个静态服务(实战)

    使用python 写一个静态服务(实战)

    今天小编就为大家分享一篇使用python 写一个静态服务(实战),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • python web框架Flask实现图形验证码及验证码的动态刷新实例

    python web框架Flask实现图形验证码及验证码的动态刷新实例

    在本篇文章里小编给大家整理的是关于python web框架Flask实现图形验证码的相关知识点,有需要的朋友们参考下。
    2019-10-10
  • Python文件路径处理模块pathlib示例详解

    Python文件路径处理模块pathlib示例详解

    pathlib是跨平台的、面向对象的路径操作模块,可适用于不同的操作系统,其操作对象是各种操作系统中使用的路径,下面这篇文章主要给大家介绍了关于Python文件路径处理模块pathlib的相关资料,需要的朋友可以参考下
    2023-04-04

最新评论