转:https://blog.csdn.net/Tigerdong1/article/details/80159156
前段时间用一种流行语言,一个主流工具,一个实用框架,写了一个美团app自动化测试的Demo,利用appium+python+unittest+uiautomatorviewer,编写了测试用例,并通过HTMLTestRunner输出测试报告。Appium环境搭建的过程就不说了(这种内容百度一搜一大把)。我是利用uiautomatorviewer进行元素定位的,当然如果比较简单也可以用appium-desktop自带功能的进行元素定位。下面是面向过程对美团APP进行自动化测试的一个Demo:from appium import webdriver
import time
desired_caps = {}
desired_caps['platformName'] = 'Android'
desired_caps['platformVersion'] = '4.4.2'
desired_caps['deviceName'] = '127.0.0.1:62001'
desired_caps['appPackage'] = 'com.sankuai.meituan'
desired_caps['appActivity'] = '.activity.MainActivity'
desired_caps['autoAcceptAlerts'] = 'True'   # 自动确认弹窗
desired_caps['unicodeKeyboard'] = 'True'    #处理无法输入中文的问题,使用unicodeKeyboard的编码方式来发送字符串
desired_caps['resetKeyboard'] = 'True'      #将键盘给隐藏起来
d = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
time.sleep(3)               # app启动后等待3秒,方便元素加载完成
d.find_element_by_id('com.sankuai.meituan:id/citylist_search').send_keys('深圳')
time.sleep(3)
d.find_element_by_id('com.sankuai.meituan:id/citylist_textview').click()
time.sleep(3)
d.tap([(75, 400)])
time.sleep(3)       # 临时取消弹框
d.tap([(0,270),(180,450)],500)
time.sleep(3)       # 定位元素美食,按住500毫秒
d.tap([(218,406)])  # 定位商家
time.sleep(2)
d.tap([(191,654)])  # 查看商品详情
time.sleep(2)
d.find_element_by_id("com.sankuai.meituan:id/buy").click()   #立即购买
d.find_element_by_id("com.sankuai.meituan:id/mobile").send_keys("15623512919")      # 输入手机号
d.find_element_by_id("com.sankuai.meituan:id/get_code").click()             # 获取验证码
#异常处理(解决有时候需要输入图片验证码,有时候又不需要输入的问题)
try:
    print('请输入图片验证码')
    picutrecode = input()
    d.find_element_by_id('com.sankuai.meituan:id/captcha').send_keys(picutrecode)
    d.find_element_by_class_name('android.widget.Button').click()
    time.sleep(5)
except:
    print('请输入短信验证码')
    code = input()
    d.find_element_by_id('com.sankuai.meituan:id/code').send_keys(code)
    d.find_element_by_id('com.sankuai.meituan:id/submit').click()
else:
    print('在输入图片验证码后,请再次输入短信验证码')
    code = input()
    d.find_element_by_id('com.sankuai.meituan:id/code').send_keys(code)
    d.find_element_by_id('com.sankuai.meituan:id/submit').click()
    print('程序运行正常')
    time.sleep(2)
# 通过查找不到元素从而报错来判断是否登录成功(相当于断言)
try:
    d.find_element_by_id('com.sankuai.meituan:id/submit').click()
    print('登录下单成功啦')
except:
    d.find_element_by_id('android:id/button1').click()
    print('登录失败啦')
