【Mac + Appium + Python3.6学习(二)】之Android自动化测试,appium-desktop配置和简易自动化测试脚本...-程序员宅基地

技术标签: python  测试  移动开发  

上一篇文章介绍安装appium测试环境,这一片研究介绍如何测试Android自动化。

上一篇地址:《【Mac + Appium学习(一)】之安装Appium环境

 这一篇参考:《Mac 下 appium 自动化测试 Android 测试配置和脚本编写(四)

配置环境:

  • Appium version :1.9.1
  • Appium-desktop:后改为1.7.1
  • Android:6.0.1
  • Mac:10.13.6

一、appium-desktop配置连接Android真机

1、开启appium服务

 

如果报错:参考上一篇解决办法(第二节第6小点)

2、配置连接真机的参数

 参数配置如下: 参考《Mac 下 appium 自动化测试 Android 测试配置和脚本编写(四)

其中,appPackage、appActivity如何获取呢(有坑):

参考:《获取app的 appPackage和appActivity

输入如下:

$ adb shell
shell@R9s:/ $ dumpsys activity | grep mFocusedActivity
  mFocusedActivity: ActivityRecord{f8dacd9 u0 cn.sqm.citymine_safety/.LoginActivity(这块有问题,见下面) t64}

其中:cn.sqm.citymine_safety/.LoginActivity是我们需要的

可以点击【Save As】进行保存

 

然后点击【Start Session】按钮。

但是报错:An unknown server-side error occurred while processing the command. Original error: Error occured while starting App. Original error: Permission to start activity denied.

经查询得知是:appActivity这块的问题

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

解决如下,命令行输入:

adb shell dumpsys activity activities >/Users/xxx/Desktop/activity.txt

打开文档,如下:

 

3、检查器

修改后再一次运行,会打开The Inspector:

检查器是应用程序状态的可视化表示具有在应用程序中执行某些交互的能力Appium。 

 

 

4、解决每次启动时都安装setting和unlock app方法

但是有一个问题是,以后每次启动都要安装setting和unlock app,为了解决,如下:

关掉appium setting 和unlock自动安装的方法*

==========================================================

下面两个因为不是在appium-desktop下修改的,所以对本文不适。

 

①《MacBook Appium 禁止每次运行都会启动appium setting 、appium unlock

 

②《appium解决每次运行都需要安装Unlock以及AppiumSetting的问题

==========================================================

 

1)首先修改...lib/android-helpers.js文件

从网上找了很多修改的方法但是统一都在appium下的android-helpers.js修改,屡试不爽,经过查询得知应该在appium-desktop下修改,可能是因为我用的是这个软件吧:

它的路径为:

# 修改android-helpers.js
open
/Applications/Project/Appium1.7.1.app/Contents/Resources/app/node_modules/appium/node_modules/appium-android-driver/lib

打开android-helpers.js文件

 ①搜索下面代码后注释掉:328行
await adb.install(unicodeIMEPath, false);

如图:

②接着注释掉下面两行代码:469、472行
await helpers.pushSettingsApp(adb);

await helpers.pushUnlock(adb); 

这个文件就算改完了,保存并退出。

2)其次修改.../build/lib/android-helpers.js文件

# 修改android-helpers.js
open /Applications/Project/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-android-driver/build/lib/

①注释掉代码并在下一行添加一行代码:892、893行
// return _regeneratorRuntime.awrap(adb.install(_appiumAndroidIme.path, false));
return context$1$0.abrupt('return',defaultIME);

 ②接着注释下面并添加一行:1287、1288行;1297、1298行
// return _regeneratorRuntime.awrap(helpers.pushSettingsApp(adb));
return context$1$0.abrupt('return',defaultIME);

// return _regeneratorRuntime.awrap(helpers.pushUnlock(adb));
return context$1$0.abrupt('return',defaultIME);

ok,保存并且退出。重启appium-desktop即可。不会再无休止地让你安装Unlock和AppiumSetting了。

二、 Android自动化py脚本编写

写一下简易的代码如下:

desired_capabilities.py

def get_desired_capabilities():
    desired_caps = {
        "platformName": "Android",
        "platformVersion": "6.0.1",
        "deviceName": "OPPO",
        "appPackage": "cn.sqm.citymine_safety",
        "appActivity": ".activity.LauncherActivity",
        "udid": "608ad0fe"
    }
    return desired_caps

def get_uri():
    return 'http://localhost:4723/wd/hub'

test.py

from appium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import  expected_conditions as EC
import unittest
import time
from time import sleep
import Mine.Appium.desired_capabilities as desired_capabilities
from selenium.webdriver.common.by import By



