目的:

  通过添加设备号,则自动给添加的设备分配端口,启动对应的appium服务。注意:为了方便,将共用一个配置文件。

1、公共的配置文件名称:desired_caps.yaml

platformVersion: 5.1.
platformName: Android
deviceName: oppo
appPackage: com.iBer.iBerAppV2
appActivity: com.iBer.iBerAppV2.MainActivity
#appPackage: com.android.mms
#appActivity: /com.qiku.android.mms.ui.MmsConversationListActivity
noReset: False
unicodeKeyborad: True #使用Unicode编码方式发送字符串
resetKeyborad: True #隐藏键盘
ip: 127.0.0.1
#port:
#devices_list: ["7f4bd69a",""] #给出需要启动的设备udid,此处启动2个真机
#devices_list: ["","127.0.0.1:62001"]
devices_list: [""]
phone: [""]

2、自动根据添加的设备分配端口,前提:检查当前分配的端口是否被占用,若已被占用则自动删除此端口的进程,重新分配此端口。文件名称:Check_port.py

# -*- coding: utf- -*-
'''
意义:端口的自动检测 '''
import socket
import os
import re def check_port(host,port):
'''检测端口是否可用''' s = socket.socket(socket.AF_INET,socket.SOCK_STREAM) #socket.SOCK_STREAM 或 SOCK_DGRAM
try:
s.connect((host,port))
s.shutdown() #禁止在一个socket上进行数据的接收与发送,利用shutdown函数使socket双向数据传输变为单向数据传输,
# shutdown需要一个单独的参数,该参数表示了如何关闭socket,:表示禁止将来读,:表示禁止将来写,:表示禁止将来读写 #except OSError as msg:
except:
print("port %s is avaliable")%port #端口可用
return True
else:
print ("port %s alreadly be in use !!!")%port #端口已被占用
return False def release_port(port):
print"release_port-------------杀掉已占用的端口"
'''杀掉正在执行的端口'''
cmd = "lsof -i:%s|awk 'NR==2{print $2}'" % port
pid = os.popen(cmd).read()
print "find port:%s, pid is value:%s" %(port,pid)
cmd = "kill -9 %s" % pid
print "kill port:%s,pid value:%s"%(port,pid)
os.popen(cmd).read() # if __name__ =="__main__":
# host = "127.0.0.1"
# port =
# check_port(host,port)
# release_port(port)

3、检查appium服务是否开启,根据当前连接的设备数量,自动开启对应的appium服务,文件名称为:muti_appium.py

# -*- coding: utf- -*-

'''
python启动多个appium服务----并发
'''
import subprocess
from time import ctime
import sys,os
import yaml reload(sys)
sys.setdefaultencoding('utf8') path = os.getcwd()
print path
with open(path+"/desired_caps.yaml","r") as file:
data = yaml.load(file)
devices_list = data["devices_list"] def appium_start(host,port):
print "-----------------------------appium_start-----------------------------"
'''启动appium服务'''
#此处的port+3是为了appium服务的启动端口不跟multi_device中的端口重复
bootstrap_port = str(port+)
print "bootstrap_port" + str(bootstrap_port)
'''# win
start /b appium -a 127.0.0.1 -p --log xxx.log --local-timezone
# mac
appium -a 127.0.0.1 -p --log xxx.log --local-timezone &'''
# cmd = "start /b appium -a"+host+" -p "+str(port)+" -bp "+str(bootstrap_port) windows上的写法
cmd = "appium -a " + host + " -p " + str(port) + " -bp " + str(bootstrap_port) print "%s at %s"%(cmd,ctime())
print path+'/appium_log/'+str(port)+'.log' logpath = os.getcwd()[:-]
print logpath
subprocess.Popen(cmd,shell=True,stdout=open(logpath+'/appium_log/'+str(port)+'.log','wa'),stderr=subprocess.STDOUT) # if __name__ == "__main__":
# host = "127.0.0.1"
# port =
# appium_start(host,port) # appium_process = [] lucky注销,释放开则是并发的启动appium服务
#
for i in range(len(devices_list)): #根据连接Android设备的数量,可更改此处的值
host = "127.0.0.1"
port = ++i
print port
appium_start(host, port) # appium = multiprocessing.Process(target=appium_start,args=(host,port))
# appium_process.append(appium) # if __name__ == "__main__": lucky注销
#
# for appium in appium_process:
# appium.start()
# for appium in appium_process:
# appium.join()

