Appium 利用 IPython 来学习 Appium

付海全 · February 09, 2017 · Last by 思寒_seveniruby replied at March 19, 2017 · 1607 hits
本帖已被设为精华帖!

Appium简介

Appium是目前非常流行的移动端自动化测试工具,它是一个开源、跨平台的自动化测试工具,用于测试原生和轻量移动应用,支持 iOS, Android 和 FirefoxOS 平台。同时它也支持python语言来编写测试代码,下面就介绍一下怎么用IPython Shell来学习Appium。

Appium测试环境

Appium环境搭建

首先是Appium的环境搭建,这部分请参考官网的文档,如果有问题可以上网搜索,能找到很多相关的教程。
完成搭建之后在终端中输入下面命令来检查环境是否正确。

$ appium-doctor

输出如下:

info AppiumDoctor Appium Doctor v.1.4.1
info AppiumDoctor ### Diagnostic starting ###
info AppiumDoctor The Node.js binary was found at: /usr/bin/node
info AppiumDoctor Node version is 6.3.1
----
info AppiumDoctor Everything looks good, bye!
info AppiumDoctor

Android手机设置

准备一部android手机,我的使用的手机是Nexus 4,系统版本是5.1.1。
开启手机的开发者模式,然后设置充电时不锁定屏幕,这样测试时会方便一点。
通过数据线将手机和电脑相连接,在手机上选择允许USB调试。

最后在终端输入下面命令来检查设备是否链接正常:

$ adb devices

输出如下:

List of devices attached
04c5a5af52197902 device

Appium服务启动

环境搭建好之后,通过下面命令来启动appium服务

$ appium -a 127.0.0.1 -p 4723  #启动服务,并且指定ip和端口

可以通过下面命令来查看具体的选项的说明和用法:

$ appium --help

利用IPython学习Appium

第一个appium自动化python脚本

打开你最喜爱的文本编辑器(例如:vim),输入下面python代码,并保存为appium_deom.py文件。

#!/usr/bin/env python3
# coding=utf-8
from appium import webdriver

desired_caps = {}
desired_caps['platformName'] = 'Android' #设置操作平台
desired_caps['platformVersion'] = '5.1.1' #操作系统版本
desired_caps['deviceName'] = 'Nexus 4' #设备名称
# 设置要启动的应用的包名,可以通过UI automator Viewer工具查看
desired_caps['appPackage'] = 'com.android.calculator2'
# 设置启动应用的首页信息,可以通过adb logcat抓取到
desired_caps['appActivity'] = '.Calculator'
desired_caps['udid'] = '04c5a5af52197902' #设备ID,可以通过adb devices命令查看
desired_caps['noReset'] = 'True' # 设置会话不会重置
desired_caps['unicodeKeyboard'] = 'True' #设置可以输入中文
desired_caps['resetKeyboard'] = 'True' #同上,设置中文输入
#设置python shell命令行的超时时间,默认是60秒
desired_caps['newCommandTimeout'] = 6000
print(desired_caps) #打印配置信息

#使用上面的配置,新建driver对象
driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)
driver.implicitly_wait(10) #使用隐性等待10秒

注意:
newCommandTimeout选项一定要设置的时间比较长,默认的60秒,如果在ipython中长时间不输入语句的话,很容易出现会话自动结束问题。
另外,上面代码中“appPackage”和“appActivity”必须设置,如果没有设置会提示错误信息。

IPython的基本使用可以参考之前写的文章IPython基本介绍
在终端中输入命令启动ipython并且运行脚本

$ ipython
Python 3.5.2+ (default, Nov 3 2016, 11:10:16)
----
help -> Python's own help system.
object? -> Details about 'object', use 'object??' for extra details.
In [1]: %run appium_deom.py #运行上面写好的脚本
{'appPackage': 'com.android.calculator2', 'platformName': 'Android',
'resetKeyboard': 'True', 'unicodeKeyboard': 'True', 'udid': '04c5a5af52197902',
'platformVersion': '5.1.1', 'noReset': 'True', 'newCommandTimeout': 6000,
'deviceName': 'Nexus 4', 'appActivity': '.Calculator'}
In [2]:

通过%run 命令运行脚本成功后,脚本中的变量和函数等可以直接在ipython中使用。

利用ipython探索appium api

Tab自动补齐

通过在ipython shell中输入driver.后按[Tab 键]。即利用ipython的自动补齐功能可以查看driver对象下有多少方法和属性。

输入图片说明

也可以输入部分关键词后自动补齐,补齐的方式和bash shell类似。例如输入driver.find_element后按Tab键:

输入图片说明

help()函数查看帮助

还有可以利用help函数来查看driver对象中的函数的使用方法,命令示例:

In [3]: help(driver.get_screenshot_as_file)

输出如下:

Help on method get_screenshot_as_file in module selenium.webdriver.remote.webdriver:
get_screenshot_as_file(filename) method of appium.webdriver.webdriver.WebDriver instance
Gets the screenshot of the current window. Returns False if there is
any IOError, else returns True. Use full paths in your filename.
:Args:
- filename: The full path you wish to save your screenshot to.
:Usage:
driver.get_screenshot_as_file('/Screenshots/foo.png')

在ipython中执行python语句

现在可以在ipython中一条一条的执行python代码,可以马上在手机上看到效果,例如执行元素定位并点击操作的语句:

In [9]: driver.find_element_by_id('com.android.calculator2:id/digit_7').click()  #找到按钮“7”并点击

如果没有问题的话,你马上就可以在手机上看到appium的执行效果。
通过这种方法,你可以进行实验,或者试错法。也可以通过粘贴网上的代码到ipython中运行,可以马上查看运行结果。

最后,执行下面语句来退出driver,结束本次测试。

In [10]: driver.quit()

小结

利用ipython不需要编写完整的脚本后再运行和调试,可以直接单条语句运行和调试,这样就为我们节省了不少时间。个人认为学习IT方面的知识,多动手实践是非常好的学习方式。而ipython正好能帮助我们快速方便的探索和实验appium的使用方法。

共收到 5 条回复 时间 点赞

好详细,支持一下

好东西,学习一下

思寒_seveniruby 将本帖设为了精华贴 09 Feb 18:22

加精理由: 动手能力不错, 有探索精神

#4楼 @seveniruby 谢谢,支持😀

请更新二维码,你已经错过本轮的社区统一打赏

需要 Sign In 后方可回复, 如果你还没有账号请点击这里 Sign Up