准备:

一台真机一台模拟器(使用的是“夜神模拟器”)

先查看是否检测到设备  adb devices

  

由上图可看出没有检测到模拟器(夜神模拟器已开启)

可通过以下配置完成:

第一步:找到adb的安装路径,找到adb.exe

第二步:将adb.exe复制到夜神模拟器下安装路径下的bin,更改名称为  nox_adb.exe;

因为夜神模拟器的安装路径下已经有相同名字的文件,复制粘贴前请做好区分,如下图可先将之前的nox_adb.exe 加了_1做区分;adb.exe也一样需要做区分(或者提前改好adb.exe的名称)

再次adb devices时,可检测到模拟器

但是连接上真机的时候,又只检测到真机,不连接真机也没有检查到模拟器

这时候执行命令:adb connect 127.0.0.1:62001

能检测到模拟器,再连接上真机后,真机和模拟器都能检测到

启动多个appium服务

前提:已安装yaml 模块(pip install  pyyaml )和 tomorrow框架 (pip install tomorrow)

1.启动appium服务,可以用命令行模式

比如

第一个appium服务,可以指定一个端口 -p 4723,然后指定一个设备名称 -u 【真机】,也就是-U参数(adb devices可以查看),-bp是指定bootstrap-port

(多个appium启动链接多个android设备时需要设置不同的 bootstrap-port )

appium -a 127.0.0.1 -p 4723 -bp 4726 -U ML5RRPCUWO

第二个appium 服务指定设备名称【夜神模拟器】

appium -a 127.0.0.1 -p 4724 -bp 4725 -U 127.0.0.1:62001

def start_appium(port, bootstrap, udid):
a = os.popen('netstat -ano | findstr "%s" ' % port)
time.sleep(2)
t1 = a.read()
if "LISTENING" in t1:
print("appium服务已经启动:%s" % t1)
# s = t1.split(" ")
# s1 = [i for i in s if i != '']
# pip = s1[-1].replace("\n", "")
else:
# 启动appium服务
# appium -a 127.0.0.1 -p 4740 -U emulator-5554 127.0.0.1:62001 --no-reset
# os.system("start /b appium -a 127.0.0.1 -p %s -U %s --no-reset" % (port, udid))
# appium -a 127.0.0.1 -p 4724 -bp 4725 -U 127.0.0.1:62001
os.system("start /b appium -a 127.0.0.1 -p %s -bp %s -U %s" % (port, bootstrap, udid)) def stop_appium(): # 关闭所有的appium进程
os.system("start /b taskkill /F /t /IM node.exe")

2.

A.运行不同手机时候,desired_caps的参数配置肯定也是需要多个的,用yaml文件可以管理多个desired_caps配置,方便查看

B.yaml文件配置

pycharm新建一个文件,名称以 .yaml结尾即可

- desc: 设备名称_真机1,appium启动服务端口号_4723
port:
desired_caps:
platformName: Android
deviceName: ML5RRPCUWO
appPackage: com.zhijiepay.android
noReset: !!bool True
platformVersion: 5.1.
udid: ML5RRPCUWO
appActivity: .ui.login.ui.Splash_Activity
newCommandTimeout:
bootstrap-port: - desc: 设备名称_夜神,appium启动服务端口号_4724
port:
desired_caps:
platformName: Android
deviceName: 127.0.0.1:
appPackage: com.zhijiepay.android
noReset: !!bool True
platformVersion: 4.4.
udid: 127.0.0.1:
appActivity: .ui.login.ui.Splash_Activity
newCommandTimeout:
bootstrap-port:

C.

读yaml配置

1).读出来多个配置是list类型,desc是设备的描述,可以通过描述来找到对应的设备名称,如:真机1

2).返回desired_caps配置信息和port端口号以及bootstrap-port

