首页 > 其他分享 >测试架构需要具备哪些能力

测试架构需要具备哪些能力

时间:2022-11-12 20:44:05浏览次数:46  
标签:架构设计 架构 哪些 复杂 技术 测试 架构师

转载:https://www.cnblogs.com/imyalost/p/16834322.html

这篇文章是软件工程系列知识总结的第五篇,同样我会以自己的理解来阐述软件工程中关于架构设计相关的知识。

相比于我们常见的研发架构师,测试架构师是近几年才出现的一个岗位,当然岗位title其实没有特殊的含义,在我看来测试架构师其实更像对某一类人的抽象称呼和对其复合能力的期待及认可。

在聊这篇文章的主题之前,先来看这样一个问题:为什么软件项目需要架构设计?

 

为什么软件项目需要架构设计?

如果是一个简单的软件系统,没有太多用户使用,也没有较为复杂的业务逻辑,那架构设计几乎是不需要的。为什么呢?

一般来说用户少意味着操作场景较少,没有高并发场景,也没有复杂的业务逻辑,只要功能正确实现可以正常使用即可。但在我们实际的工作场景中,我们面对的工作对象,常常具备这两个特点:

  • 需求不确定性较高;
  • 系统使用的技术较为复杂;

需求的复杂和不确定性大家都很熟悉,特别是做互联网To C业务的企业,需求的复杂和不确定性就更高。而技术的复杂性,主要来源于下面几点因素:

  1. 需求让技术变复杂:为了满足需求的复杂和不确定性,软件系统背后的技术应用就会很复杂;
  2. 人员让技术变复杂:团队里的同学来自不同背景不同企业,技术栈和工作经验各不相同,因此技术也会变复杂;
  3. 技术本身就很复杂:不同的编程语言、框架、技术组件、数据库、大数据、算法、ARVR等本身就是复杂的技术;
  4. 让软件稳定运行很复杂:线上服务要稳定运行会面临各种不确定性,比如峰值流量冲击、云服务不可用、网络问题;

因为技术的复杂性,会导致软件研发的过程变得很复杂,而软件工程本身就是为了摆脱软件质量危机,以软件开发为核心,对开发过程组织+对方法的运用+对工具的使用

来让软件系统达到稳定,而架构设计正好可以解决这些复杂性带来的问题。架构设计的有点如下:

  1. 降低需求变更带来的研发成本;
  2. 可以更好的组织人员高效协作;
  3. 架构设计本身就是对各种复杂技术的合理运用和组合;
  4. 架构设计可以保障线上服务更稳定的为业务目标达成提供支撑;

 

测试架构师需要解决什么问题?

看完了上面关于架构设计的优势,其实可以快速推导出测试架构要做的事情。

研发角度的架构设计要做的是:用最小人力成本满足需求开发和响应变更,用最合适的技术架构来保障软件的平稳运行。

简单来说就是:组织人力高效协作+合理设计技术框架+保障线上服务稳定运行。

从测试的角度出发,测试的本质是质量保障和推动研发效能提升。那么测试架构要做的事情是:

  1. 质量把控:从需求质量到研发过程质量以及线上质量的把控;
  2. 技术设计:针对不同项目,选择合适的技术栈来快速解决问题;
  3. 组织协调:组织测试团队的同学高效完成软件产品的质量保障工作;

 

测试架构师需要具备哪些能力?

大多数企业的组织架构是横向的,而测试团队在其中的定位既可能是横向的大团队,也可以是纵向跟着项目走的小团队。而测试架构师的角色,在我看来其实需要具备两点特质:

  1. 纵向的业务了解和技术深耕;
  2. 横向的拉通对齐和组织协调;

结合测试架构要做的事情以及在团队中的角色定位,我认为测试架构应该具备如下几点基础能力:

 

 

 

测试工程师如何培养架构能力?

与其说测试架构师是一个岗位和title,不如说他是具备某些复合能力的可以解决问题的人。

