终端开发

appium 爬坑之基于 Chromedriver 测试 Android webview Linux 搭建 Android 编译构建环境 appium爬坑之iMac上基于appium多设备并发测试 appium爬坑之iMac上appium环境搭建及使用真机测试Android项目简介 H5页面通过指定Schema拉起Android应用 Android JSBridge简介 Gradle插件开发系列之发布gradle插件到开源库 Gradle插件开发系列之开发第一个gradle插件 Gradle插件开发系列之gradle插件调试方法 Gradle插件开发系列之总纲 一款检查Gradle依赖配置是否冲突的插件 记一次升级Android Gradle Plugin后databing编译报错填坑经历 iMac上 Xcode 相关设置及常见问题 iOS开发 -- 首次使用Xcode运行iOS项目代码 使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 Android安装包精简系列之资源精简 Android安装包精简系列之图片优化 Android安装包精简系列之为什么要优化精简安装包 Android安装包精简系列(总纲) Android安装包精简系列之图标转字体 gradle相关资料汇总 Android编译常见错误解决 Android编译编译速度提升 终端基于gradle的开源项目运行环境配置指引 制作终端产品演示的gif 一个关于APK Signature Scheme v2签名的神奇bug定位经历 如何随apk一起打包并使用SQLite SDK热更之gradle插件(如何在SDK代码中自动插桩及如何生成补丁包) 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 SDK热更系列之概述(持续整理编辑中~) SDK热更系列之SDKHotfix待优化点 Android 终端开发相关的一些神图(持续更新) SDK热更系列之Demo项目介绍概述 SDK热更系列之Demo体验方法 SDK热更系列之如何获取应用在当前设备上的so对应的指令集 Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Robotium二三事-Android自动化测试系列(二) Robotium介绍-Android自动化测试系列(一) Android开发中遇到的那些坑 Eclipse使用中部分经验总结 Android中关于Nativa编译(NDK、JNI)的一些问题 Android简单实现的多线程下载模块 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

标签

android 48

Linux 搭建 Android 编译构建环境 H5页面通过指定Schema拉起Android应用 Android编译常见错误解决 一个关于APK Signature Scheme v2签名的神奇bug定位经历 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 Android 终端开发相关的一些神图(持续更新) Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 iMac(OS X)El Capitan 更新遇到的那些坑 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Eclipse使用中部分经验总结 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

appium 爬坑之基于 Chromedriver 测试 Android webview

「 终端开发 」 ——  2020年03月02日

最近因为项目需要对于一些Android的基础功能添加自动化测试。以前都是基于Robotium来写,比较费时费力,这次选择用Appium,而且这样测试也可以完全黑盒。

背景

在终端开发中,难免会涉及到一些weview的界面,appium提供了基于 Chromedriver 的webview测试方法,这边文章主要介绍在iMac上搭建基于 Chromedriver 测试Android webview 的自动测试环境及测试脚本。

在整个测试过程会设计到几个定义专门列一下:

  • Chrome 或者 Chrome内核版本:这个是指你的内置浏览器所使用的web内核的版本
  • Chromedriver :ChromeDriver 是 google 为网站开发人员提供的自动化测试接口,它是 selenium2 和 chrome浏览器 进行通信的桥梁。是你的电脑上的独立应用
  • appium-chromedriver :Appium 用于webview自动测试的基于ChromeDriver的扩展,通过npm安装

webview测试事例

from appium import webdriver

caps={}
caps['platformName']= "Android"
caps['deviceName']= "6518ac77"
caps["chromeOptions"] = {
    "androidProcess":"com.bihe0832.readhub:web",
    "androidPackage":"com.bihe0832.readhub"
}
caps["chromedriverExecutableDir"] = "/Users/zixie/temp/1/1mna"
driver = webdriver.Remote("http://127.0.0.1:4725/wd/hub", caps)

contexts = driver.contexts
print(contexts)
print(driver.current_context)
if len(contexts)  < 2 :
    print("no web context" + driver.current_activity)
    exit
# 切换到webview
driver.switch_to.context(contexts[1])
print(driver.current_context)

