一、Appium入门案例

  1. demo

    from appium import webdriver
    from time import sleep # server 启用参数
    desired_caps = {} # 设备信息
    desired_caps['platformName'] = 'Android' # 设备名称
    desired_caps['platformVersion'] = '7.1.2' # 设备版本
    desired_caps['deviceName'] = '127.0.0.1:62001' # 设备号 # app信息
    desired_caps['appPackage'] = 'com.android.settings' # 应用包名
    desired_caps['appActivity'] = '.Settings' # 启动的activity desired_caps["automationName"] = 'UiAutomator1' # 解决新版appium报错 driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
    sleep(3)
    # 关闭app driver对象不会关闭
    driver.close_app() sleep(3)
    # 关闭驱动对象
    driver.quit()
    1. 常用参数
    platformName 平台的名称:iOS, Android, or FirefoxOS
    platformVersion 设备系统版本号
    deviceName 设备号 IOS:instruments -s devices,Android: adb devices
    app 安装文件路径:/abs/path/to/my.apk or http://myapp.com/app
    appActivity 启动的Activity
    appPackage 启动的包
    unicodeKeyboard unicode设置(允许中文输入)
    resetKeyboard 键盘设置(允许中文输入)

二、App操作API

  1. 安装apk到手机中

    import os
    
    from appium import webdriver
    from time import sleep # server 启用参数
    desired = {
    # 设备信息
    'platformName': 'Android', # 设备名称
    'platformVersion': '7.1.2', # 设备版本
    'deviceName': '127.0.0.1:62001', # 设备号
    # app信息
    'appPackage': 'com.android.settings', # 应用包名
    'appActivity': '.Settings', # 启动的activity
    # 解决新版appium报错
    'automationName': 'UiAutomator1'
    } driver = webdriver.Remote('http://localhost:4723/wd/hub', desired)
    sleep(3)
    # 下载apk
    driver.install_app(os.getcwd() + os.sep + "jisuanqi.apk")
    sleep(3)
    # 关闭app driver对象不会关闭
    driver.close_app() sleep(3)
    # 关闭驱动对象
    driver.quit()
    • 说明:

      driver.install_app(app_path)

      参数:app_path:APK文件所在路径

    1. 从手机中卸载apk
    import os
    
    from appium import webdriver
    from time import sleep # server 启用参数
    desired = {
    # 设备信息
    'platformName': 'Android', # 设备名称
    'platformVersion': '7.1.2', # 设备版本
    'deviceName': '127.0.0.1:62001', # 设备号
    # app信息
    'appPackage': 'com.youba.calculate', # 应用包名
    'appActivity': '.MainActivity', # 启动的activity
    # 解决新版appium报错
    'automationName': 'UiAutomator1'
    } driver = webdriver.Remote('http://localhost:4723/wd/hub', desired)
    sleep(3)
    # 卸载apk
    driver.remove_app("com.youba.calculate")
    sleep(3)
    # 关闭app driver对象不会关闭
    driver.close_app()
    # 关闭驱动对象
    driver.quit()
    • 说明:

      driver.remove_app(app_id)

      参数:app_id:需要卸载的app包名

    1. 判断APP是否有安装
    import os
    
    from appium import webdriver
    from time import sleep # server 启用参数
    desired = {
    # 设备信息
    'platformName': 'Android', # 设备名称
    'platformVersion': '7.1.2', # 设备版本
    'deviceName': '127.0.0.1:62001', # 设备号
    # app信息
    'appPackage': 'com.android.settings', # 应用包名
    'appActivity': '.Settings', # 启动的activity
    # 解决新版appium报错
    'automationName': 'UiAutomator1'
    } driver = webdriver.Remote('http://localhost:4723/wd/hub', desired)
    sleep(3)
    result = driver.is_app_installed("com.youba.calculate")
    print(result)
    # 判断是否有com.youba.calculate该apk,有就删除 True,没有就下载 False
    if result:
    driver.remove_app("com.youba.calculate")
    else:
    driver.install_app(os.getcwd() + os.sep + "jisuanqi.apk")
    sleep(3)
    # 关闭app driver对象不会关闭
    driver.close_app()
    # 关闭驱动对象
    driver.quit()
    • 说明:

      driver.is_app_installed(bundle_id)

      参数:bundle_id: 可以传入app包名,返回结果为True(已安装) / False(未安装)

