• UID5201
  • 登录2017-10-18
  • 粉丝2
  • 关注0
  • 发帖57
  • 主页
  • 金币285枚
Ifyou 发布于2017-09-05 16:49
0/282

在金融APP做自动化这条路上,我们填过哪些坑?

楼层直达


从市场上金融企业对app的重视程度,自然看出其在市场、用户和企业眼中的重要性。甚至有测试部门要求拿着圆规比对icon圆是不是正圆,拿着尺子去量icon尺寸是不是正确!软件质量要求最高的的金融行业,在对待app自动化这件事自然是走在业内前列。
而当前金融行业app做自动化的问题已经不是是否用UI自动化的方式,也不是说是录制、回放还是写脚本的方式。答案很明显:app最注重用户体验,自然要做UI自动化,不能让测试人员写脚本。写脚本对测试人员要求极高,也增加了企业成本。
世人眼中的UI自动化
手工测试人员:UI自动化实现了,测试就可以不用测了自动工程师:最大的难点是维护成本极高,验证功能而非UI,能获得多少收益关键看被测系统本身的稳定性以及自动化技术能力


今天就来说说,为了达到一定高的自动化率,我们都遇到过哪些坑。
 
在做app自动化过程中,有两大通用性问题不可回避;
 
1、屏幕分辨率和系统差异
 
业内人士一定知道,做app的自动化一定不能依靠坐标,最多作为辅助手段。图像识别也被人诟病,极客们通常是从入门到放弃。原因是大家用的开源算法,或许做了点优化,但仍然不能适应多样化的app以及app版本的迭代。
 
示例:采用坐标点击方式不能适配不同机型

图片:图片 1.png


 
因此这种方式必不可取。
 
2、iOS&Android两套完全不同的系统
 
用例几乎不分两套系统,可是这两套系统却决定了自动化脚本必须是两套。
 

图片:QQ20170904-160733@2x.png


 
对金融企业科技部来讲,要自研这两套系统的app自动化系统,投入太大时间太久,更不用说操作系统升级后的更新(要知道乔爸爸血统一次更新可能就是换血)。
 
 
第一大类:影响自动化执行(操作)准确性
 
H5技术运用越来越多
 
H5技术的诞生,给开发者带来了福音,却给自动化开发者带来了强烈的冲击。许多原本已经做好app自动化框架大公司也不得重新考虑。而不管选择哪种机制都必然会遇到一些意外:
 
采用非原生webview控件
 
为了使产品更加完美,开发人员使用了各种非原生的webview控件,示例:这是开发人员在页面设计时调用了腾讯X5的内核浏览器,就无法用统一的技术获取到页面layout
 

图片:QQ20170904-160805@2x.png



 
诸如此类的问题还有很多,H5layout获取不到、不准确,都将导致自动化执行失败和预期结果检查出错。
 
键盘加密、验证码获取
 
乱序加密键盘

图片:图片 2.png


 
这是金融行业最一致的问题,为了让每用例脚本互不影响,初始状态都从登录开始。这些乱序加密键盘不可能获取到layout,那必须采用特定算法精确找到数字区域并自动点击。
 
手势密码
 
还有银行通常使用的手势密码
 
验证码获取
 
部分金融企业采用了验证码方式:正常验证码、艺术验证码
 
都需要用特定技术手段获取到准确的验证码内容,同时自动化工具有灵活机制实时填入。
 
3、日期控件,不同系统版本、不同手机厂商、不同app开发团队
 
不管是银行还是证券,对历史记录的查询是不可缺少的测试案例。例如测试前几年某个月的记录,那就需要滑动、点击很多次。这就导致执行准确度低、用例执行效率低。
 
这需要定制化研发一整套(两套系统,多个版本,多种机型)日期自动化设置小工具,才能实现这些用例的自动化。
 
 
第二大类:阻塞结果校验正确行
 
提取控件部分内容
 
示例:如图所示的alert内容,需要提取作为预期结果检查,但合同号“5”是变化的。则只能检查您的申请已提交,合同号为:“5”则要单独提取作为查询的索引。
 
安卓提示采用Toast机制
 
toast提示难以抓取,就无法从APP端验证流程正确性。这是评价app自动化工具强大的一个标准。
 
特殊计算
 
示例:需要计算持仓1/41/3的整数份。例如:持仓800股(每手为100股),卖出1/3,则卖出数量为:800/3(取整)=200股(2手)。
 
如何有效应对版本更新带来的批量脚本更新问题

 
以上问题都建立在app的页面layout信息不变的情况,而实际上是可能变化的,即使是以稳定为主的金融企业,也会因为创新业务需求,改变页面设计。这就导致一个问题,现在已有大量的测试脚本,这种基于layout的录制方式,页面设计改动后,如何高效更新大量的测试脚本,让自动测试真正的快起来?
 
 
TestBird眼中的UI自动化(轻量、简单、高效率)
 
不写脚本
用例的自动化率达到一定高的程度才能获得收益
维护成本一定要降低到可接受范围
app的自动化是适配多终端、多系统的