常见错误

  • 错误1:Original error: Could not load a driver for platformName ‘Android’. Please verify your Appium installation

    • 错误事例:

      selenium.common.exceptions.WebDriverException: Message: An unknown server-side error occurred while processing the command. Original error: Could not load a driver for platformName ‘Android’. Please verify your Appium installation

    • 解决方案:

      这个问题一般是因为没有安装appium-chromedriver扩展引起,可以参考 http://appium.io/docs/en/writing-running-appium/web/chromedriver/ 的提示安装。或者直接用下面的命令重装appium:

        sudo npm install -g appium --unsafe-perm=true --allow-root --chromedriver_version="2.46"
      

      然后再启动Appium的时候增加参数:--allow-insecure chromedriver_autodownload,例如:

        /usr/local/bin/appium  --allow-insecure chromedriver_autodownload -a 127.0.0.1 -p 4725 -g ./log/appium_server_4725.log
      
  • 错误2:There must be at least one Chromedriver executable available for use if the current Chrome version cannot be determined

    • 错误事例:

      WebDriverException(‘An unknown server-side error occurred while processing the command. Original error: There must be at least one Chromedriver executable available for use if the current Chrome version cannot be determined’, None, None)

    • 解决方案:

      这个问题一般是因为没有无法找到适合你的 webview 的 Chromedriver引起的,可以,根据你的webview对应的内核。然后再测试脚本中添加 chromedriverExecutableDir 的定义,例如:

        caps={}
        caps['platformName']= "Android"
        caps['deviceName']= "6518ac77"
        caps["chromedriverExecutableDir"] = "./appium"
        driver = webdriver.Remote("http://127.0.0.1:4725/wd/hub", caps)
      

    对于如何知道你的webview对应的内核版本,可以用下面的方法:

    1. 打开应用的webview界面

    2. 在PC的Chrome 浏览器里面输入:chrome://inspect/#devices

    3. Remote Target 里面选择你的webview,然后点击下方的 inspect

    4. 在弹出的 DevTools 界面里面切换到Console 的tab,然后输入命令 window.navigator.userAgent,就可以得到类似下面的信息:

       "Mozilla/5.0 (Linux; Android 7.1.1; OS105 Build/NGI77B; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/66.0.3359.126 MQQBrowser/6.2 TBS/045118 Mobile Safari/537.36/  MnaVersion/3.0.0/4889/1/JSVersion/1.0.0/1"
      

      就可以看到Chrome内核的版本

    5. http://appium.io/docs/en/writing-running-appium/web/chromedriver/ 查看 Chrome 与 Chromedriver的对应关系然后前往 https://chromedriver.storage.googleapis.com/index.html 下载适合你的PC的与webview对应的Chromedriver版本。

  • 错误3:Unable to automate Chrome version because it is too old for this version of Chromedriver

    • 错误事例:

      selenium.common.exceptions.WebDriverException: Message: An unknown server-side error occurred while processing the command. Original error: Unable to automate Chrome version because it is too old for this version of Chromedriver. Chrome version on the device: Chrome/66.0.3359.126 Visit ‘https://github.com/appium/appium/blob/master/docs/en/writing-running-appium/web/chromedriver.md’ to troubleshoot the problem. A new session could not be created. Details: session not created: Chrome version must be between 71 and 75 (Driver info: chromedriver=2.46.628411 (3324f4c8be9ff2f70a05a30ebc72ffb013e1a71e),platform=Mac OS X 10.14.4 x86_64)

      • 解决方案:

        这个问题一般是因为没有无法找到适合你的 webview 的 Chromedriver引起的,或者自动下载,你手动下载的 Chromedriver 版本与你的webview无法对应引起的,解决方案参考错误2。

  • 错误4:Failed to get sockets matching: @webview_devtools_remote_.*15531 (make sure the app has its WebView configured for debugging)

    • 错误事例:

      repr(e): WebDriverException(‘An unknown server-side error occurred while processing the command. Original error: An unknown server-side error occurred while processing the command. Original error: unknown error: Failed to get sockets matching: @webview_devtools_remote_.*15531\n (make sure the app has its WebView configured for debugging)\n (Driver info: chromedriver=2.40.565386 (45a059dc425e08165f9a10324bd1380cc13ca363),platform=Mac OS X 10.15.1 x86_64)’, None, None)

    • 解决方案:

      这个问题可能是因为你的webview是独立进程的,导致无法获取,只需要在 chromeOptions 添加 androidProcess 即可,例如:

        desired_caps={}
        desired_caps['platformName']= "Android"
        desired_caps['deviceName']= uuid
        desired_caps["chromeOptions"] = {
            "androidProcess":"com.bihe0832.readhub:web",
            "androidPackage":"com.bihe0832.readhub"
        }
        desired_caps["chromedriverExecutableDir"] = "./appium"
        driver=webdriver.Remote('http://127.0.0.1:'+str(port)+'/wd/hub',desired_caps)
      
  • 错误5: Original error: Could not find a connected Android device

    • 错误事例:

      selenium.common.exceptions.WebDriverException: Message: An unknown server-side error occurred while processing the command. Original error: Could not find a connected Android device.

    • 解决方案:

      这个问题可能是因为你的webview是独立进程的,导致无法获取,只需要在 chromeOptions 添加 androidPackage 即可,添加方法可以参考错误4


赞赏

取消
微信扫一扫,赞赏子勰
扫码支持
屌丝程序猿,鸡血攻城狮!努力学技术,潜心做精品!