def get_desired_caps(devices_name):
"""
从yaml读取desired_caps配置信息
参数name:设备名称,如:夜神/真机
:return: desired_caps字典格式 """
# curpath = os.path.dirname(os.path.realpath(__file__))
yamlpath = os.path.join(yaml_path, "yaml_appium.yaml")
print("配置地址:%s" % yamlpath)
f = open(yamlpath, "r", encoding="utf-8")
a = f.read()
f.close()
# 把yaml文件转字典
d = yaml.load(a)
for ii in d:
if devices_name in ii["desc"]: # 判断输入的设备名称是否存在
print(ii)
# 启动服务
devicesname = ii['desired_caps']['udid']
print("devicesName: %s" % devicesname)
# print("port: %s" %ii['port'])
start_appium(port=ii['port'], bootstrap=ii['bootstrap-port'], udid=ii['desired_caps']['udid'])
# start_appium(port=ii['port'], udid=devicesName)
return ii['desired_caps'], ii['port']
完整代码如下:
# coding=utf-8
from appium import webdriver
import time
import yaml
import os
from tomorrow import threads
from src.pages import login_page
from config.globalparameter import login_name, login_password, yaml_path def start_appium(port, bootstrap, udid):
a = os.popen('netstat -ano | findstr "%s" ' % port)
time.sleep(2)
t1 = a.read()
if "LISTENING" in t1:
print("appium服务已经启动:%s" % t1)
# s = t1.split(" ")
# s1 = [i for i in s if i != '']
# pip = s1[-1].replace("\n", "")
else:
# 启动appium服务
# appium -a 127.0.0.1 -p 4740 -U emulator-5554 127.0.0.1:62001 --no-reset
# os.system("start /b appium -a 127.0.0.1 -p %s -U %s --no-reset" % (port, udid))
# appium -a 127.0.0.1 -p 4724 -bp 4725 -U 127.0.0.1:62001
os.system("start /b appium -a 127.0.0.1 -p %s -bp %s -U %s" % (port, bootstrap, udid)) def stop_appium(): # 关闭所有的appium进程
os.system("start /b taskkill /F /t /IM node.exe") def get_desired_caps(devices_name):
"""
从yaml读取desired_caps配置信息
参数name:设备名称,如:夜神/真机1
:return: desired_caps字典格式 """
# curpath = os.path.dirname(os.path.realpath(__file__))
    yamlpath = os.path.join(yaml_path, "yaml_appium.yaml")
print("配置地址:%s" % yamlpath)
f = open(yamlpath, "r", encoding="utf-8")
a = f.read()
f.close()
# 把yaml文件转字典
d = yaml.load(a)
for ii in d:
if devices_name in ii["desc"]: # 判断输入的设备名称是否存在
print(ii)
# 启动服务
devicesname = ii['desired_caps']['udid']
print("devicesName: %s" % devicesname)
# print("port: %s" %ii['port'])
start_appium(port=ii['port'], bootstrap=ii['bootstrap-port'], udid=ii['desired_caps']['udid'])
# start_appium(port=ii['port'], udid=devicesName)
return ii['desired_caps'], ii['port'] @threads(2)
def run_app(devices_name):
# 配置参数
desired_caps = get_desired_caps(devices_name)
print(desired_caps)
print(desired_caps[1])
# 执行代码
driver = webdriver.Remote('http://127.0.0.1:%s/wd/hub' % desired_caps[1], desired_caps[0])
time.sleep(5)
login_page1 = login_page.login_page(driver)
login_page1.input_user(login_name)
login_page1.input_Pws(login_password)
login_page1.click_btnLogin()
# self.driver.find_element_by_id('com.zhijiepay.android:id/but_OK').click()
# 设置隐式等待时间
driver.implicitly_wait(3)
time.sleep(5) if __name__ == "__main__":
devices = ["夜神", "真机1"]
for i in devices:
run_app(devices_name=i)
stop_appium()