0人打赏
您需要登录后才可以回帖
发表回复
极贡献
技术问答
专题荟萃
程序人生
视觉设计
Android开发
iOS开发
编程语言
前端开发
后端开发
服务器架构
软件测试
运维方案
创业路上



最热文章墙

  • 84780/384   【精品推荐】200多种Android动画效果的强悍框架,太全了,不看这个,再有动画的问题,不理你了^@^

  • 48500/191   情人节福利,程序员表白的正确姿势:改几行代码就变成自己的表白了

  • 47029/0   Python爬虫:常用浏览器的useragent

  • 44164/261   【精品推荐】Android版产品级的音乐播放器源码,功能太强大了,最好的产品原型有木有?

  • 40542/145   省时省力的Android组件群来了,非常棒的原型参考

  • 32202/143   2016抢红包软件及源码

  • 30509/71   原创表白APP,以程序员的姿势备战新年后的7夕,持续完善中!

  • 29823/2   超全!整理常用的iOS第三方资源

  • 26284/161   Android版类似UC浏览器:非常赞,产品级的源码

  • 23636/31   麻省理工的一帮疯子,真的实现了随意操控万物!(绝对黑科技)

  • 23404/27   2016程序员跳槽全攻略

  • 23376/26   Android工程师面试题大全

  • 22492/10   GitHub上排名前50的iOS项目:总有一款你用得着

  • 21609/21   码魂:程序员的牛B漫画

  • 20296/74   【持续更新中】Android福利贴(二):资料源码大放送

  • 20065/85   Android小而全的博客源码:非常适合全面掌握开发技巧

  • 19923/43   一个绚丽的loading动效分析与实现!

  • 19442/10   2016年最全的Android面试考题+答案 精编版

  • 19343/3   吐槽那些程序员的搞笑牛逼注释

  • 18897/104   Android带弹幕的视频播放器源码,来自大名鼎鼎的Bilibili弹幕网站

  • 18629/45   惊艳的App引导页:背景图片切换加各个页面动画效果

  • 18591/82   仿京东商城客户端Android最新版,不错的原型和学习资料

  • 18134/1   iOS 动画总结

  • 18027/25   个人收集的Android 各类功能源代码

  • 17801/23   Android福利第三波【Android电子书】

  • 17620/81   【精品推荐】类似360安全卫士安Android源码:非常赞的产品原型

  • 17518/1   iOS中文版资源库,非常全

  • 17509/5   新一代Android渠道打包工具:1000个渠道包只需要5秒

  • 17359/54   基于瀑布流的美女图片浏览App,有注释的源代码

  • 17071/18   用JavaScript 来开发iOS和Android 原生应用:React Native开源框架中文版来啦

  • 16843/10   女程序员的梦,众网友的神回复

  • 16822/23   珍藏多年的素材,灵感搜寻网站

  • 16689/19   65条最常用正则表达式,你要的都在这里了

  • 16682/11   年会上现场review代码是怎么样的体验!

  • 15422/16   基于Android支付宝支付设计和开发方案

  • 15062/18   什么是真正的黑客:收获12200+Stars,人气远超微软开源VS

  • 14922/11   有木有这样一张酷图帮你集齐所有git命令超实用

  • 14903/62   【技巧一】搭配Android Studio,如何实现App远程真机debug?

  • 14845/4   46 个非常有用的 PHP 代码片段

  • 14811/47   在线音乐播放器完整版(商用级的源码):非常赞,可听免费高品质专辑

  • 14201/0   GitHub iOS 库和框架Top100 

  • 14038/7   用程序员的姿势抢过年的火车票

  • 14003/7   一张图搞定iOS学习路线,非常全面

  • 13642/10   成为Java顶尖程序员 ,看这11本书就够了

  • 13609/10   微信支付终于成功了(安卓,iOS),在此分享

  • 13512/18   一张图搞定Android学习路线,非常全面

  • 13475/29   【持续更新中】Android福利贴(一):资料源码

  • 13279/4   基于Node.js的强大爬虫,能直接发布抓取的文章哦

  • 12524/3   即时通信第三方库

  • 12497/1   基于node-webkit跨平台应用案例集之(一)

  • 12024/9   流媒体视频直播方案

  • 11994/18   八个最优秀的Android Studio插件

  • 11769/9   B站建开源工作组:APP想支持炫酷弹幕的看过来

  • 11757/2   【精品推荐】高质量PHP代码的50个实用技巧:非常值得收藏

  • 11473/9   烧了5亿美金,这家神秘的公司即将颠覆人类未来!

  • 11431/12   中国黑客的隐秘江湖:攻守对立,顶尖高手月入千万美元

  • 10915/0   过上惬意生活的精华资源:创业、工作、生活成长

  • 10693/6   开箱即用!Android四款系统架构工具

  • 10593/2   Android性能优化视频,文档以及工具

  • 10486/4   10款GitHub上最火爆的国产开源项目——可以媲美西半球

  • 返回顶部