zoukankan      html  css  js  c++  java
  • Appium 分布式执行

    https://blog.csdn.net/weixin_34393428/article/details/90655384

    https://blog.csdn.net/chen072086/article/details/106503548

    https://blog.csdn.net/ljl6158999/article/details/80803239

    Appium Grid 并发测试


    一、背景

    Selenium玩的比较6的同学比较清楚:在Selenium中三大组件中有包含了Selenium Grid,而其作用就是分布式执行测试用例。

    主要的应用场景在于:

    ◆ 缩短测试执行时间,提高自动化测试效率

    ◆ 多浏览器的兼容性测试。

    Selenium只是针对于web平台的自动化,然而移动端平台的兼容性测试所涉及到机型众多,多设备并发测试需求更加迫切。

    而Appium Grid恰好就是基于Selenium Grid这一模式发展而来,可以很好的满足我们的需求。

    Google爬到一张原理图,大家可以来看下:


    Appium Grid 并发测试

    Grid模式下有两个非常重要的组件:

    ◆ hub跟交换机的角色类似,通过网线连通到各种设备。

    官方的解释是:hub用来管理各个节点的注册和状态信息,并且接受远程客户端代码的请求调用,然后把请求的命令再转发给节点来执行。

    ◆ node节点,执行脚本代码,通过上图可以看到,hub将请求发给node去执行,这里的node就是Appium Server端 。


    二、环境/工具准备

    ◆ selenium-server-standalone-3.12.0.jar

    ◆ 夜神模拟器多开

    ◆ Appium Desktop V1.8.2

    ◆ nodejs安装包


    三、实践步骤

    开启hub

    selenium-server-standalone-3.12.0.jar

    这支文件可以从

    http://selenium-release.storage.googleapis.com/index.html 进行下载

    下载完成之后直接再dos环境下去执行:


    Appium Grid 并发测试

    -role参数表示指定当前角色是为hub 当然除了-role参数还有很多其他的参数可以提供


    Appium Grid 并发测试

    此时可以在浏览器中输入 http://127.0.0.1:4444/grid/console 进行访问,

    默认hub起来的端口为4444

    此页面为hub的控制管理页面,当前没有node节点链接上


    Appium Grid 并发测试


    三、node注册

    首先开启模拟器(这里以夜神模拟器举例,其他的模拟器/真机类似),保证adb devices是可以检测到设备


    Appium Grid 并发测试

    当前deviceName为127.0.0.1:62001

    新建test1.json文件,在json中的配置即为node注册到hub所需要的信息(注意在#后面的内容需要删除掉,我这边是为了方便进行释义)


    Appium Grid 并发测试

    安装nodejs(Appium desktop版本默认没有提供命令行启动的方式,需要安装nodejs支持)

    进入到Appium的js启动脚本路径,我的路径为

    C:\Users\Administrator\AppData\Local\Programs\Appium\resources\app\node_modules\appium\build\lib\main.js

    通过执行如下Appium启动指令


    Appium Grid 并发测试

    ◆ -a参数表示Appium Server的工作IP地址

    ◆ -p参数表示Appium Server的端口号

    ◆ -bp参数表示bootstrap的监听端口号

    ◆ -U参数表示Appium链接到哪台设备上

    ◆ --nodeconfig后面接node节点配置文件

    可以看到第一个Appium Server节点已经成功注册上


    Appium Grid 并发测试

    刷新浏览器即可得到节点相关信息


    Appium Grid 并发测试


    四、注册另外的节点

    以此类推,使用夜神模拟器多开功能开启第二台夜神模拟器,第二个node节点的json配置:


    Appium Grid 并发测试

    执行命令:


    Appium Grid 并发测试

     


    Appium Grid 并发测试


    五、总结

    目前我们的hub能够管理多个节点,但是需要注意的是我们只是用Grid搭建好了分布式测试环境,不能直接一个脚本扔给hub就可以开始在node上并发测试。

    怎么对接到我们的脚本,能够让我们的脚本分发到不同node去执行,多个node节点并发执行测试用例这些问题我们还没有解决,后续的文章我们为大家补充,大家可以持续关注。

    本文由柠檬班歪歪老师原创,转载需注明出处!

  • 相关阅读:
    iOS6和iOS7代码的适配(3)——坐标适配
    iOS6和iOS7代码的适配(2)——status bar
    iOS6和iOS7代码的适配(1)
    深入Blocks分析
    文字溢出加省略号
    点击图表每一部分触发某事件
    图表添加红线
    比较月份是否存在封装数据
    云上示范区项目总结
    页面之间通过地址栏传参
  • 原文地址:https://www.cnblogs.com/python-xiakaibi/p/13037433.html
Copyright © 2011-2022 走看看