本文主要是介绍Appium并发测试4-python依次和并发启动多个appium服务,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
启动appium服务的方式有三种
- 通过appium desktop直接启动
- 通过cmd命令启动:appium –p 端口
- 通过python脚本启动
前面第1和第2种只能依次启动appium server,第3种可以并发同时启动appium服务
Python多进程介绍
Python启动appium主要是应用subprocess模块实现的;python并发启动appium则主要是应用多进行multiprocess模块实现的。
- 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 group参数未使用,值始终为None
2 target表示调用对象,即子进程要执行的任务
3 args表示调用对象的位置参数元组,args=(1,2,'egon',)
4 kwargs表示调用对象的字典,kwargs={'name':'egon','age':18}
5 name为子进程的名称
- 方法介绍:
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 subprocessfrom time import ctimedef 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=4723for i in range(2):port=4723+2*iappium_start(host,port)
执行结果:
不输入/b情况下,则会打开cmd命令窗口,如下图
Python并发启动多个appium服务
并发启动多个appium服务,主要是增加以下两个步骤:
- 构建appium进程组
- 加载appium进程组
- Main函数使用multiprocess的方法:start()和join()
实例:并发启动appium服务
import subprocessfrom time import ctimeimport 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并发测试4-python依次和并发启动多个appium服务的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!