说到移动APP自动化测试,代表性的测试框架非Appium莫属,从今天开始我们将从APP结构解析、Appium框架学习、安卓/iOS自动化测试实战、自动遍历回归测试、自动化测试平台及持续集成,多个维度一起由浅入深的学废Appium
今天我们先来初步认识Appium,以及移动APP的UI自动化应该怎么设计更合理
1、Appium设计理念
Appium是开源的、由WebdriverAgent、espresso、UI automator2 多个服务集成的框架,驱动各端完成自动化测试
Appium支持多语言:python java nodejs,一门语言就可以完成多端测试工作
Appium支持跨平台:Android、iOS、windows、mac
Appium支持底层多引擎可切换,比如iOS的:KIF、WDA、XCTest;Android的: robotium、ui automator
你的客户端可以发送HTTP请求告诉Appium你想为什么样的程序提供自动化,并帮我点击某个按钮,实现断言
2、Appium底层引擎列表
Android:主要的引擎是分为两个selendroid、Esresso 引擎: 这两个引擎可以完成更加底层的调用,比如调用底层SDK的APIUI automator2:用于支持跨APP测试、兼容性测试
IOS: XCUItest引擎UI automator:已经被Apple公司废弃XCUItest:Facbook的WDA(webdriverAgent)
3、Appium多端架构体系一览图
遍历工具 or 脚本,通过webdriver发起HTTP请求
appium 服务接收后, 通过上述所说的中间引擎去调用对应的Api 或 App
如果说测的是手机浏览器、小程序等,需要借助chrome driver、webview内核去调用
4、合理的使用UI自动化测试
UI自动化测试分为传统的基于测试用例的测试以及自动遍历测试基于测试用例的测试
价值:基于用例维护体系,核心、复杂的业务流程须交给基于用例维护的测试体系去维护、支持老功能的回归
缺点:会有用例维护成本、不能覆盖到新功能的探索,需重新写测试用例
自动遍历测试
定义:以自动化的方式对APP进行充分的功能遍历以探索bug
价值:降低自动化维护成本,覆盖兼容性、稳定性、性能、以及基本业务的断言一个APP差不多有50~60%是属于非常简单的浏览,数据展示等,完全可以交给自动化遍历去维护,同样支持基础老功能的回归
用途:多设备兼容测试、自动化专项测试
4、移动APP分层测试策略
单元测试:使用APP分层测试策略,增加单测规模,控制UI自动化测试规模
基于测试用例的测试:核心集成与验收测试 用例交给自动化测试
自动遍历测试:大部分的基础回归测试交给自动遍历
人工测试:测试团队主负责,整个产品团队参与
使用不同的测试方法 去解决产品中不同的测试诉求,通过安卓官方的测试指导和行业内已经成熟的测试技术,找到适合自己公司的一套测试手段,从而对公司的测试体系进行相关建设
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!