[Android测试] Appium的一些坑问题错误解决 与 技巧集锦

原创 2016年09月22日 16:42:20

问题

1. error: Failed to start an Appium session, err was: Error: Requested a new session but one was in progress

这里写图片描述
之前的会话没有关闭,然后你又运行了测试实例,也没有设置覆盖.
解决:
1. 重新停止appium服务,开启Appium服务
2. 在Genarel Setting那里设置覆盖Session,重启Appium

测试结束在AfterClass加driver.quit()

2. error: Failed to start an Appium session, err was: Error: Command failed: C:\Windows\system32\cmd.exe /s /c “D:\android-sdk-windows\platform-tools\adb.exe -s adb server version (32) doesn’t match this client (36); killing…

wait-for-device”
error: could not install smartsocket listener: cannot bind to 127.0.0.1:5037:

这里写图片描述

没有链接上手机或者模拟器,请确认已经连接成功,重新链接

3. error: Android devices must be of API level 17 or higher. Please change your device to Selendroid or upgrade Android on your device.

这里写图片描述

手机系统低于4.2,appium不支持4.2.2以下的系统,请换一个手机或者模拟器来测试。

4. Error: Permission to start activity denied.

这里写图片描述
**activity在清单文件里面没添加android:exported=”true”的话,你不能直接打开对应的activity,需要从启动页activity打开。
exported属性就是设置是否允许activity被其它程序调用**

5. error: Failed to start an Appium session, err was: Error: Activity used to start app doesn’t exist or cannot ve launched! Make usre it exists and is launchable activity

这里写图片描述

要打开的activity不存在,activity路径错误,改为完整正确的activity路径

6. error: Failed to start an Appium session, err was: Error: ‘java - version’ failed. Error: Command failed: C:\Windows\system32\cmd.exe /s /c “java -version”

这里写图片描述
Java版本错误,请安装最新的版本

7.> info: [debug] Error: Command failed: C:\Windows\system32\cmd.exe /s /c “D:\android-sdk-windows\platform-tools\adb.exe -s 8806a0b0 shell “echo ‘ready‘“error: unknown host service

这里写图片描述

链接手机失败,重新链接手机即可,我就是重新拔插了一下usb

Error: Command failed: C:\Windows\system32\cmd.exe /s /c “D:\android-sdk-windows\platform-tools\adb.exe -s 8806a0b0 shell “echo ‘ping’”“

error: unknown host service

adb被突然占用导致,例如你在运行用例的时候运行了模拟器。

7. UIAutomatorViewer提示: Unable to connect to adb. Check if adb is installed correctly

解决,sdk升级到了25产生的问题。

解决方法:

  1. 将adb.exe 复制一份到uiautomatorviewer.bat 目录下
  2. 修改uiautomatorviewer.bat文件最后一行(改binddir=%prog_dir%为自己的platform-tools本地路径)
    image

技巧

1. 每次测试都重新安装app

为capabilities色设置noReset为true
capabilities.setCapability(“noReset”, true);

2. 中文乱码

这都是编码问题:

1.方法1:

Android Studio修改文件编码的方法,最底部的UTf-8,点击选GBK就可以了,reload文件。(ps: 先把文件内容全选复制一下再转换编码,再粘贴,不然文件内容就变乱码了)

这里写图片描述

2.方法2:

用的是原来的UTF-8编码,然后在测试module的build.gradle里面添加三行代码

tasks.withType(JavaCompile){
    options.encoding = 'UTF-8'
}

这里写图片描述

3. 清除编辑框EditText内容

这个问题好像是看手机系统的,我之前的手机就会出现sendKeys的时候没有全选去掉本来的内容,现在都会自动全选覆盖了,这个也不算问题了。

    /**
     * 逐字删除编辑框中的文字
     * @param element 文本框架控件
     */
    public void clearText(AndroidElement element){
        String className = element.getClass().getSimpleName();
        if (className.equals("EditText")){
            String text = element.getText();
            //跳到最后
            driver.pressKeyCode(KEYCODE_MOVE_END);
            for (int i = 0; i < text.length(); i ++){
                //循环后退删除
                driver.pressKeyCode(BACKSPACE);
            }
        }else {
            print("不是文本输入框架,无法删除文字");
        }

    }

4. 点击输入法键盘的回车搜索

方法1: 切换输入法

利用adb命令先切换为自己的输入法,按了搜索再切换为appium的输入法

查看当前手机的输入法

cmd执行下面的的代码