当然并不是说所有测试同学都需要变成测试架构师,这种测试架构能力在日常工作和学习中是可以培养的。

对于普通的测试工程师,想要培养测试架构能力,我建议可以先从如下几点入手:

  1. 分析需求:在日常工作中仔细分析需求,做好需求评审和风险评估;
  2. 技术选型:无论是自动化或者性能或者单元测试,尽可能选择成熟的技术方案并对其深入了解;
  3. 逐步迭代:解决问题的过程中,避免追求完美的方案,而是先解决眼下问题,再逐步深入分析和优化;
  4. 不断优化:解决问题后要不断验证其效果和效率,评估能否满足未来的变化,能否持续保障软件高质量运行;

你看,上面四点是不是和产品设计中提倡的mvp方案有类似的思路。

我在前面的文章中也提到过一个质量保障体系的总结,即:风险可识别+问题可追踪+结果可验证+数据可量化

按照上面的几点坚持去做,迟早我们都会具备架构能力。

标签:架构设计,架构,哪些,复杂,技术,测试,架构师
From: https://www.cnblogs.com/ceshi2016/p/16884612.html

相关文章

  • 22-MySQL架构与性能优化
    架构:C/SConnectors:连接器可供NativeCAPI、JDBC、ODBC、NET、PHP、Perl、Python、Ruby、Cobol等连接mysql;站在编程角度可以理解为连入数据库管理系统的驱动,站在mysql角度......
  • Pytest接口测试框架实战项目搭建(三)—— 统一登录处理
    一、前言业务系统的登录均要经过统一登录系统S,本篇演示2个业务系统的登录,一个是内部业务系统C,一个是外部用户使用的系统W,因为账号密码以及headers信息都不一样,所以要......
  • 软件产品测试之压力测试
    压力测试是一种性能测试方法,通过迫使软件处于极端情况发现性能瓶颈。在极端情况下软件更容易暴露出性能问题。因此采用压力测试分析实时软件的性能以保障它的质量。其实就......
  • 24. echarts 可以画哪些图表
    1.折线图2.柱状图3.饼图 4.地图5.雷达图 延申问题:画折线图和柱状图哪些配置可以改变样式 1.  color 设置每个数据的颜色2. grid网格设......
  • 一个页面上有大量的图片,加载很慢, 你有哪些方法优化这些图片的加载,给用户更好的体验
    一个页面上有大量的图片,加载很慢,你有哪些方法优化这些图片的加载,给用户更好的体验点击查看代码图片懒加载,在页面上的未可视区域可以添加一个滚动条事件,判断图片位置与浏......
  • 黑盒、白盒、灰盒测试
    黑盒、白盒、灰盒测试点击查看代码白盒测试:白盒测试也称为结构测试或逻辑驱动测试,是针对被测单元内部是如何进行工作的测试。它根据程序的控制结构设计测试用例,主要用......
  • 软件测试之编写用例的重要性
    1.深入了解需求的过程一个项目立项开始,测试就开始介入,我们从产品的PRD文档、用户交互图,视觉图等相关文档去熟悉产品的各个模块,各个业务流程。或者在产品规划和设计......
  • Mongodb中的PSA转换为PSS架构
    PSA架构的问题众所周知,PSA架构中如果Secondary发生故障会带来一系列的问题,包括Majority写入无法完成造成主库内存压力的增加重启主库需要更多的时间特殊情况下会导致数据的......
  • Java项目的程序里为什么老用注解?注解有哪些作用
    注解和注释不同的是,注解会被Java编译器处理而非跳过。注解是在JDK5.0版本开始引入的,它可以在编译期使用预编译工具进行处理,也可以在运行期使用Java反射机制进行处理。......
  • 一个简单的查询学生信息的接口测试
    Test作业提交学习笔记编写一个业务接口(登录,查找学生等)打包成jar包在本机上面执行相应的命令,通过浏览器访问接口获得数据。(可选)将该jar包放在服务器上面运行,通......