为什么要进行自动化测试?
开始正文前,我们必须先统一认知,充分认识到自动化测试的必要性,随着被测系统越来越大,逻辑越来越复杂,测试的工作量也会倍增,这必然会暴露出测试资源与测试生命周期的冲突,因此为了更快、有效、可靠的对被测系统进行测试,需要引入自动化测试。 加我VX:atstudy-js 回复“测试”,进入 自动化测试学习交流群,内含直播课+实战+面试资料~~
而另一方面,当下测试开发岗位是目前软件测试的主趋势,也是升职加薪的必要手段,因此自动化测试必须要尽快实施。
分层做自动化
选择做自动化,首先要明确目标,自动化是分层的,目前主流认为,自动化测试主要分为UI、SERVICE、JUNIT 三层。
所以我们做自动化的第一步要确认,自己要做针对哪一层的自动化,每一层自动化要做的事情如下:
UI 层:主要是对页面元素进行检验,多用于测试浏览器的兼容性。
SERVICE 层:主要针对的就是接口,而接口关注的就是一个类、或者一个函数的实现。
Junit 层:则关注于底层代码的逻辑,需要精确到每个 if 分支、每个 for 循环的运行。
以主流电商淘宝网为例:
此时我们想验证下谷歌、火狐、EDGE、Safari 浏览器是不是都可以正常进行搜索,此时我们就可以将这个功能做出 UI 自动化,自动识别搜索框,而后在各个浏览器以验证其兼容性。
那么我们输入”苹果手机”,而后点击搜索,此时服务器会根据用户要求返回查询结果,这时就是接口测试。
有了接口,后台会判断关键字:收到”苹果手机”就返回其相关内容,如果搜索的为”华为手机”就要返回华为手机相关内容,此时就涉及逻辑判断,最好通过单元测试实现。
明白了每层的自动化的测试标的,接下来再给大家介绍下,为什么是金字塔模型,这代表每层的比重和重要性,因此这个模型告诉我们:
一定要对底层实现做单元(JUNIT)测试,当然这部分大部分都是由开发实现。
UI 因为其不稳定性,投入高但是往往效果小,因此比重低,但是这个框架有个好处,适合学习入门,因此如果你第一次尝试自动化,不妨从 UI 开始做起。
接口自动化,对测试人员的编码能力有足够高的要求,但是相对于单元测试,又少了很多细节技术的学习,因此推荐有一定代码基础的人从接口自动化做起。
所以这里我的建议是,先树立目标,从哪一层开始做起,入门级做 UI,有一定的基础直接做接口。
自动化前的技术储备
决定做自动化之后,是需要有一定的技术储备的,结合我个人的经验,给出如下建议:
第一步:确立学习一门主要的编程语言,这里主推 java,虽然 python 被很多人说适合测试,但是我建议你学习 java,因为自动化核心的框架 selenium、testng 都是 java 语言编写的,最主要的是,用 java 更贴近于目前大部分公司系统,遇到问题可以随时请教公司研发同事,另外一旦实施,很多环境可以开箱即用。
第二步:学习一门自动化框架,推荐 selenium、testng、allure(这个用来产出报告的)
第三步:弄清楚主流的应用层通讯协议,这点至关重要,如果你压根不明白什么是 http 接口,什么是微服务接口,什么是 TCP 协议接口,什么是 API 接口,那么你可能很难有自动化的架构思维。
第四步:了解下自动化的基本组成,一般要进行:自动化用例设计、脚本开发、数据驱动、参数化、生成测试报告 这六大模块,需要了解下每个模块的大致做法,这样方便后面自己定位问题。
学习下主流的开发技术框架,推荐 springboot,有了这个一站式开发框架,可以快速的帮助你搭建分层的自动化框架,一定要了解下。
学习下 maven,这个可以更好的帮助你管理自己的自动化工程。
最后一步,最最关键,边学习边做是最佳实践,不要学完了在用,而是要边学习边应用,边应用边积累,养成写技术博客的习惯。
这里我强调技术储备非一朝一夕之功,只要自己有了学习方向,就可以边做边学!
终极测试的职业规划
如果一旦进入到自动化测试的行业,请明白,也只是测试职业生涯的一小步而已。如果想要在测试行业继续耕耘,有更高的成就,需要为自己制定好严格的职业规划路径。如果把目前的自动化测试分为初级、中级、高级、专家四类,在每一级的要求如下:
可见从初级成长到专家,要做的事情非常多,每一级别的成长都有其对应的技能标准,我们只有对自己的职业有清晰的认识,才能使我们走的每一步都掷地有声。
总结来看,首先要清晰的认识自己到底要从哪一层的自动化开始做起,这需要对自己目前现状做充分分析才能决定,确定了做自动化,那么技术储备必不可少,要清晰的认识到做自动化是离不开技术编码的,最后入行了自动化,要对其职业发展有明确的规划,这样自己才能朝着目标越来越近,大道至简,多说无益,选择转行自动化,那么从现在开始行动吧!
原文链接:http://blog.itpub.net/31407649/viewspace-2791521/