Appium并发测试4-python依次和并发启动多个appium服务

启动appium服务的方式有三种

  1. 通过appium desktop直接启动
  2. 通过cmd命令启动:appium –p 端口
  3. 通过python脚本启动

前面第1和第2种只能依次启动appium server,第3种可以并发同时启动appium服务

Python多进程介绍

Python启动appium主要是应用subprocess模块实现的;python并发启动appium则主要是应用多进行multiprocess模块实现的。

  1. subprocess模块:可以创建新的进程,并连接到进程的输入、输出、错误等管道信息,并且可以获取进程的返回值

subprocess.Popen():是subprocess模块定义了一个类: Popen
subprocess.Popen(args,bufsize=0,executable=None,stdin=None,stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False,  startupinfo=None, creationflags=0)

其中:

Ags表示要执行的命令

Shell当shell=True时,如果arg是个字符串,就使用shell来解释执行这个字符串。如果args是个列表,则第一项被视为命令,其余的都视为是给shell本身的参数

Stdout表示子程序的标准输出

Stderr表示自程序的标准错误输出,stderr=subprocess.STDOUT,则表示错误流合并到标准输出流里面去

 

2.multiprocess模块:可以创建新的进程
  1. 参数介绍:
1 group参数未使用,值始终为None
2 target表示调用对象,即子进程要执行的任务
3 args表示调用对象的位置参数元组,args=(1,2,'egon',)
4 kwargs表示调用对象的字典,kwargs={'name':'egon','age':18}
5 name为子进程的名称
  1. 方法介绍:
1 p.start():启动进程,并调用该子进程中的p.run() 
2 p.join([timeout]):主线程等待p终止(强调:是主线程处于等的状态,而p是处于运行的状态)。timeout是可选的超时时间,需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程。

 

Python依次启动多个appium服务

测试场景:

启动appium服务端口:4723 ,bp端口为4724

启动appium服务端口:4725 ,bp端口为4726

注意:bp端口表示—bootstrap-port,是appium服务和设备之间通信的端口,如果不指定该端口,那无法启动多台设备

实例:启动依次启动appium服务

import subprocess

from time import ctime

def appium_start(host,port):

    bootstrap_port=str(port+1)

    #/b表示不打开cmd命令窗口,-p表示指定appium端口,-bp表示指定appium和设备通信的端口

    cmd='start /b appium -a '+host+' -p '+str(port)+' -bp '+str(bootstrap_port)



    print('%s at %s' %(cmd,ctime()))

    #a是追加写入的方式

    subprocess.Popen(cmd,shell=True,stdout=open('appium_log/'+str(port)+'.log','a'),stderr=subprocess.STDOUT)



if __name__ == '__main__':

    host='127.0.0.1'

    port=4723

    for i in range(2):

        port=4723+2*i

        appium_start(host,port)

执行结果:

不输入/b情况下,则会打开cmd命令窗口,如下图

Appium并发测试4-python依次和并发启动多个appium服务_第1张图片

 

Python并发启动多个appium服务

并发启动多个appium服务,主要是增加以下两个步骤:

  1. 构建appium进程组
  2. 加载appium进程组
  3. Main函数使用multiprocess的方法:start()和join()

实例:并发启动appium服务

import subprocess

from time import ctime

import multiprocessing #导入多进程模块

def appium_start(host,port):

    bootstrap_port=str(port+1)

    #/b是不打开cmd命令窗口

    cmd='start /b appium -a '+host+' -p '+str(port)+' -bp '+str(bootstrap_port)

    print('%s at %s' %(cmd,ctime()))

    #a是追加写入的方式

    subprocess.Popen(cmd,shell=True,stdout=open('appium_log/'+str(port)+'.log','a'),stderr=subprocess.STDOUT)

#构建appium进程组

appium_process=[]



#加载appium进程

for i in range(2):

    host = '127.0.0.1'

    port = 4723+2*i

    #target指向方法,args指向参数,且必须是一个元组的形式

    appium=multiprocessing.Process(target=appium_start,args=(host,port))

    #将进程从变量appium加载到进程内

    appium_process.append(appium)



if __name__ == '__main__':

    #并发启动appium服务,for循环开启多个appium服务,join主进程等待子进程结束

    for appium in appium_process:

        appium.start()

    for appium in appium_process:

        appium.join()

 

你可能感兴趣的:(appium)