您现在的位置是:首页 > 文章详情

测试之效能提升

日期:2019-09-26点击:307

一、测试的阶段

image
我们现处于哪层?最顶层;每一层我们可以做哪些事?现在公司基本两层:前端→后端,稍微复杂点项目三层,UE4→前端→后端 ,后端后续微服务之后,前端→网关→后端:服务排查问题置顶向下成本将越来越高,长期受益可以从后面几个阶段提升;

二、单元测试

2.1项目周期:

测试第一步:单元测试(开发模块完成);例如:

image

image

2.2单元测试的好处:

1、没有什么数据是造不出来的,通通返回Mock 的对象 2、代码中的异常处理代码,也可以通过mock 接口,使之抛出异常 3、不产生任何脏数据 4、跑 case 更快了,因为不用启动整个项目,相当于 Main 方法 5、项目测试越往后越顺畅,为 接口测试,功能测试打头阵 

image

三、接口测试
3.1手工测试的痛点:

1、牛牛搭系统复杂度不断增加,手工测试的工作不断增加; 2、回归工作较大测试效率越来越低,覆盖不完全; 3、线上bug没有有效保障手段,比较被动(线上bug反填到自动化脚本) 4、bug排查效率低(前后端及各服务之间分离越来越明显) 

3.2自动化优点:

1、日常测试前端字段的校验不能满足要求,服务端字段校验时,通过接口测试来做能很快满足测试场景; 2、当APP的代码不更新,而服务端代码更新时,直接通过接口自动化测试就能快 速知道是否影响APP的功能。 3、接口测试相对容易实现自动化,也容易实现持续集成,且相对UI自动化也比较稳定; 4、可以减少人工回归测试人力成本与时间,缩短测试周期,支持后端快速发版需求。 5、接口持续集成会带来效率提升,人力手工成本的减少,最终达到低成本高收益。 备注:自动化的收益 = 迭代次数 * (全手动执行成本 - 维护成本) - 首次自动化成本 

3.3接口自动化怎么做?

选型思路: 1、可自动化,低成本(√) eg:postman+newman+Jenkins持续集成 2、自动化,成本高(ToDo) TD:①Test工程+Junit框架 ②单元测试 eg:持续集成+报告+得出覆盖率 3、不可自动化(待定) eg:业务成熟之后,UI自动化是否能解决 

四、自动化持续集成搭建
4.1环境搭建大概过程:

1、linux虚拟机搭建,作为测试服务器主机(我旁边那台电脑) 2、Newman安装,用于psotman脚本执行工具 3、Git 安装,clone test工程,用于拉取服务器postman的脚本; 4、Jenkins搭建,自动构建+报告展示 5、钉钉发送报告消息 

五、postman工具使用
5.1,操作流程

1、下载Postman工具的客户端 eg:单接口测试及断言脚本调试 2、newman下载安装 eg:调式导出的postman脚本,确保能跑出来脚本再提交到git 3、注册一个postman账号,通过这个地址加入项目组: https://app.getpostman.com/join-team?invite_code=89e29047b32f8ccd21a88992dc13e500 4、新增第一个request请求

image

5.2 页面功能

1>接口名称; 2>接口的请求类型:GET; 3>环境变量; eg:建议接口测试过程中多思考,灵活运用 变量;便于日后脚本维护; 4>接口请求地址 5>URL带入的入参 6>新增查看环境变量 7>发送接口请求 8>保存接口,存到对应的脚本目录下

image

5.3 断言初步使用

1>header头 eg:x-access-token 登陆接口保存token 2>Body请求入参,接口文档获取; 3>Test,用于Asser断言验证结果; eg: 第一行,Json返回结果赋值给一个变量; 大框的,断言脚本登录返回值,塞到token里面 最后一行,效验该接口的角色权限结果 

image

5.4 批量执行/调试脚本

1>导出postman脚本 2>下载环境变量脚本; 3>cmd,运行脚本; eg: newman run Test.postman_collection.json -n 2 -e base_url.postman_environment.json Test.postman_collection.json -- 接口测试脚本文件 base_url.postman_environment.json -- 环境变量文件 -n 2表示迭代2次 

image

六、展望未来(YY)

6.1 最后YY一下IT话题

1、现阶段单元测试自动化,接口测试自动化,UI测试自动化,叫什么?满足什么?未来有什么价值? 引入DevOps,DevOps是什么?跟我们有什么关系? eg:DevOps是一种软件开发方法,涉及软件在整个开发生命周期中的持续开发,持续测试,持续集成,持续部署和持续监控。标红对于 测试而言是什么,大家自我思考; 2、被管道化的运维工程师? eg:想想技术最初有DBA,运维工程,开发,测试,现在呢?只有 开发+测试 被管道化之后出现两类极端? ① 小中型公司,普通的运维岗位消失了 不被公司需要,被阿里云管道化,自动打包,一键部署等;(是否有危机感) ② 高级运维工程师,能力要求越来越高了,工资也越来优厚了,可以看出最终的结果,宁缺毋滥

image

6.2 YY Test话题

说说测试,测试现在岗位被细化:功能测试—单元测试—接口测试自动化—UI自动化—性能测试 这几个细化岗位,近几年最可能会被管道化是谁? 1、功能测试目前大厂基本很少有了(核心模块少量业务专家),都是外包测试,可能会被UI自动化代替; 2、单元测试,开发在做部分没有养成习惯,主要是保证开发质量,为下游扫平基础障碍; 3、接口测试 是不是开发也可以做,只是愿不愿意做,极端一点,把测试工资给他试试看?谷歌一开始是没有测试的; 4、UI自动化一般最难做,受产品变更的影响,成本高收益低,最近图片识别及照片算法脱衣服,想着如果应用到UI自动化 也是不会有太 大难度;(稍远稍近了点,哈哈~) 5、不能被管道化的,我们来看看 我们应该想着怎么在单元测试/接口测试 加重我们的价值,接口测试/单元测试 有逻辑验证在里面 近期 几年被管道化可能性较低,性能有结果分析,脚本调优,暂时也不必担心;
原文链接:https://yq.aliyun.com/articles/719514
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章