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

在金融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开发
编程语言
前端开发
后端开发
服务器架构
软件测试
运维方案
创业路上



最热文章墙

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

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

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

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

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

  • 30063/142   2016抢红包软件及源码

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

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

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

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

  • 22568/25   Android工程师面试题大全

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

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

  • 20912/20   码魂:程序员的牛B漫画

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

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

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

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

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

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

  • 17633/1   iOS 动画总结

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

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

  • 17150/23   个人收集的Android 各类功能源代码

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

  • 16619/21   Android福利第三波【Android电子书】

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

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

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

  • 16367/0   iOS中文版资源库,非常全

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

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

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

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

  • 14853/15   基于Android支付宝支付设计和开发方案

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

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

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

  • 13719/0   GitHub iOS 库和框架Top100 

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

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

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

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

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

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

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

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

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

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

  • 11452/8   流媒体视频直播方案

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

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

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

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

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

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

  • 10017/10   十大技巧快速提升Android应用开发性能

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

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

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

  • 返回顶部