adb shell ime list -s

可以看到类似下面的结果,

C:\Users\LITP>adb shell ime list -s
com.baidu.input_mi/.ImeService
com.sohu.inputmethod.sogou.xiaomi/.SogouIME
io.appium.android.ime/.UnicodeIME

C:\Users\LITP>

执行adb命令

先写好一个执行cmd的方法

    /**
     * 执行adb命令
     * @param s 要执行的命令
     */
    private void excuteAdbShell(String s) {
        Runtime runtime=Runtime.getRuntime();
        try{
            runtime.exec(s);
        }catch(Exception e){
            print("执行命令:"+s+"出错");
        }
    }

在需要搜索的时候执行下面的代码,切换的输入法用自己查看列表的输入法内容,我这里是搜狗输入法

        //使用adb shell 切换输入法-更改为搜狗拼音,这个看你本来用的什么输入法
        excuteAdbShell("adb shell ime set com.sohu.inputmethod.sogou.xiaomi/.SogouIME");
        //再次点击输入框,调取键盘,软键盘被成功调出
        clickView(page.getSearch());
        //点击右下角的搜索,即ENTER键
        pressKeyCode(AndroidKeyCode.ENTER);
        //再次切回 输入法键盘为Appium unicodeKeyboard
        excuteAdbShell("adb shell ime set io.appium.android.ime/.UnicodeIME");
版权声明:本文为博主原创文章,转载请带上出处,谢谢。 https://blog.csdn.net/niubitianping/article/details/52624417

appium Activity used to start app doesn't exist or cannot be launched 问题解决

appium Activity used to start app doesn't exist or cannot be launched 问题解决         运行appium测试报错 “er...
  • achang21
  • achang21
  • 2017-03-09 18:02:11
  • 1807

《Appium学习中遇到的问题》之“运行脚本时报错:Activity used to start app doesn't exist or cannot be launched!”

运行脚本时报错:Activity used to start app doesn't exist or cannot be launched! 解决方案:初始化appium设置的ap...
  • Gorky1112
  • Gorky1112
  • 2017-12-07 10:08:18
  • 113

Appium Desktop-启动异常Permission to start activity denied.

Appium DesKtop 配置了各项参数后,启动报错 [MJSONWP] Encountered internal error running command: Error: Error occ...
  • miss_hua
  • miss_hua
  • 2017-11-30 16:54:36
  • 909

Appium测试app报错Permission to start activity denied.

一、现象提示启动activity被拒绝,具体报错如下:A new session could not be created. (Original error: Permission to start ...
  • hualf
  • hualf
  • 2017-12-21 12:32:15
  • 263

Android问题集锦之八:调用其他程序中的activity和Permission Denial: starting Intent 错误解决办法

今天想调试多个task中栈的情况,在测试程序中调用另一个程序的activity, 代码片段如下: btnStartX=(Button)findViewById(R.id.btnStar...
  • lincyang
  • lincyang
  • 2011-09-22 17:40:10
  • 38414

Appium TS1 - Command failed: error: cannot bind to socket

搭完 Appium 环境, 跑示例代码时
  • pjinglian
  • pjinglian
  • 2014-06-16 15:17:00
  • 2228

appium知识总结

自动化测试文档学习
  • qq_21826709
  • qq_21826709
  • 2017-01-17 11:43:42
  • 1112

appium junit运行解决第二条用例运行报错(error: Requested a new session but one was in progress)

初学appium时发现用junit运行第二条用例的时候会报错发现很多人都遇到此问题。 问题原因: 因为在appium配置的代码部分用的是@Before注释(目前的appium的新手教程中用的都是这个方...
  • haipeng1
  • haipeng1
  • 2017-03-23 11:53:59
  • 411

android自动化测试--appium运行的坑问题及解决方法

问题 1. error: Failed to start an Appium session, err was: Error: Requested a new session but one w...
  • m0_38100619
  • m0_38100619
  • 2017-12-07 16:54:53
  • 403

Error occured while starting App. Original error: Permission to start activity denied.错误的解决方法

错误异常:eclipse1) LoginTest(com.csdn.test.LoginTest)org.openqa.selenium.WebDriverException: An unknown ...
  • youxitou
  • youxitou
  • 2018-02-22 17:06:13
  • 213
收藏助手
不良信息举报
您举报文章:[Android测试] Appium的一些坑问题错误解决 与 技巧集锦
举报原因:
原因补充:

(最多只允许输入30个字)