前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mac OS 下超详细搭建 Appiumm 自动化测试环境

mac OS 下超详细搭建 Appiumm 自动化测试环境

作者头像
顾翔
发布2019-12-11 13:53:45
2.2K0
发布2019-12-11 13:53:45
举报
文章被收录于专栏:啄木鸟软件测试

来源:https://www.testwo.com

现在很多公司,尤其是研发团队开始使用mac OS了,测试团队也不列外。所以,特意写下 mac OS 下自动化测试的各种环境搭建吧,计划分期写,感兴趣的持续关注。

Appium 在 mac OS 环境搭建

Appium 一年之前相比,有了很大的改变

1、iOS 9 之前一直以 instruments 下的 UIAutomation 为驱动底层技术(弊端由于 instruments 的限制,单台 mac 只能对应单台设备);

2、iOS 9.3 时代推出 XCUITest 工具,用以替代 UIAutomation;

3、iOS 10 时代苹果直接废弃了 UIAutomation、Facebook 推出 WebDriverAgent(实现的 server 能够支持单台 mac 对应多个设备);4、Appium 在iOS 9.3 后全面采用 WebDriverAgent 的方案。

首先,我们要知道环境搭建所需工具:

其次,重中之重:版本很重要,xcode9.3 + node10.11.0 + appium1.7.0,如果根据以下配置仍然不能成功运行,那么99%是版本的问题。

下面开始逐个安装

1、安装node

brew install node

通过这种方法安装的node是最新版本,因为我本地需要有node 8.1.1版本,所以使用nvm进行安装。

2、下载Xcode 和 Command Line Tools:需要有个AppleID,并根据自己电脑OS版本。

下载后直接安装即可,注意Xcode保持在application文件夹下只有一个唯一版本。

3、下载安装JDK

下载完成后直接安装即可。

4、安装Android SDK

很多资料都推荐使用brew安装,但是实践后发现SDK文件为空,所以使用Android studio来安装。

如果打开Android studio报错,直接cancel到下一步即可;若使用default方式安装,也可以在configuration里重新下载相关tools。

5、安装appium最新版本

这里不使用npm下载方式是因为下载过程较长,且容易报错。

6、安装appium-doctor

npm install -g appium-doctor

7、配置Android环境变量

在 ~/.bash_profile文件中添加path

export ANDROID_HOME=~/Library/Android/sdk/

export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_171.jdk/Contents/Home #jdk安装路径

export PATH=~/bin:$PATH:/usr/local/bin:$ANDROID_HOME/platform-tools/:$JAVA_HOME/bin

export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

在appium的configurations里设置

8、安装其他依赖

brew install libimobiledevice --HEAD

npm install -g ios-deploy

brew install carthage

libimobiledevice / ideviceinstaller 库:相当于 android 的 adb,是 Appium 底层用到的工具之一,用于获取 iOS 设备信息

ios-deploy:查看设备应用

carthage:类似于 java 的 maven,项目依赖管理,主要是 WebDriverAgent 使用

9、配置WebDriverAgent

(1)首先进入WebDriverAgent所在文件目录下:

/Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-xcuitest-driver/WebDriverAgent

(2)根目录下执行:

./Scripts/bootstrap.sh

(3)打开WebDriverAgent.xcodeproj工程文件

(4)添加自己的account:Xcode -> Preferences -> account -> 左下角 +

(5)更改bundle id:这里的bundle id就相当于一个App的唯一识别号,更改的规则随意,只要确认不会与有重复即可;所有的targets都需要修改。

10、验证是否环境已经安装成功了

(1)终端输入:appium-doctor

如果环境都已配置好,应该是文章最开始图片中的结果。

(2)运行WebDriverAgentRunner

按照图中,1:选择scheme为WebDriverAgentRunner -> 2:选择运行设备,模拟器和真机都可以 -> 3:选择要构建的方式 ->4:选择Test方式的步骤验证是否能成功运行,WebDriverAgentRunner

如果真机运行后弹出需要在设置中信任证书。

Verify the Developer App certificate for your account is trusted on your device. Open Settings on iPhone and navigate to General -> Device Management, then select your Developer App certificate to trust it.

按照步骤操作后,重新运行就可以了。

成功运行结果图

11、遇到的问题总结

1)appium版本不支持xcode版本(需要调用XCUITest),重新下载可匹配的Xcode版本。

Xcode9.3 + Appium1.6.4时,运行WebDriverAgentRunner报错。

Early unexpected exit, operation never finished bootstrapping - no restart will be attempted

解决方法:更新Appium版本到1.7.0

2)appium无法调起webdriverrunner(webdriveragent更新),查看是否因为webdriveragent证书签名、依赖framework、serverURL抛出错误信息。

安装依赖framework时报错

Falling back to building from the source

A shell task (/usr/bin/xcrun xcodebuild -project /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-xcuitest-driver/WebDriverAgent/Carthage/Checkouts/CocoaAsyncSocket/CocoaAsyncSocket.xcodeproj CODE_SIGNING_REQUIRED=NO CODE_SIGN_IDENTITY= CARTHAGE=YES -list) failed with exit code 72:

xcrun: error: unable to find utility "xcodebuild", not a developer tool or in PATH

解决方法:选择Command Line Tools

Xcode -> Preferences -> Locations -> Command Line Tools。

3)长时间测试,server中断,这个无法解决,appium自身问题。

4)webdriveragent启动失败,status、inspector无法正常查看,查看版本。

5)appium脚本启动失败,查看脚本中的配置。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-10-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档