Appium的一些常见问题及解决方法

问题1:报错A new session could not be created. (Original error: Requested a new session but one was in progress)。
这里写图片描述
原因:之前的会话没有关闭,然后又运行了测试实例导致的。
解决方法:停止Appium服务,选择设置图标,然后在General Settings中勾选覆盖Session,重启Appium,如下图所示:
这里写图片描述

问题2:使用sendKeys()方法时出现无法输入中文,而数字和英文字母都可以
解决方法:

cap.setCapability("unicodeKeyboard", true);//使用 Unicode 输入法
cap.setCapability("resetKeyboard", true); //重置输入法到原有状态

问题3:向sendKeys(CharSequence[])方法传递String类型的参数将会编译出错,提示:sendKeys(CharSequence[]) in the type WebElement is not applicable for the arguments (String)
解决:将java compiler 改变到1.5以上
注意:Java Build Path是运行时环境 ,Java Compiler是编译时环境

问题4及解决:每次测试是否重新安装app 以及签名。做如下设置来避免每次测试都需要进行重新登录。

cap.setCapability("noSign", "True"); //不重新签名apk
cap.setCapability("noReset", "True"); //是否不需要重新安装app

问题5:报错: Android devices must be of API level 17 or higher. Please change your device to Selendroid or upgrade Android on your device.
解决:Appium不支持4.2.2以下的系统,将手机或模拟器的系统进行更新。

问题6:
1. 如何找appPackage、appActivity
2. 报错:Error occured while starting App. Original error: Permission to start activity denied. 这是由于启动了错误的activity
解决:先对待测App进行一些操作,然后在cmd中输入以下命令:

adb shell dumpsys activity activities > log.txt

命令执行后会生成一个log.txt文件(若需要指定该文件路径,只需要在该文件名前添加路径即可,例如:F:\Appium\log.txt),打开该文件,查找关键字:LAUNCHER,即可找到,如下图所示:(其中红框部分分别为appPackage、appActivity)
这里写图片描述

问题7:如何获得真机的deviceName
解决:
方法1: 命令行输入:adb devices
这里写图片描述
红框内的数字就是deviceName的一部分,完整结构是:品牌-型号_这串数字,
(型号可通过手机查看,设置里面有个关于手机),例如:oppo-oppo_a33-9729eb6b
方法2:利用UI Automator Viewer工具,列表显示的是deviceName的全称,如下图所示:
这里写图片描述
注:需要有多台Android设备连接PC时才能显示设备列表,包括模拟器在内,否则不会出现该列表。

### Appium 使用中的常见问题解决方法 #### 启动 Appium 和运行脚本时遇到的问题 当点击启动 Appium 按钮后,如果显示 `[Appium] Welcome to Appium v1.7.2` 提示,则表示 Appium 已经成功启动并准备就绪[^1]。 #### 证书签名错误导致的应用安装失败 对于因证书签名不一致而导致的应用无法安装或认证错误的情况,通常发生在更换不同版本的 Appium 客户端之后。此时应考虑更新至最新版 appium-desktop 或者通过设备上的应用管理功能卸载所有与 Appium 相关的应用组件后再重新尝试执行测试脚本[^2]。 #### 权限不足引起的服务启动异常 若发现由于权限不够而造成 Appium server 启动困难的情形下,建议采用具备更高权限的方式开启 Appium server,比如以管理员身份运行相应的应用程序来规避此类障碍。 #### 手动干预特定服务的状态调整 针对某些情况下程序未能自动激活 `appiumsettings` 的状况,可以通过手动方式触发此服务的操作;尽管这一步骤可能不会呈现直观可见的用户界面,但这属于预期行为的一部分[^3]。 #### 配置环境变量以便于命令行工具调用 为了确保能够在任意路径下调用到像 `appium-doctor` 这样的辅助诊断工具而不遭遇找不到命令的问题,应当确认已将这些工具所在的目录加入系统的 PATH 环境变量之中[^4]。 #### iOS 设备的信任设置必要性说明 在开展基于 iOS 平台的自动化测试之前,务必完成对所使用的 Apple ID 用户账号进行一次性的“信任”授权动作,这对于后续顺利部署和控制真机至关重要[^5]。 ```bash export PATH=$PATH:/path/to/appium/binaries ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值