APP测试(appium+Python基础操作)一的更多相关文章

  1. python基础操作以及hdfs操作

    目录 前言 基础操作 hdfs操作 总结 一.前言        作为一个全栈工程师,必须要熟练掌握各种语言...HelloWorld.最近就被"逼着"走向了python开发之路, ...

  2. app自动化测试Appium+python

    一.node.js安装 https://nodejs.org/en/download/ ##一直下一步 ###cmd查看 二.  .NET Framework安装 https://www.micros ...

  3. Python菜鸟之路:Python基础-操作缓存memcache、redis

    一.搭建memcached和redis 略,自己去百度吧 二.操作Mmecached 1. 安装API python -m pip install python-memcached 2. 启动memc ...

  4. python学习之路-1 python基础操作

    本篇所涉及的内容 变量 常量 字符编码 用户交互input 格式化字符串 python的缩进规则 注释 初始模块 条件判断 循环 变量 变量的概念基本上和初中代数的方程变量是一致的,只是在计算机程序中 ...

  5. Python基础操作-集合

    在Python set是基本数据类型的一种集合类型,它有可变集合(set())和不可变集合(frozenset)两种.创建集合set.集合set添加.集合删除.交集.并集.差集的操作都是非常实用的方法 ...

  6. python基础操作以及变量运用

    今天学习关于pycharm的操作以及变量的知识 1.关于pycharm的基本操作,作为一个小白,仪式感还是要有 在基础界面上新建然后打印hello world,也是对python的一种尊重吧 2.关于 ...

  7. python基础操作

    1.打印操作 print('2222') 2.接收用户输入 name=input('name') 3.if else判断 name='qiao'name2='师弟'username=input('输入 ...

  8. python 基础操作--数据类型

    一.变量 1.定义:将运算的中间结果暂存到内存,以便后续程序调用. 2.命名规则 1.变量由字母.数字.下划线搭配组合而成: 2.不可以用数字开头,也不能全都是数字: 3.不能是python 关键字, ...

  9. Appium + python - TouchAction操作

    from appium import webdriverfrom appium.webdriver.common.touch_action import TouchActionfrom appium. ...

随机推荐

  1. 敏捷史话(十五):我发明了敏捷估算扑克牌 —— James Greening

    雪鸟会议 雪鸟会议前夕,James Grenning 在 Object Mentor 与 Robert C. Martin 一同工作,彼时组织雪鸟会议的 Bob 大叔盛情邀请 James,告知他会议的 ...

  2. 如何识别自己基因组数据是哪个全基因组参考版本(Genome Reference Versions/ Genome Build)

    首先在这里先感谢我们[Bio生信学习交流群]的群友和创建此群的群主[陈博士后]. 今天解决的问题是怎么查看自己的基因组数据是哪个Genome Reference Versions. 步骤: 第一步,打 ...

  3. JDBC_15_悲观锁和乐观锁

    悲观锁和乐观锁 并发控制 当程序中可能出现并发操作的情况时,就需要保证在并发操作的情况下数据的准确性,以此确保当前用户和其他用户一起操作时,所得到的结果和某个用户单独操作时的结果是一样的.这种手段就叫 ...

  4. 使用docker快速安装软件

    安装mysql mkdir /opt/mysql /opt/mysql/etc /opt/mysql/data docker run -itd --name mariadb -e MYSQL_ROOT ...

  5. 探索使用 Golang 和 Webassembly 构建一个多人游戏服务器

    什么是 WebAssembly?由 Google.Microsoft.Mozilla.Apple 等发起的 WebAssembly 是一种新的字节码格式,主流浏览器都已经支持 WebAssembly. ...

  6. dot 语法总结

    在使用pprof分析go的项目时,经常会查看各项指标的有向图 原理是使用Graphviz(Graph Visualization Software)解析生成的dot脚本得到最终展示给我们的图信息. d ...

  7. 01- APP移动端测试怎么测试?APP测试方法大全。

    由于智能手机时代来临,很多产品都有了APP,作为一个测试人员掌握APP测试是必要的. 在展开APP测试之前,首先了解一下几个点: 1.基于软件测试框架之上.复习下软件测试框架. 2.框架的内容贯穿于A ...

  8. 【新手/零基础】Hexo+Gitee个人博客搭建教程--详细版

    前言 点此转到--精简版 可能很多小伙伴都有搭建一个属于自己的博客的想法.但是经常是无奈于自己匮乏的知识.但是,每个老手都是新手过来的,再困难的事情,只要肯花一点时间都可以办成. 本次教程分为详细版和 ...

  9. php图片合成【png图片】

    php 图片合成[png图片] 示例代码 <?php header("Content-type:text/html;charset=utf-8"); error_report ...

  10. vue2整个项目中,数据请求显示loading图----------未完成阅读,码

    一般项目中,有时候会要求,你在数据请求的时候显示一张gif图片,然后数据加载完后,消失.这个,一般只需要在封装的axios中写入js事件即可.当然,我们首先需要在app.vue中,加入此图片.如下: ...