Appium最新的服务器初始化参数(Capability)【截止11月29日,后续最新的可以看github】
键 | 描述 | 值 |
---|---|---|
automationName |
自动化测试的引擎 | Appium (默认)或者 Selendroid |
platformName |
使用的手机操作系统 | iOS , Android , 或者 FirefoxOS |
platformVersion |
手机操作系统的版本 | 例如 7.1 , 4.4 |
deviceName |
使用的手机或模拟器类型 |
等等.... 在 iOS 上,使用 Instruments的
备的列表。在Andorid 上虽然这个 参数目前已被忽略, 但仍然需要添加上该参数 |
app |
本地绝对路径_或_远程 http URL 所指向的一个安装包 ( Appium 将其安装到合适的设备上。 请注意,如果您指定了 和 Android 则不需要此参数了。 该参数也与 |
|
browserName |
做自动化时使用的浏览器名字。 如果是一个应用则只需填写个 空的字符串 |
'Safari' 对应 iOS,'Chrome', 'Chromium', 或 'Browser' 则对 应 Android |
newCommandTimeout |
用于客户端在退出或者结束 session 之前,Appium 等待客户端发送一条 新命令所花费的时间(秒为单位) |
例如 60 |
language |
(Sim/Emu-only) 为模拟器设置语言 | 例如 fr |
locale |
(Sim/Emu-only) 为模拟器设置所在 区域 |
例如 fr_CA |
udid |
连接真机的唯一设备号 | 例如 1ae203187fc012g |
orientation |
(Sim/Emu-only) 模拟器当前的方向 | 竖屏 或 横屏 |
autoWebview |
直接转换到 Webview 上下文 (context)。默认值为 |
true , false |
noReset |
在当前 session 下不会重置应用的 状态。默认值为 |
true , false |
fullReset |
(iOS)删除所有的模拟器文件夹。 (Android)要清除 app 里的数据, 请将应用卸载才能达到重置应用的 效果。在 Android, 在session 完 成之后也会将应用卸载掉。 默认值为 |
true , false |
Android 独有
键 | 描述 | 值 |
---|---|---|
appActivity |
Activity 的名字是指从你的包中所要启动 的 Android acticity。他通常需要再前面 添加
|
MainActivity , .Settings |
appPackage |
运行的 Android 应用的包名 |
|
appWaitActivity |
用于等待启动的 Android Activity 名称 | SplashActivity |
appWaitPackage |
用于等待启动的 Android 应用的包 |
|
appWaitDuration |
用于等待 appWaitActivity 启动的超时时间 (以毫秒为单位)(默认值为 |
30000 |
deviceReadyTimeout |
用于等待模拟器或真机准备就绪的超时时间 | 5 |
androidCoverage |
用于执行测试的 instrumentation 类。 传送
|
|
enablePerformanceLogging |
(仅适用于 Chrome 与 webview)开启 Chromedriver 的性能日志。(默认值为 |
true , false |
androidDeviceReadyTimeout |
用于等待设备在启动应用后准备就绪的超时时间。 以秒为单位。 |
例如 30 |
androidInstallTimeout |
用于等待在设备中安装 apk 所花费的时间 (以毫秒为单位)。默认值为 |
例如 90000 |
adbPort |
用来连接 ADB 服务器的端口(默认值为 5037 ) |
5037 |
androidDeviceSocket |
开发工具的 socket 名称。只有在被测应用是一个使用 Chromium 内核的浏览器时才需要。socket 会被浏 览器打开,然后 Chromedriver 把它作为开发者工具 来进行连接。 |
例如 chrome_devtools_remote |
avd |
被启动 avd 的名字 | 例如 api19 |
avdLaunchTimeout |
用于等待 avd 启动并连接 ADB 的超时时间 (以毫秒为单位),默认值为 |
300000 |
avdReadyTimeout |
用于等待 avd 完成启动动画的超时时间 (以毫秒为单位),默认值为 |
300000 |
avdArgs |
启动 avd 时使用的额外参数 | 例如 -netfast |
useKeystore |
使用自定义的 keystore 给 apk 签名, 默认值为 |
true 或false |
keystorePath |
自定义 keystore 的路径, 默认路径 为 ~/.android/debug.keystore |
例如 /path/to.keystore |
keystorePassword |
自定义 keystore 的密码 | 例如 foo |
keyAlias |
key 的别名 | 例如 androiddebugkey |
keyPassword |
key 的密码 | 例如 foo |
chromedriverExecutable |
webdriver 可执行文件的绝对路径 (如果 Chromium 内嵌一个自己提供的 webdriver,则应使用他去替换掉 Appium 自带的 chromedriver) |
/abs/path/to/webdriver |
autoWebviewTimeout |
用于等待 Webview 上下文(context) 激活的时间(以毫秒为单位)。默认值为 |
例如 4 |
intentAction |
用于启动 activity 的 intent action (默认值为 |
例如
|
intentCategory |
用于启动 activity 的 intent category。 (默认值为 |
例如
|
intentFlags |
用于启动 activity 的标识(flags) (默认值为 |
例如 0x10200000 |
optionalIntentArguments |
用于启动 activity 的额外 intent 参数。 请查看 Intent 参数 |
例如
|
dontStopAppOnReset |
在使用 adb 启动应用之前,不要终止被测应用的进程。 如果被测应用是被其他钩子(anchor)应用所创建的, 设置该参数为 false 后,就允许钩子(anchor)应用的进 程在使用 adb 启动被测应用期间仍然存在。换而言之, 设置
capability 或 设置为 (flag)。默认值为
|
true 或false |
unicodeKeyboard |
使用 Unicode 输入法。 默认值为 false |
true 或false |
resetKeyboard |
在设定了 重置输入法到原有状态。如果单独使用,将会被忽略。 默认值为 |
true 或false |
noSign |
跳过检查和对应用进行 debug 签名的步骤。仅适用于 UiAutomator,不适用于 selendroid。 默认值为 |
true 或false |
ignoreUnimportantViews |
调用 uiautomator 的函数
由于 Accessibility 命令在忽略部分元素的情况下执 行速度会加快,这个关键字能加快测试执行的速度。 被忽略的元素将不能够被找到,因此这个关键字同 时也被实现成可以随时改变的 设置 ( settings )。 默认值为 |
true 或 false |
disableAndroidWatchers |
禁用 android 监视器(watchers)。监视器用于 见识应用程序的无响应状态(anr)和崩溃(crash), 禁用会降低 Android 设备或模拟器的CPU 使用率。 该 capability 仅在使用 UiAutomator 时有效, 不适用于selendroid,默认设置为 |
true 或 false |
chromeOptions |
允许对 ChromeDriver 传 chromeOptions 的参数。 了解更多信息请查阅 chromeOptions |
|
recreateChromeDriverSessions |
当移除非 ChromeDriver webview时, 终止掉 ChromeDriver的 session。 默认设置为 |
true 或false |
nativeWebScreenshot |
在 web 的上下文(context),使用原生 (native)的方法去截图,而不是用过代理 的 ChromeDriver。默认值为 |
true 或false |
androidScreenshotPath |
在设备中截图被保存的目录名。 默认值为 |
例如 /sdcard/screenshots/ |
autoGrantPermissions |
让Appium自动确定您的应用需要哪些权限, 并在安装时将其授予应用。默认设置为 |
true 或false |
iOS 独有
键 | 描述 | 值 |
---|---|---|
calendarFormat |
(仅支持模拟器) 为iOS的模拟器设置日历格式 | 例如 gregorian |
bundleId |
被测应用的 bundle ID 。用于在真实设备中启动测试, 也用于使用其他需要 bundle ID 的关键字启动测试。 在使用 bundle ID 在真实设备上执行测试时,你可以 不提供 |
例如 io.appium.TestApp |
udid |
连接的真实设备的唯一设备编号 (Unique device identifier) |
例如 1ae203187fc012g |
launchTimeout |
以毫秒为单位,在 Appium 运行失败之前设置一个 等待 instruments 的时间 |
例如 20000 |
locationServicesEnabled |
(仅支持模拟器)强制打开或关闭定位服务。 默认值是保持当前模拟器的设定. |
true 或false |
locationServicesAuthorized |
(仅支持模拟器)通过修改 plist 文件设定是否允许应用 使用定位服务,从而避免定位服务的警告出现。默认值是 保持当前模拟器的设定。请注意在使用这个关键字时,你 同时需要使用 bundle ID。 |
true 或false |
autoAcceptAlerts |
当警告弹出的时候,都会自动去点接受。 包括隐私访问权限的警告(例如 定位,联系人,照片)。 默认值为 false。不支持基于 |
true 或false |
autoDismissAlerts |
当警告弹出的时候,都会自动去点取消。 包括隐私访问权限的警告(例如 定位,联系人,照片)。 默认值为 false。不支持基于 |
true 或false |
nativeInstrumentsLib |
使用原生 intruments 库 (即关闭 instruments-without-delay)。 |
true 或false |
nativeWebTap |
(仅支持模拟器)在Safari中允许“真实的", 非基于 javascript 的 web 点击 (tap) 。 默认值: 大小/比例, 点击操作不一定能精确地点中 对应的元素。 |
true 或false |
safariInitialUrl |
(仅支持模拟器) (>= 8.1) 初始化 safari 的 时使用的地址。默认是一个本地的欢迎页面 |
例如 https://www.github.com |
safariAllowPopups |
(仅支持模拟器)允许 javascript 在 Safari 中创建新窗口。默认保持模拟器当前设置。 |
true 或false |
safariIgnoreFraudWarning |
(仅支持模拟器)阻止 Safari 显示此网站可能 存在风险的警告。默认保持浏览器当前设置。 |
true 或false |
safariOpenLinksInBackground |
(仅支持模拟器)Safari 是否允许链接在新 窗口打开。默认保持浏览器当前设置。 |
true 或false |
keepKeyChains |
(仅支持模拟器)当 Appium 会话开始/结束时是否保 留存放密码存放记录 (keychains) 库(Library)/钥匙 串(Keychains)) |
true 或false |
localizableStringsDir |
从哪里查找本地化字符串。默认值为 en.lproj |
en.lproj |
processArguments |
通过 instruments 传递到 AUT 的参数 | 例如 -myflag |
interKeyDelay |
以毫秒为单位,按下每一个按键之间的延迟时间 | 例如 100 |
showIOSLog |
是否在 Appium 的日志中显示设备的日志。 默认值为 |
true 或false |
sendKeyStrategy |
输入文字到文字框的策略。模拟器默认值:
(一个接着一个)。真实设备默认值:
|
oneByOne , grouped 或setValue |
screenshotWaitTimeout |
以秒为单位,生成屏幕截图的最长等待时间。 默认值为:10 |
例如 5 |
waitForAppScript |
用于判断 "应用是否被启动” 的 iOS 自动化脚本代码。 默认情况下系统等待直到页面内容非空。 结果必须是布尔类型。 |
例如
|
webviewConnectRetries |
用于获取 webview 失败时,发送连接信息到远程调 试器的次数。默认次数为: |
例如 12 |
appName |
被测应用的名字。 用于支持 iOS 9 以上系统的应用的 自动化。 |
例如 UICatalog |
customSSLCert |
(Sim/Emu-only) 给模拟器添加一个 SSL 证书。 |
例如
|
使用 XCUITest(iOS 独有)
键 | 描述 | 值 |
---|---|---|
processArguments |
将会传送到 WebDriverAgent 的进程参数与环境 |
或
|
wdaLocalPort |
如果这个值被指定了,Mac 主机就会使用 这个端口,通过 USB 发送数据到 iOS 设 备中。默认的端口与iOS 设备中 WDA 的 端口号是一致的。 |
例如 8100 |
showXcodeLog |
是否显示运行测试时 Xcode 的输出日志, 如果值设置为 产生大量的额外日志。默认设置为 |
例如 true |
iosInstallPause |
安装应用程序与启动 WebDriverAgent 之间停止的间隔时间(以毫秒为单位), 特别适用于体积较大的包。默认是设置为 |
例如 8000 |
xcodeConfigFile |
一个可选的 Xcode 可配置文件的完整路径, 用于指定在真机上运行 WebDriverAgent 的 个人身份或者团队身份的代码签名。 |
例如
|
keychainPath |
从系统的 keychain 中导出私有开发秘钥的 完整路径。在真机测试时与 配合使用。 |
例如
|
keychainPassword |
在 keychainPath 中指定 keychain 的解锁密码。 |
例如 super awesome password |
scaleFactor |
模拟器缩放因子。这对于默认分辨率是大于实际 分辨的模拟器来说非常有用。因此,你不用上下 滑动模拟器的屏幕就能看到所有模拟器显示的内 容了。 |
可接受的值为:
这些值都应该是一个字符串 |
preventWDAAttachments |
设置 WebDriverAgent 项目中的 DerivedData文件夹的权限为 为了防止 XCTest 框架产生大量 无用的截屏与日志,该设置是非常必要的, 因为这是不可能通过 Apple 提供的接口 去关闭的。 |
设置 capabilitity 为 将会设置Posix 的文件夹的 权限为 则会将权限重置回 |
webDriverAgentUrl |
若提供了 URL,Appium 将在这 URL 上 连接现有的WebDriverAgent 实例,而 不是重新启动一个。 |
例如 http://localhost:8100 |
useNewWDA |
若设置为 WebDriverAgent 客户端。在某些情况, 该做法可以提高稳定性。默认设置为 |
例如 true |
wdaLaunchTimeout |
等待 WebDriverAgent 可 ping 同的时间 (以毫秒为单位)。默认设置为 60000ms。 |
例如 30000 |
calendarAccessAuthorized |
若设置为 模拟器上访问日历。若设置为 则不被允许。否则,日历的 authorizationStatus 会保持不变。 |
- |
You.i 引擎独有
键 | 描述 | 值 |
---|---|---|
youiEngineAppAddress |
正在运行的应用的设备的 IP 地址。使用 作为模拟地址。使用 使用设备的 IP 地址作为真机的 IP。 |
例如 |
WinAppDriver 独有
键 | 描述 | 值 |
---|---|---|
platformName |
运行测试时所在的平台 |
例如 |
deviceName |
运行测试时所使用设备的名字 |
例如 |
app |
被测 windows 应用的 appID 或被测的 .exe 文件的路径。 查阅该文档可了解更多查找 appID 的 详细方法。 |
例如
|
本文来自博客园,作者:drewgg,转载请注明原文链接:https://www.cnblogs.com/drewgg/p/10037668.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?