class AndroidTest(unittest.TestCase):


    @classmethod
    def setUpClass(self):
        desired_cap = desired_capabilities.get_desired_capabilities()
        uri = desired_capabilities.get_uri()
        self.d = webdriver.Remote(uri,desired_cap)


    @classmethod
    def tearDownClass(self):
        sleep(10)
        self.driver.quit()
        pass


    def setUp(self):
        print("=======start!=======")
        sleep(5)
        size = self.d.get_window_size()
        print(size)
        # 输入用户名
        userName = self.d.find_element(By.ID,"cn.sqm.citymine_safety:id/et_login_id")
        userName.send_keys("xxx")
        # 输入密码
        password = self.d.find_element(By.ID,"cn.sqm.citymine_safety:id/et_login_password")
        password.send_keys("xxx")
        # 登录密码
        button = self.d.find_element(By.ID,"cn.sqm.citymine_safety:id/btn_login")
        button.click()


    def tearDown(self):
        print("=======stop!=======")


    def test1(self):
        print("测试开始!")
        # 发起任务
        self.d.find_element_by_id("cn.sqm.citymine_safety:id/rl_add_task").click()
        # 任务类型
        self.d.find_element_by_id("cn.sqm.citymine_safety:id/tv_select_task_type").click()
        self.d.swipe(534, 1630, 534, 1583, 500)
        # 向上拖动
        self.d.swipe(500, 1270, 500, 500, 500)


        # 获取值
        text = self.d.find_element_by_id("cn.sqm.citymine_safety:id/tv_get_location").text
        self.assertEqual(text,"公园1","定位不对!")


if __name__=='__main__':
    unittest.main()

 

但是报错:

selenium.common.exceptions.WebDriverException: Message: Parameters were incorrect. We wanted {"required":["value"]} and you sent ["text","value","id","sessionId"]

解决参考如下:

appium+webdriveragent+Python+真机/模拟器 app自动化测试

找到原因是selenium版本的问题,把selenium版本降到3.0.1 就可以了,执行命令如下:

# 查看命令:
pip show selenium //查看当前包的版本信息

# 卸载命令:
pip uninstall selenium //卸载当前安装的包

# 安装命令:
pip install selenium==3.0.1 //指定版本号安装

# 查看命令:
pip show selenium //查看当前包的版本信息

但是再一次执行appium程序时又遇到如下报错:

ImportError: cannot import name 'InvalidArgumentException'

参考解决如下:《执行appium程序时遇到如下报错,ImportError: cannot import name 'InvalidArgumentException'

在此路径下的exceptions.py文件中添加一段代码:

/Users/xxx/.pyenv/versions/3.6.1/lib/python3.6/site-packages/selenium/common/exceptions.py

class InvalidArgumentException(WebDriverException):
    """
    """
    pass

再一次运行appium程序,自动化运行成功!!!! 

 

转载于:https://www.cnblogs.com/Owen-ET/p/9945164.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_30699831/article/details/95517276

智能推荐

TensorFlow安装过程问题汇总_loading channels: failed-程序员宅基地

文章浏览阅读1.6k次。1. 问题: conda search numpy 以及 conda search --full-name python 失败。失败的现象:Loading channels: failedCondaHTTPError: HTTP 404 NOT FOUND for url <http://pypi.douban.com/simple/noarch/repodata.json>..._loading channels: failed

pip install sklearn安装成功后,提示ModuleNotFoundError: No module named ‘sklearn‘错误解决办法_pip sklearn库安装成功但是报错-程序员宅基地

文章浏览阅读6.5k次,点赞10次,收藏16次。pip install sklearn安装成功后,提示ModuleNotFoundError: No module named 'sklearn'错误解决办法_pip sklearn库安装成功但是报错

玩转传感器——DHT11温湿度传感器(STM32版)_温湿度传感器接线图-程序员宅基地

文章浏览阅读7.4w次,点赞327次,收藏2.3k次。玩转传感器——DHT11温湿度传感器(STM32版)文章目录玩转传感器——DHT11温湿度传感器(STM32版)前言一、接口说明1 接线图2 电源引脚3 串行接口(单线双向)二、通信过程三、测量分辨率与电气特性四、使用注意事项1 工作与贮存条件2 暴露在化学物质中3 恢复处理4 温度影响5 光线6 配线注意事项五、DHT11驱动程序1 DHT11.c1.1 配置输入输出GPIO1.2 复位DHT111.3 检查DHT11是否正常1.4 DHT11初始化1.5 读取一位数据(返回值0/1)1.6 读取一个_温湿度传感器接线图

如何把自己的驱动编译进内核或模块(Kconfig和Makefile)_nvp6324 驱动-程序员宅基地

文章浏览阅读905次。本说明以NVP6324为例。1、首先在drivers\media\i2c中修改Kconfig和Makefile,如下: 在Kconfig中添加如下:config VIDEO_NVP6324 tristate "NVP6324 AHD sensor support" depends on I2C ---help--- This is a V4L2 sensor-le..._nvp6324 驱动