d.get_screenshot_as_file(u'F:\自动化截图\美团.png')  #是否登录成功截图备注:第一个异常处理,主要是因为输入手机号后,点击获取验证码,可能会让你直接输入短信验证码,也可能需要你输入图片验证码后再次输入短信验证码,所以用了try-except-else来规避这个问题,当try下面语句报错(也就是不用输入图片验证码时),直接执行except中的内容(直接输入短信验证码),当try下面语句未报错时(也就是输入图片验证码后需要再次输入短信验证码时),try下面语句执行完后,继续执行else语句(输入短信验证码的过程)。因为try语句未报错时候,将不会执行except语句,所以需要加else语句。将面向过程的Demo封装成类与函数,如下所示:import  unittest
from appium import webdriver
from time import sleep
class MeituanTest(unittest.TestCase):
    #手机初始化进入APP
    def setUp(self):
        print('开始跑用例啦--setup')
        desired_caps = {}
        desired_caps['platformName'] = 'Android'
        desired_caps['platformVersion'] = '4.4.2'
        desired_caps['deviceName'] = '127.0.0.1:62001'
        desired_caps['appPackage'] = 'com.sankuai.meituan'
        desired_caps['appActivity'] = '.city.CityActivity'
        desired_caps['unicodeKeyboard'] = 'True'
        desired_caps['resetKeyboard'] = 'True'
        self.d = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
        sleep(3)
    #选择地区购买商品流程
    def test_goshopping(self):
        d = self.d
        d.find_element_by_id('com.sankuai.meituan:id/citylist_search').send_keys('深圳')
        sleep(3)
        d.find_element_by_id('com.sankuai.meituan:id/citylist_textview').click()
        sleep(3)
        d.tap([(75, 400)])
        sleep(3)  # 临时取消弹框
        d.tap([(0, 270), (180, 450)], 500)
        sleep(3)  # 定位元素美食,按住500毫秒
        d.tap([(218, 406)])  # 定位商家
        sleep(2)
        d.tap([(191, 654)])  # 查看商品详情
        sleep(2)
        d.find_element_by_id("com.sankuai.meituan:id/buy").click()  # 立即购买
        d.find_element_by_id("com.sankuai.meituan:id/mobile").send_keys("15623512919")  # 输入手机号
        d.find_element_by_id("com.sankuai.meituan:id/get_code").click()  # 获取验证码
        # 异常处理(解决有时候需要输入图片验证码,有时候又不需要输入的问题)
        try:
            print('请输入图片验证码')
            picutrecode = input()
            d.find_element_by_id('com.sankuai.meituan:id/captcha').send_keys(picutrecode)
            d.find_element_by_class_name('android.widget.Button').click()
            sleep(5)
        except:
            print('请输入短信验证码')
            code = input()
            d.find_element_by_id('com.sankuai.meituan:id/code').send_keys(code)
            d.find_element_by_id('com.sankuai.meituan:id/submit').click()
        else:
            print('在输入图片验证码后,请再次输入短信验证码')
            code = input()
            d.find_element_by_id('com.sankuai.meituan:id/code').send_keys(code)
            d.find_element_by_id('com.sankuai.meituan:id/submit').click()
            print('程序运行正常')
            sleep(2)
        # 通过查找不到元素从而报错来判断是否登录成功(相当于断言)# 是否登录成功校验
        try:
            d.find_element_by_id('com.sankuai.meituan:id/submit').click()
            print('登录下单成功啦')
        except:
            d.find_element_by_id('android:id/button1').click()
            print('登录失败啦')
        d.get_screenshot_as_file(u'F:\自动化截图\美团.png')  # 是否登录成功截图
    def tearDown(self):
        sleep(2)
        self.d.quit()
if __name__ == "__main__":
    unittest.main()接下来就是把编写好的测试用例执行,利用HTMLTestRunner生成测试报告:
import  unittest,time
from HTMLTestRunner import HTMLTestRunner
if __name__ == "__main__":
    test_dir = (r'F:\appiumtest')
    discover = unittest.defaultTestLoader.discover(test_dir,'*case.py')
    testReportDir = (r'F:\report')
    nowTime = time.strftime("%Y-%m-%d-%H_%M_%S",time.localtime())
    fileName = nowTime+".html"
    report_Name = testReportDir+fileName
    fp = open(report_Name,"wb")
    runner = HTMLTestRunner(stream=fp,title="美团自动化测试报告",description="测试结果")
    runner.run(discover)
    fp.close()备注:discover=...是匹配以case结尾的文件(也就是编写测试用例的文件)
---------------------
作者:Tigerdong1
来源:CSDN
原文:https://blog.csdn.net/Tigerdong1/article/details/80159156
版权声明:本文为博主原创文章,转载请附上博文链接!