4、检查当前添加的设备号,自动开始执行多设备。文件名称为:muti_device.py

# -*- coding: utf- -*-

from appium import webdriver
from time import ctime
import yaml
import sys from Add_Case_Gather import Run_test
import os,time
from time import sleep
#为了读取yaml中的中文,否则会报错
reload(sys)
sys.setdefaultencoding('utf8') #获取desired_caps.yaml的存放路径
path = os.getcwd()
with open(path+"/desired_caps.yaml","r") as file:
data = yaml.load(file)
devices_list = data["devices_list"] #开始执行设备
for i in range(len(devices_list)):
port = + + i
def appium_desire(udid,port):
print "--------------------appium_desire-------------------------"
desired_caps = {}
desired_caps["platformName"] = data["platformName"]
desired_caps["platformVersion"] = data["platformVersion"]
desired_caps["deviceName"] = data["deviceName"]
desired_caps["udid"]=udid
desired_caps["appPackage"] = data["appPackage"]
desired_caps["appActivity"] = data["appActivity"]
desired_caps["noReset"] = data["noReset"] print ("appium port:%s start run %s at %s" %(port,udid,ctime()))
print str(data['ip'])+str(port)
driver = webdriver.Remote('http://'+str(data['ip'])+':'+str(port)+'/wd/hub',desired_caps)
print driver #调用需要执行的步骤操作方法
Run_test(driver).run_test1() return devices_list[i],port

5、将如上的文件共同在一个文件中进行启动调用,文件名称为:Run_Test.py

# -*- coding: utf- -*-
'''并发的测试
主要功能:
、检查给定的端口是否被占用,如果占用则自动释放
、并发启动appium服务
、并发启动device服务
''' from Test.Common.multi_appium import appium_start
#from multi_device import appium_desire
from Test.Common.multi_device import appium_desire
from Test.Common.Check_port import *
from time import sleep
import multiprocessing
import sys
import yaml #为了读取yaml中的中文,否则会报错
reload(sys)
sys.setdefaultencoding('utf8') # 获取desired_caps.yam的路径
path = os.getcwd()
with open(path+"/desired_caps.yaml","r") as file:
data = yaml.load(file) devices_list = data["devices_list"] def start_appium_action(host,port):
print "start_appium_action------------------"
if check_port(host,port)==False:
release_port(port)
elif check_port(host,port)==True:
appium_start(host, port)
return True
else:
print("appium %s start faild!"%port)
return False def start_devices_action(udid,port):
host = "127.0.0.1"
appium_desire(udid, port) def appium_start_sync():
appium_process = []
for i in range(len(devices_list)):
host = "127.0.0.1"
port = ++i
appium = multiprocessing.Process(target=start_appium_action,args=(host,port))
appium_process.append(appium) for appium in appium_process:
appium.start()
for appium in appium_process:
appium.join() sleep() def devices_start_sync():
desired_process = []
for i in range(len(devices_list)):
port = ++i
desired = multiprocessing.Process(target=start_devices_action, args=(devices_list[i], port))
desired_process.append(desired) for desired in desired_process:
desired.start()
for desired in desired_process:
desired.join() if __name__ == "__main__":
appium_start_sync()
devices_start_sync()

如上已完成了多设备的添加,如果需要新增多个设备,则在desired_caps.yaml中的 devices_list: ["57614229"]中新增设备号,然后运行Run_Test.py即可。