自适应直方图均衡(CLAHE) 代码及详细注释【OpenCV】_自适应双平台直方图均衡算法代码-程序员宅基地

文章浏览阅读2.7w次,点赞9次,收藏80次。理论请参考博客OpenCV源码的本地路径: %OPENCV%\opencv\sources\modules\imgproc\src\clahe.cppclahe.cpp// ----------------------------------------------------------------------// CLAHEnamespace{ class C_自适应双平台直方图均衡算法代码

计算机视觉及其图像处理操作-程序员宅基地

文章浏览阅读3.1k次,点赞3次,收藏22次。点击上方“小白学视觉”,选择加"星标"或“置顶”重磅干货,第一时间送达作者丨吃猫的鱼python @CSDN编辑丨3D视觉开发者社区目录content一、什么是计算机视觉二、图片处理基础操作图片处理:读入图像图片处理:显示图像图片处理:图像保存三、图像处理入门基础图像成像原理介绍图像分类四、像素处理操作读取像素修改像素使用python中的numpy修改像素点五、获取图像属性形状像素数目图像类型六..._计算机视觉与图像处理

随便推点

JavaScript——leetcode剑指 Offer 36. 二叉搜索树与双向链表_leetcode 链表的head是什么js-程序员宅基地

文章浏览阅读157次。题目描述输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的循环双向链表。要求不能创建任何新的节点,只能调整树中节点指针的指向。为了让您更好地理解问题,以下面的二叉搜索树为例:我们希望将这个二叉搜索树转化为双向循环链表。链表中的每个节点都有一个前驱和后继指针。对于双向循环链表,第一个节点的前驱是最后一个节点,最后一个节点的后继是第一个节点。下图展示了上面的二叉搜索树转化成的链表。“head” 表示指向链表中有最小元素的节点。特别地,我们希望可以就地完成转换操作。当转化完成以后,树中节点的左指针需_leetcode 链表的head是什么js

一篇文章让你全面了解TDengine-程序员宅基地

文章浏览阅读1.5w次,点赞3次,收藏46次。一篇文章让你全面了解TDengine本文将从以下几个方面全面介绍TDengine。TDengine的基本介绍TDengine的发展历程TDengine的优势TDengine的适用场景TDengine的写入存储策略TDengine的特点TDengine的基本介绍一句话了解TDengineTDengine是一个高效的存储、查询、分析时序大数据的平台,专为物联网、车联网、工业互联网、运维监测等优化而设计。你可以像使用关系型数据库MySQL一样来使用它,简单又方便。为什么会有TDengin_tdengine

成为JavaGC专家Part II:如何监控Java垃圾回收机制-程序员宅基地

文章浏览阅读215次。 成为JavaGC专家Part II :如何监控Java垃圾回收机制 本文是成为Java GC专家系列文章的第二篇。在第一篇《深入浅出Java垃圾回收机制》中我们学习了不同GC算法的执行过程,GC是如何工作的,什么是新生代和老年代,你应该了解的JDK7中的5种GC类型,以及这5种类型对于应用性能的影响。 在本文中,我将解释JVM到底是如何执行垃圾回收处理..._成为javagc专家part ii — 如何监控java垃圾回收机制。

python学习导航线_python点线导航-程序员宅基地

文章浏览阅读122次。文章目录python学习导航线一、seleniumpython-selenium二、python基础知识python的聊天室python学习导航线一、seleniumpython-selenium二、python基础知识python的聊天室_python点线导航

静态成员-静态成员变量-程序员宅基地

文章浏览阅读3.4k次,点赞4次,收藏22次。静态成员静态成员都是用static修饰,它的特点是不论创建多少个对象,程序都只创建一个静态成员。最主要的特点:共享什么是共享呢?例如:统计超市中所有商品数量的总和,商品数量的总和是随着每一个数量的变化而变化的,这是我们就可以用静态成员处理。(代码下面有写)静态成员又分为静态成员变量和静态成员函数。(一)静态成员变量特点:1、所有对象共享一份数据。 2、在编译阶段分配内存。 3、类内声明,类外初始化。#include<io..._静态成员变量

HTML5七夕情人节表白网页制作【情人节满屏爱心HTML5特效】HTML+CSS+JavaScript html生日快乐祝福网页制作_html 满屏爱心-程序员宅基地

文章浏览阅读879次,点赞21次,收藏20次。1 网页简介:基于HTML+CSS+JavaScript 制作七夕情人节表白网页、生日祝福、七夕告白、 求婚、浪漫爱情3D相册、炫酷代码,快来制作一款高端的表白网页送(他/她)浪漫的告白,制作修改简单,可自行更换背景音乐,文字和图片即可使用等任意html编辑软件进行运行及修改编辑等操作)。_html 满屏爱心

推荐文章

热门文章

相关标签