一、Android启动app
python启动脚本如下:
from appium import webdriver
desired_caps = {}
desired_caps['platformName'] = 'Android'
desired_caps['platformVersion'] = '4.4'
#desired_caps['app'] = os.path.abspath('/Users/a58/Downloads/zhuanzhuan_market_923.apk')
desired_caps['appPackage'] = 'com.wuba.zhuanzhuan'
desired_caps['appActivity'] = '.presentation.view.activity.LaunchActivity'
desired_caps['appActivity'] = '.presentation.view.activity.LaunchActivity'
wd = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)
说明:
1.appium通过webdriver.Remote()传递appium的server地址和启动的client信息desired_caps
2.server的格式“http://serverip地址:4723/wd/hub”
3.desired_caps是一个字典格式,包含platformName等
各项介绍如下:
|`platformName`|你要测试的手机操作系统|`iOS`, `Android`, 或 `FirefoxOS`|
|`platformVersion`|手机操作系统版本|例如: `7.1`, `4.4`|
|`appPackage`| 你想运行的Android应用的包名|比如`com.example.android.myApp`, `com.android.settings`|
|`appActivity`| 你要从你的应用包中启动的 Android Activity 名称。它通常需要在前面添加 `.` (如:使用`.MainActivity` 而不是 `MainActivity`) |`MainActivity`, `.Settings`|
|`app`|`.ipa` or `.apk`文件所在的本地绝对路径或者远程路径,也可以是一个包括两者之一的`.zip`。 Appium会先尝试安装路径对应的应用在适当的真机或模拟器上。针对Android系统,如果你指定`app-package`和`app-activity`(具体见下面)的话,那么就可以不指定`app`。 **会与 `browserName` 冲突** |比如`/abs/path/to/my.apk`或`http://myapp.com/app.ipa`|
4.Android机上如果安装了要测试的app,可以通过appPackage和appActivity指定要启动的app界面,而不需要app
如果指定了app(apk安装目录),则不用指定appPackage和appActivity。每次都会去重新安装一遍
5.通过[adb devices]来判断真机是否连接到电脑上了(我用的是真机,一定要用数据线连接到电脑上)
全部参数:
automationName:使用哪个自动化引擎,默认是Appium
platformName:使用哪个移动操作系统,iOS Android 或者 FirefoxOS
platform Version: 移动操作系统的版本
device Name:使用的移动设备或者模拟器类型,例如Android Emulator,在ios系统下通过 instruments -s devices命令 返回正确的设备,android的话使用adb devices可以获取设备的id
app: 绝对本地路径或者指向ipa或apk文件,对于android来说如果指定了appPackage和appActivity属性,那么该属性就不是必须的。
browserName:用于自动化测试ide移动Web浏览器,例如ios为Safari,android为Chrome Chromium 或Browser
newCommandTimeout:Appium等待接收从客户端发送的新命令的超时时长,超时后Appium认为客户端已经退出,终止会话。
autoLaunch:是否让Appium自动安装和启动应用,默认为True
language:设置语言
locale:设置位置
udid:所链接物理设备的唯一设备标识符
orientation:指定一个特定的方向
autoWebview:直接进入Webview内容中,默认为false
noReset:在会话前不重置应用状态,默认为false
fullReset:在ios中删除整个模拟器文件夹,在android中ton故宫卸载APP来重置app状态,而不是清楚数据。
Appium server capabilities (只针对android)
appActivity:测试人员希望从保重启动的android activity的名称,通常都会加个前缀“ . ”
appPackage:希望运行的android应用的java包,例如com.example.android.myApp
appWaitActivity:希望等待的Android Activity的名称
appWaitPackage:希望等待的Java包的名称
deviceReadyTimeout:等待设备就绪的超时时长,以秒为单位
androidCoverage:完全合格的instrumentation类
enablePerformanceLogging:让Chromedriver的性能日志功能生效,只针对Chrome和Webview,默认为false
androidDeviceSocket:Devtool socket名,只有当待测应用是Chromium embedding browser时才需要,浏览器打开端口,Chromedriver以devtools客户端的方式连接该端口
avd:启动的avd名(android virtual device)
avdLaunchTimeout:等待avd启动和链接到adb的超时时长,单位为毫秒,默认120000
avdReadyTimeout:等待avd完成其开机动画的超时时长,单位为毫秒,默认120000
avdArgs:当启动avd时,用到的其它模拟器参数
useKeystore:使用一个自定义密钥库来签名apk,默认为false
keystorePath:自定义密钥库的路径,默认为~/.android/debug.keystore
keyAlias:key的别名
keyPassword:Key的密码
chromdriverExecutable:指向webdriver executable的绝对本地路径
autoWebviewTimeout:等待webview内容激活的超时时长 ,毫秒单位,默认2000
intentAction:用来启动activity的Intent action(默认为android.intent.action.MAIN)
unicodeKeyboard:启用Unicode输入,默认为false
ignoreUnimportantViews:调用函数uiautomator()和setCompressedLayoutHierarchy(),该属性可以加速测试执行,原因在于Accessibility命令忽略某些元素时运行更快,忽略的元素无法找到,默认false
Appium server capabilities (只针对iOS)
calendarFormat:设置ios模拟器的日历格式
bundleID:待测应用的bundleID
udid:所连接的物理设备的唯一的设备标识符
launchTimeout:在假定instruments已经挂掉了并终止会话前的超时时长,单位为毫秒
locationServicesEnabled:(只针对模拟器)强制打开或者关闭位置服务,默认保持当前设置
locationServicesAuthorized:(只针对模拟器)通过plist授权设置位置服务或者不授权设置位置服务,这样位置服务警告框就不会弹出,默认保持当前设置,注意如果使用了该设置,则必须同时使用bundleid属性
autoAcceptAlerts:遇到弹出的ios隐私访问权限警告时自动接受,默认为false
autoDismissAlerts:弹出ios隐私访问权限警告,自动解除,默认false
nativeWebTap:在Safari中,启用真实的 非基于javascript的web单击,默认false
safariInitialUrl:初始化safari url,默认是本地欢迎页面
safariAllowPopups:在safari中允许javascript打开新窗口
safariIgnoreFraudWarning:阻止safari显示一个欺诈性网站的警告
safariOpenLinksInBackground:safari是否允许在新窗口中打开链接
keepKeyChains:在appium会话启动和终止时,是否保存keychains
interKeyDelay:打字时发送到某个元素的按键敲击之间的时长,以毫秒为单位
showiOSLog:是否在Appium日志中显示任何从设备捕获的日志
screenshotWaitTimeout:等待截屏产生的最大超时时长,单位为秒,默认10
waitForAppScript:用来判断应用是否已经启动,ios自动化测试脚本,默认情况下系统等待页面源码不为空,结果是布尔值