在Mac OSX上配置Appium+Android自动化测试环境

发表于:2017-12-25 10:43

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:betacat    来源:SegmentFault

  前提准备
  开始正文之前,你需要准备好一些基本条件:
  1、安装好Mac OSX 操作系统的设备
  2、能够访问中国局域网以外资源的方法(没有也行,但很痛苦)
  3、已经安装好 homebrew
  4、已经安装好 Python3.x
  5、已经安装好 Java Runtime Environment
  安装 Android Studio / SDK
  本文主要为了测试安卓应用,那么这里我们就需要安装Android Studio或者Android SDK。
  · Android Studio - 完整的开发以及测试工具,需要梯子
  · Android SDK - 足够完成自动化测试,通过homebrew安装
  如果只是为了自动化测试我建议安装SDK足矣,使用brew命令安装。
  brew install android-sdk
  在国内使用brew可以事先配置好国内源,速度会快很多。
  如果有梯子建议选择Android Studio,安装方法很简单,官网下载后一路Next,启动后会让你把SDK等等一系列依赖都装好,一步到位。
  准备Android 模拟器或者使用真机
  如果SDK已经安装完毕,应该可以使用adb命令来检查可用的模拟器或者已经连接到电脑上的实体手机
  adb devices
  如果不知道adb工具在哪,可以先在命令行里通过find搜索。
  find /Users -name adb  # 搜索用户目录
  find / -name adb  # 搜索全盘
  找到之后可以把 adb 目录加入PATH,方便后续使用。
  安装Appium
  Appium 可以通过多种方式安装。
  方式一:使用 NodeJS 安装
  首先通过brew安装nodejs:
  brew install node
  配置国内源,在个人目录下新建一个.npmrc文件,写入:
  registry=https://registry.npm.taobao.org/
  开始安装Appium:
  npm install -g appium
  npm install -g appium-doctor
  Appium-doctor 可以帮你诊断测试环境,建议安装。
  方式二:下载Appium桌面版安装
  官方的Appium桌面安装包可以从github下载,需要梯子。
  https://github.com/appium/app...
  下载到的dmg文件双击装载,把Appium拖到Application里完成安装。
  安装 Appium-Client
  本文只讨论Python实现的Appium测试,所以你只需要允许以下命令:
  pip install Appium-Python-Client
  如果需要使用其他编程语言,下表供参考:
  语言/框架Github版本库以及安装指南
  Rubyhttps://github.com/appium/rub...
  Pythonhttps://github.com/appium/pyt...
  Javahttps://github.com/appium/jav...
  JavaScript (Node.js)https://github.com/admc/wd
  Objective Chttps://github.com/appium/sel...
  PHPhttps://github.com/appium/php...
  C# (.NET)https://github.com/appium/app...
  RobotFrameworkhttps://github.com/jollychang...
  必要的环境变量设置
  如果你已经安装了appium-doctor,那么你只要运行appium-doctor命令就可以知道你还需要设置哪些环境变量,比如:
tobyqin@CatBook ~> appium-doctor
info AppiumDoctor Appium Doctor v.1.4.3
info AppiumDoctor ### Diagnostic starting ###
info AppiumDoctor  ? The Node.js binary was found at: /usr/local/bin/node
info AppiumDoctor  ? Node version is 7.10.0
info AppiumDoctor  ? Xcode is installed at: /Applications/Xcode.app/Contents/Developer
WARN AppiumDoctor  ? Xcode Command Line Tools are NOT installed!
info AppiumDoctor  ? DevToolsSecurity is enabled.
info AppiumDoctor  ? The Authorization DB is set up properly.
WARN AppiumDoctor  ? Carthage was NOT found!
info AppiumDoctor  ? HOME is set to: /Users/tobyqin
info AppiumDoctor  ? ANDROID_HOME is set to: /Users/tobyqin/Library/Android/sdk/
info AppiumDoctor  ? JAVA_HOME is set to: /Library/Java/JavaVirtualMachines/jdk1.8.0_112.jdk/Contents/Home
info AppiumDoctor  ? adb exists at: /Users/tobyqin/Library/Android/sdk/platform-tools/adb
info AppiumDoctor  ? android exists at: /Users/tobyqin/Library/Android/sdk/tools/android
info AppiumDoctor  ? emulator exists at: /Users/tobyqin/Library/Android/sdk/tools/emulator
info AppiumDoctor  ? Bin directory of $JAVA_HOME is set
info AppiumDoctor ### Diagnostic completed, 2 fixes needed. ###
info AppiumDoctor
info AppiumDoctor ### Manual Fixes Needed ###
info AppiumDoctor The configuration cannot be automatically fixed, please do the following first:
WARN AppiumDoctor - Please install Carthage. Visit https://github.com/Carthage/Carthage#installing-carthage for more information.
info AppiumDoctor ###
info AppiumDoctor
info AppiumDoctor Bye! Run appium-doctor again when all manual fixes have been applied!
  其实你不一定需要把通过所有检查项,如果只是为了完成Android的Appium测试,只要确保ANDROID_HOME 和 JAVA_HOME 正确配置,另外SDK Tools 和Platform Tools都加入PATH就基本完成了。可以参考我个人目录下的.bash_profile设置:
  export ANDROID_HOME=~/Library/Android/sdk/
  export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_112.jdk/Contents/Home
  export PATH=~/bin:$PATH:/usr/local/bin:$ANDROID_HOME/platform-tools/:$JAVA_HOME/bin
  开始编写自动化测试
  终于到了开始写代码的时候了,相信你已经迫不及待了,别急,你还要准备以下条件:
  模拟器或者测试机必须是Ready的状态,每次启动模拟器都很费时间,所以建议模拟器不要关闭,通过代码来启动模拟器是一个办法,但是时间成本有点高。
  如果是调试代码阶段,建议保持Appium桌面版长期运行,但是Appium和uiautomator有冲突,只能二选一。
  Appium会根据你的测试代码去寻找符合要求的设备,如果你启动了多台虚拟机或者连接了多台实体机,请显式地在代码中指定设备名称或者版本号。
  自动化测试代码例子如下,启动内置拨号软件,搜索关键字。
from appium import webdriver
desired_caps = {}
desired_caps['platformName'] = 'Android'
desired_caps['platformVersion'] = '7.1.1'
desired_caps['deviceName'] = 'Android Emulator'
desired_caps['appPackage'] = 'com.android.dialer'
desired_caps['appActivity'] = 'DialtactsActivity'
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
driver.find_element_by_id('com.android.dialer:id/search_box_collapsed').click()
search_box = driver.find_element_by_id('com.android.dialer:id/search_view')
search_box.click()
search_box.send_keys('hello toby')
  恭喜你,解锁了移动应用测试的新成就!

上文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理。
《2023软件测试行业现状调查报告》独家发布~

精彩评论

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号