appium+python 【Mac】UI自动化测试封装框架介绍 <五>---脚本编写(多设备)的更多相关文章

  1. appium+python 【Mac】UI自动化测试封装框架介绍 <七>---脚本编写规范

    脚本的使用,注释非常关键,无论自己的后期查看还是别人使用,都可以通过注释很明确的知道代码所表达的意思,明确的知道如何调用方法等等.每个团队均有不同的商定形式来写脚本,因此没有明确的要求和规范来约束.如 ...

  2. appium+python 【Mac】UI自动化测试封装框架介绍 <二>---脚本编写(单设备)

    1.单设备的执行很简单,平时可多见的是直接在config中进行配置并进行运行即可.如下: # coding=UTF- ''' Created on // @author: SYW ''' from T ...

  3. appium+python 【Mac】UI自动化测试封装框架介绍 <三>---脚本的执行

    我自己编写的脚本框架中,所有的脚本执行均放在一个py文件中,此文件作为启动文件执行,包含了运行此文件将执行脚本.分配设备端口.自启appium服务等. 详细的介绍待后期补充.

  4. appium+python 【Mac】UI自动化测试封装框架介绍 <四>---脚本的调试

    优秀的脚本调试定位问题具备的特点: 1.方便调试. 2.运行报错后容易定位出现的问题. 3.日志的记录清晰 4.日志可被存储,一般测试结果的分析在测试之后会进行,那么日志的存储将会为后期的分析问题带来 ...

  5. appium+python 【Mac】UI自动化测试封装框架流程简介 <一>

    为了多人之间更方便的协作,那么框架本身的结构和编写方式将变得很重要,因此每个团队都有适合自己的框架.如下本人对APP的UI自动化测试的框架进行进行了简单的汇总.主要目的是为了让团队中的其余人员接手写脚 ...

  6. Python爬虫教程-30-Scrapy 爬虫框架介绍

    从本篇开始学习 Scrapy 爬虫框架 Python爬虫教程-30-Scrapy 爬虫框架介绍 框架:框架就是对于相同的相似的部分,代码做到不出错,而我们就可以将注意力放到我们自己的部分了 常见爬虫框 ...

  7. 使用appium+python做UI自动化的demo

    使用appium+python做UI自动化的demo 案例使用的知乎app,下载最新的知乎apk,存在了电脑上,只需要配置本机上app目录,不需要再配置appPackage和appActivity # ...

  8. Appium+python移动端自动化测试-python库及pycharm安装(二)

    一.安装python库 安装python库有很多种方法,如pip安装.源文件安装.运行包安装,但我们最常用的就是使用pip进行安装 Appium+python做移动端的自动化测试,所需要安装以下pyt ...

  9. 基于python+appium+yaml安卓UI自动化测试分享

    结构介绍 之前分享过一篇安卓UI测试,但是没有实现数据与代码分离,后期维护成本较高,所以最近抽空优化了一下.不想看文章得可以直接去Github,欢迎拍砖大致结构如下:   结构.png testyam ...

随机推荐

  1. input标签自动填充问题

    <input type='text' placeholder='手机号' /> <input type='text' placeholder='地址' /> <input ...

  2. 基于SymmetricDS的多主一从数据库同步方案

    原文参照:https://blog.csdn.net/seattle0564/article/details/22096901 下面就记录下测试的一款第三方同步方案SymmetricDS(以下简称S) ...

  3. python线程定时器Timer(32)

    相对前面几篇python线程内容而言,本片内容相对比较简单,定时器 – 顾名思义,必然用于定时任务. 一.线程定时器Timer原理 原理比较简单,指定时间间隔后启动线程!适用场景:完成定时任务,例如: ...

  4. CNN-2: AlexNet 卷积神经网络模型

    1.AlexNet 模型简介 由于受到计算机性能的影响,虽然LeNet在图像分类中取得了较好的成绩,但是并没有引起很多的关注. 知道2012年,Alex等人提出的AlexNet网络在ImageNet大 ...

  5. 《Tsinghua os mooc》第15~16讲 处理机调度

    第十五讲 处理机调度 进程调度时机 非抢占系统中,当前进程主动放弃CPU时发生调度,分为两种情况: 进程从运行状态切换到等待状态 进程被终结了 可抢占系统中,中断请求被服务例程响应完成时发生调度,也分 ...

  6. Oracle之配置节点间相互信任机制测试

    更改一下,之前的都不对,现在来一版简单有效的ssh互信配置 例如我的是在配置rac,在grid用户下配置互信:建立好相应的文件 mkdir .ssh chmod -R 700 .ssh/ 使用ssh- ...

  7. 多个结果集union后保持各自原有排序

    SELECT *FROM ( SELECT TOP (@count1) a.* FROM Article AS a WITH (NOLOCK)LEFT JOIN Article_Type AS at ...

  8. pandas数据结构之Series笔记

    对Series的理解也源于对其相关的代码操作,本次仅贴一些代码来加深理解以及记忆 import pandas as pd import numpy as np s = pd.Series(np.ran ...

  9. mybaits实现oracle批量新增数据,回填主键

    项目有需求,百度了很久,反正他们说的方法,我都没成功,我也不知道是不是我写代码的姿势不正确,没办法只能自己想法子了 我们这个项目用到了通过Mapper,通用Mapper里通过OracleProvide ...

  10. (四)Hibernate的增删改查操作(1)

    Hiberntae的查找操作有多种: 1.  使用Criteria接口查询 Query_Criteria.java package action; import java.util.ArrayList ...