启动多个appium服务(同时运行多台设备)的更多相关文章

  1. appium+python自动化60-windows上同时启动多个appium服务,让多个android机器并行运行

    前言 做android自动化的时候,启动一个appium服务,只能匹配一个手机去自动化执行.有时候想同一套代码,可以在不同的手机上执行,测下app在不同手机上兼容性. 这就需要启动多个appium服务 ...

  2. Appium+Python app自动化测试之脚本启动和停止Appium服务

    研究了一段时间的Appium android app的自动化测试,工作中需要连接多台手机终端同时执行测试用例,我实现的方式是获取用例中需要执行用例的设备id个数以及实际连接到的设备数(通过adb de ...

  3. 用命令方式启动、停止appium服务和app

    启动appium服务并监听一个端口命令: 命令command==> appium -a {ip} -p {port} -U {deviceName} -g {log} 以shell命令方式执行命 ...

  4. Appium+python自动化(三十六)- 士兵突击许三多 - 多个appium服务启动,多个设备启动,多进程并发启动设备-并发测试 - 上(超详解)

    简介 前面课程只是启动了单个appium服务,只能控制单台设备.如果需要针对多台设备测试那么该如何处理?而且发现群里的小伙伴们也在时不时地在讨论这个问题,想知道怎么实现的,于是宏哥就决定写一片这样的文 ...

  5. Appium+python自动化(三十七)- 士兵突击许三多 - 多个appium服务启动,多个设备启动,多进程并发启动设备-并发测试 - 下(超详解)

    简介 接着上一篇继续看一下如何并发测试以及并发测试的过程中,可能遇到的问题,在这里宏哥把宏哥遇到的和小伙伴或者童鞋们,一起分享一下. Appium端口检测 问题思考 经过前面学习,我们已经能够使用py ...

  6. appium--python启动appium服务

    前戏 前面我们都是在cmd下通过输入appium加端口号来启动服务的,在我们做自动化的时候,我们当然不希望我们手动启动appium服务,而是希望通过脚本自动启动appium服务. 我们可以使用subp ...

  7. 第四章 Appium真机运行测试用例讲解

    -----手机自动化之Appium 手机自动化测试用例虽然可以在模拟器上运行,可是模拟器毕竟和真机还是有区别的.在第二章我们讲到了模拟器上运行测试用例后,我又花了两天的时间,研究了一下真机运行测试用例 ...

  8. appium自动化测试框架——自动化启动多台设备思路梳理

    今天,我们聊一聊如果自动化实现在多台设备上运行脚本. 一.首先我们回忆一下如何在一台设备上运行python脚本,一般分为三步 1.启动appium服务 2.创建驱动 3.运行python脚本 同样的, ...

  9. jenkins启动appium服务

    想在jenkins中,自动定时启动appium服务,shell命令已准备如下: BUILD_ID=dontKillMe echo "" > appium.log nohup ...

随机推荐

  1. 《OpenGL超级宝典》编程环境配置

    最近在接触OpenGL,使用的书籍就是那本<OpenGL超级宝典>,不过编程环境的搭建和设置还是比较麻烦的,在网上找了很多资料,找不到GLTools.lib这个库.没办法自己就借助源码自己 ...

  2. Java 设计模式系列(二三)访问者模式(Vistor)

    Java 设计模式系列(二三)访问者模式(Vistor) 访问者模式是对象的行为模式.访问者模式的目的是封装一些施加于某种数据结构元素之上的操作.一旦这些操作需要修改的话,接受这个操作的数据结构则可以 ...

  3. WHY JAVASCRIPT NEEDS TYPES

    Types have a bad reputation for making code harder to read, adding unnecessary ceremony, and in gene ...

  4. win7更改路由器wifi 密码

    1.有线.无线都能进入192.168.1.1路由设置界面 (也可能是192.168.0.1看路由底面IP) ps: 无线(笔记本与路由没使用网线相连)情况下必须开启wifi连接上该路由才能进入. 无法 ...

  5. [label][Chrome-Extension] How to start Chrome Extension's development

    Firstly , you should read these two pages.  https://developer.chrome.com/extensions/overview https:/ ...

  6. SEGGER J-Link install

    Why J-Link? In case you wonder why GNU ARM Eclipse decided to provide support to SEGGER J-Link, the ...

  7. python signal

    在了解了Linux的信号基础之 后,Python标准库中的signal包就很容易学习和理解.signal包负责在Python程序内部处理信号,典型的操作包括预设信号处理函数,暂 停并等待信号,以及定时 ...

  8. C#中索引器的作用和实现。

    官方描述:索引器允许类或结构的实例就像数组一样进行索引.索引器形态类似于,不同之处在于它们的取值函数采用参数. 这一功能在创建集合类的场合特别有用,而在其他某些情况下,比如处理大型文件或者抽象有些资源 ...

  9. 解决IIS中Login failed for user 'NT AUTHORITY\ANONYMOUS LOGON'.

  10. django系列1--介绍与简单原理, wsgiref模块

    一.web应用框架 Web应用框架(Web application framework)是一种计算机软件框架,用来支持动态网站.网络应用程序及网络服务的开发.这种框架有助于减轻网页开发时共通性活动的工 ...