基于Appium的APP自动化测试基础--美团APP的实例的更多相关文章

  1. 基于Appium的UI自动化测试

    为什么需要UI自动化测试 移动端APP是一个复杂的系统,不同功能之间耦合性很强,很难仅通过单元测试保障整体功能.UI测试是移动应用开发中重要的一环,但是执行速度较慢,有很多重复工作量,为了减少这些工作 ...

  2. 基于 appium 的 UI 自动化测试

    其中主要的目录和文件为: /MPTestCases ----------- 存放测试用例 /errorScreenShot ------------ 用例执行失败生成的错误截图 startTest.p ...

  3. 基于appium的app自动化测试框架

    基于appium框架的app自动化测试 App自动化测试主要难点在于环境的搭建,appium完全是基于selenium进行的扩展,所以app测试框架也是基于web测试框架开发的 一.设备连接 (即构建 ...

  4. Android Native App自动化测试实战讲解(上)(基于python)

    1.Native App自动化测试及Appuim框架介绍 android平台提供了一个基于java语言的测试框架uiautomator,它一个测试的Java库,包含了创建UI测试的各种API和执行自动 ...

  5. Android App自动化测试实战(基于Python)(三)

    1.Native App自动化测试及Appuim框架介绍 android平台提供了一个基于java语言的测试框架uiautomator,它一个测试的Java库,包含了创建UI测试的各种API和执行自动 ...

  6. Android Hybrid App自动化测试实战讲解(基于python)

    1.Hybrid App自动化测试概要 什么是Hybrid App? Hybrid App(混合模式移动应用)是指介于web-app.native-app这两者之间的app,兼具“Native App ...

  7. 基于UiAutomator2+PageObject模式开展APP自动化测试实战

    前言 在上一篇<APP自动化测试框架-UiAutomator2基础>中,重点介绍了uiautomator2的项目组成.运行原理.环境搭建及元素定位等基础入门知识,本篇将介绍如何基于uiau ...

  8. Windows下部署Appium教程(Android App自动化测试框架搭建)

    摘要: 1,appium是开源的移动端自动化测试框架: 2,appium可以测试原生的.混合的.以及移动端的web项目: 3,appium可以测试ios.android.firefox os: 4,a ...

  9. 篇4 安卓app自动化测试-Appium API进阶

    篇4                 安卓app自动化测试-Appium API进阶 --lamecho辣么丑 1.1概要 大家好! 我是lamecho(辣么丑),今天是<安卓app自动化测试& ...

随机推荐

  1. Python写业务逻辑的几个编码原则

    作为一个写业务逻辑的boy,我需要专注的就是把业务逻辑写好.写业务逻辑并不复杂,就是把编程最基础的东西使用好,有变量.循环.流程控制.函数.数据库等. 但是写出的逻辑要通俗易懂.易于理解,避免炫技.晦 ...

  2. android studio出现 Could not initialize class com.android.sdklib.repository.AndroidSdkHandler

    新的android studio  (4.2)已经不支持旧有的 com.android.tools.build:gradle:2.3.3 了,有些方法和类会找不到. 去build.gradle中把这个 ...

  3. 前端er必须掌握的数据可视化技术

    又是一月结束,打工人准时准点的汇报工作如期和大家见面啦.提到汇报,必不可少的一部分就是数据的汇总.分析. 作为一名合格的社会人,我们每天都在工作.生活.学习中和数字打交道.小到量化的工作内容,大到具体 ...

  4. Qt Creator 源码学习笔记04,多插件实现原理分析

    阅读本文大概需要 8 分钟 插件听上去很高大上,实际上就是一个个动态库,动态库在不同平台下后缀名不一样,比如在 Windows下以.dll结尾,Linux 下以.so结尾 开发插件其实就是开发一个动态 ...

  5. Mysql 主从复制机制

    https://blog.csdn.net/girlgolden/article/details/89226528 MySQL异步复制及semi-sync半同步复制,它们都基于MySQL binlog ...

  6. VS c/c++常用配置项

    VS2015 下面的配置,Vs是通用的 自己常用VS2015, 但其默认的一些设置不能满足我的日常. 比较熟悉c/c++, 以下配置仅适用c/c++ 设置方法: 工具-选项-文本编辑器-c/c++ 常 ...

  7. 【LeetCode】814. Binary Tree Pruning 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 后序遍历 日期 题目地址:https://leetc ...

  8. DevTools 实现原理与性能分析实战

    一.引言 从 2008 年 Google 释放出第一版的 Chrome 后,整个 Web 开发领域仿佛被注入了一股新鲜血液,渐渐打破了 IE 一家独大的时代.Chrome 和 Firefox 是 W3 ...

  9. Windows服务注册(需要指定config文件的情况下)

    最近,遇到一个问题:需要将telegraf在Win平台下注册为windows服务(避免误操作关闭CMD窗口): 尝试了网上的几种注册Windows服务的方法,发现无法将telegraf这种需要在CMD ...

  10. 【Java】质数判断

    static boolean isPrime(int n) { if(n<=1) { return false; } if(n==2||n==3) { return true; } if(n%6 ...