您还未登录! 登录 | 注册 | 帮助  

您的位置: 首页 > 软件测试技术 > 其他相关 > 正文

测试之效能提升

发表于:2019-10-15 作者:小牛哥技术团队 来源:云栖社区
一、测试的阶段

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、不能被管道化的,我们来看看 我们应该想着怎么在单元测试/接口测试 加重我们的价值,接口测试/单元测试 有逻辑验证在里面 近期     
  几年被管道化可能性较低,性能有结果分析,脚本调优,暂时也不必担心;