iosMonkey

Project Url: baozhida/iosMonkey
Introduction: 基于 macacajs 和 webdriveragent 模拟 monkey 的执行。可以一起执行多个 ios 设备
More: Author   ReportBugs   
Tags:

现在客户端是使用同步的方式处理发送的事件,效率稍低

经实测:

iPhone 6plus 10.2.1,每分钟可以执行大约 40 次事件;

iPhone 7 10.2,每分钟可执行大约 60 次事件;

通过修改代码实现了异步 http 请求,发送事件的请求数量可以大幅提升,但是很多请求会阻塞,没有执行,实际效果不好,遂放弃。

更新

2017.3.17: 原版本呼起 app 的指令是当成事件,按照一定的频率执行,不管现在是否是在测试 APP 页面都会执行。现在改为守护进程的模式,只有当前页面跳出测试 APP 时候才会执行打开 APP 的指令。

2017.4.5:

1.修复 app 守护进程的 bug,由于时间问题导致的

2.增加返回 homescreen 的事件,事件概率是 2%,返回手机主页 5s 后重新打开 app

0、简介

  • 1.修改了原版的构建方式,maven bulid(其实没看到之前构建的配置)

  • 2.解决了 idevicedebug 命令呼起 app 无效的问题

  • 3.根据 app 实际情况,修改了特殊点的处理(在有些页面,点击固定的位置才能返回,不是通用的右上角)

  • 4.如果不修改直接使用,直接使用 target 下面的 jar 包,如果实现自己的方法,需要重新编译

1、功能

  • 1.可以模拟 android monkey 执行的方式,在 IOS APP 页面点击 滑动操等作,支持 ios 9 和 ios10

  • 2.支持多台 ios 一起执行

  • 3.计划保存截图(未完成)

  • 4.计划自动收集 crash 日志(未完成)

2、准备 macaca 环境

安装 usbmuxd

$ brew install usbmuxd

安装 ios_webkit_debug_proxy

$ brew install ios_webkit_debug_proxy

安装 ios-deploy

$ npm i ios-deploy -g

安装 ideviceinstaller

$ brew install ideviceinstaller

编译 libimobiledevice

libimobiledevice 需要自己编译,证实直接安装的不能用

https://github.com/libimobiledevice/libimobiledevice

下载到本地

Before building, try setting:

LD_LIBRARY_PATH=/usr/local/opt/openssl/lib:"${LD_LIBRARY_PATH}"
CPATH=/usr/local/opt/openssl/include:"${CPATH}"
PKG_CONFIG_PATH=/usr/local/opt/openssl/lib/pkgconfig:"${PKG_CONFIG_PATH}"
export LD_LIBRARY_PATH CPATH PKG_CONFIG_PATH
You might want to add that to your .bash_profile.

CPATH and PKG_CONFIG_PATH are for compiling. LD_LIBRARY_PATH is for runtime. See also https://gist.github.com/samrocketman/70dff6ebb18004fc37dc5e33c259a0fc

Then to compile run:

./autogen.sh
make
sudo make install

安装 carthage

$ brew install carthage

安装 macaca 套件 包括,macaca-cli macaca-ios

npm install macaca-cli -g

npm install macaca-ios -g

MAC 全局安装的路径分别如下:

/usr/local/lib/node_modules/macaca-cli
/usr/local/lib/node_modules/macaca-ios

检测 macaca 环境,无报错

$ macaca doctor

3、WebDriverAgent 项目重签名

按照项目

https://github.com/baozhida/MacacaAutomation

操作项目重签名

4、帮助命令

如果需要多个 iOS 设备一起执行,需要指定 proxyport ,同时 macaca 使用不同的端口

$ java -jar iosMonkey-1.0.jar -h
-u:设备的 UDID
-b:测试 App 的 Bundle
-port:macaca 服务的端口,默认 3456
-proxyport:usb 代理端口,默认 8900

5、执行 iosMonkey

开一个窗口执行

$ macaca server --verbose

在一个新窗口执行

$ java -jar [iosMonkey.jar Path] -u [设备的 UDID] -b [测试 App 的 BundleID] -port [macaca 服务端口,可选] -proxyport[usb 代理端口,可选]

6、修改源码重新打包方法

如果需要源码实现自定义的功能,在项目目录下执行

$ mvn assembly:assembly

最后提示如下,标示打包成功,target 下生成 iosMonkey-1.0.jar,可以使用最新的包

INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 7.350 s
[INFO] Finished at: 2017-03-06T17:01:30+08:00
[INFO] Final Memory: 20M/324M
[INFO] ------------------------------------------------------------------------
Apps
About Me
GitHub: Trinea
Facebook: Dev Tools