微软的软件测试工程师——《微软的软件测试之道》

简介:

   好多人极力推荐《微软的软件测试之道》这本书,于是在网上搜索了一番,英文版的阅读起来有难度,在51CTO上发现了前第二章和第三章中文的内容。

    在这个世界顶级的企业里,软件测试工程是的测试是怎样的。

------------------------------------------------------------------------------------------------

     一、职位名称含义:

即使你给玫瑰花起不同的名字,它闻起来可能还是同样的香。但是,如果你给工程师不同的职位名称,他们对自己职责的理解就会大不相同。微软将那些通过编写代码来开发产品功能的软件工程师统称为"软件开发工程师"(Software Development Engineer,SDE)。而微软测试工程师的正式职位名称是"软件开发测试工程师"(Software Development Engineer in Test,SDET)。 这两个职称听起来很像,因为微软的测试工程师也同时做开发。测试工程师的其他主要职责包括:制定测试计划、设计测试用例、分析缺陷的根本原因、参与程序代 码的审查和产品设计的审查,以及开发测试自动化程序。有时测试工程师也参与产品源代码的开发,或缺陷的修正等工作。但总的来说,因为测试工程师的工作量很 大,所以直接参与产品开发的情况并不是很普遍。

雇 用对测试有激情的软件工程师做测试工作是微软行之有效的创新,它完全不同于软件行业其他公司的做法。对此外界常得出一种结论,认为我们雇用会编写程序代码 的工程师来做测试工作是因为我们想让他们编写有效的自动化测试程序,从而排除手工测试。其实这只是其中的一小部分原因。那些懂得怎样编写程序和计算机基本 构造的测试工程师,常常具有软件测试所必备的分析技能。他们能够尽早发现缺陷并分析其根本起因,这使得他们能很快发现类似的缺陷。拥有和开发工程师一样的 计算机基础增强了测试工程师的技能,给了我们的测试工程师更灵活和动态的生产力。

2005年以前,微软将软件测试人员人分为:软件测试工程师(Software Test Engineer,STE)和软件开发测试工程师(SDE/T)。SDE/T 和STE的分工。

可 以看出,STE的工作更贴近于我们一般黑盒测试人员的工作,专注于测试计划、测试用例、测试的执行以及设计方案的审查;而SDE/T 的工作内容则是开发测试工具(安全、性能、自动化方面的工具的开发)以及找bug、参与设计方案审查、代码审查等一般的测试工作。(ps:只用大牛公司才 会设开发测试工具的测试人员,呵呵)

2005年以后,微软调整了测试职称,将所有的测试人员统称为:软件测试开发工程师(SDET)

微软的SDET培训路线图:

二、微软的测试架构师

微软1999年设立测试架构师职称。是专门为那些对产品有影响的高级独立贡献者而设的。测试架构师的职称反映了一个SDET对其所工作的产品的广泛影响力。而高级SDET、首席SDET、合伙人SDET的职称则主要是给那些对某个产品的功能产生影响的人。

不 过请记住,很重要的一点是测试架构师是一种角色而不是一个职位。尽管一个高级测试工程师可能会晋升为测试架构师,但是并不是所有的人都会成为测试架构师。 通常,有些部门会出于商业需要或策略需求设立一个测试架构师的角色。但有时候你也会看到一个高级测试工程师发挥测试架构师的作用,但是却没有测试架构师的 职称。注意,此处所讨论的是测试架构师的角色而不是测试架构师的职称。

 

    微软并没有具有普遍性或代表性的测试架构师角色。微软的测试架构师们致力于各种各样的目标,承担着各种各样的任务。有些人花时间开发测试的基本结构、测试 框架,或者评估产品功能、创立复杂的测试。有些人则负责管理其所在部门的某项特殊技术。还有些人负责怎样提高测试效率的咨询。所有测试架构师的角色的共同 点和主要职责是为本部门提供技术指导和制定策略方向。测试架构师的级别通常表明他们的职责范围--是致力于产品的一组功能、一条产品线,还是跨越整个部门。当然,除了被期待对现有产品负责外,测试架构师还应该超越产品的现有版本而能高瞻远瞩,如果可能的话,还拥有两三个不与某个特别产品的发行有直接关系的成果。

     微软的测试架构师不仅要有效地影响测试领域,还要在开发和项目管理方面发挥影响力。测试架构师必须能驾驭产品的质量、提供指导、反馈和建议,以提高整个工程部门的质量规范。

  前面谈论了测试架构师"是什么",那么,测试架构师"不是什么"呢?测试架构师的职称不是因为级别或经验而授予的。设立测试架构师是一种投资。 这种投资结合了市场对有能力帮助产品做灵活变化的人才的需求。值得强调的是测试架构师并不是一种职业发展轨道。对测试架构师的技能要求和对相似级别的其他 职务的职业阶段发展要求是一致的,都强调跨组织的沟通和推动变革的能力。提示:

截止至2008年,微软全球的9000多名测试工程师中只有四十几位测试架构师。

 

     三、微软的测试职业的发展道路

1.       SDET独立贡献者开始的职业发展历程

      影响力的范围从一个狭窄定义的产品功能扩展到一个系列产品的功能、一个完整的产品。比如Microsoft Office Word或者Microsoft Media Player,直到最后达到一条产品线,比如Office或者Windows系统。影响力可以像测试架构师的职位那样,基于测试的各个方面横向延伸,也可 以基于一个像协议安全那样的技术领域纵向延伸。

      合伙人SDET并不是一个工程师的职业发展轨道的最高点,却是测试职业发展轨道的最高点。合伙人SDET 比杰出工程师(Distinguished Engineers)(相当于公司副总裁级别)要低一个级别。这并不是因为微软觉得在测试领域不需要杰出工程师,而是我们相信随着工程师们在职业道路上不 断地前进发展,他们的行为表现变得越来越相似,不同学科的差异所带来的影响价值在减少。在某种意义上,每一个从事10个工程学科中的任何一个学科的工程 师,随着他们技术领域的发展,都可以达到成为另外一个学科的工程师的水平。

 

2.       SDET管理开发的职业发展历程简介

  

    在微软,当一个工程师转向管理职位时,这是一个"平级"的变化,转为管理人员这并不说明你有更高的工资,更好的办公环境。也就是说微软有技术人员都有资深的技术背景,而他们在管理的同时也要分担技术工作。

     有一点很重要,在决定一个SDET主管能否在职业道路上继续前进和发展的因素中,技术复杂度和他的技术水平远比他所管理的测试组的大小重要。负责测试产品 安全的小组就是一个例子。这些规模小,但技术含量高的组通常对产品的质量有着重要的影响,所以在这样的组里,你可能常会发现一个更资深的SDET主管。在 一个相对规模较小的组,SDET主管自己也需要做很多的测试、编程、分析和记录软件漏洞的工作。从最高级别的执行董事到刚加入的新员工,产品组的每一个成 员在发现产品漏洞的时候都应该对漏洞记录存档。随着一个组的规模越来越大,主管需要承担更多的管理职责,而在具体的技术工作上花费的时间较少。无论组的规 模大小,SDET主管都应该具备很强的技术能力,同时也担负起一个组的技术领导工作SDET主管通常都是组里对一个产品功能懂得最多的工程师,同时也是组里最好的测试和开发人员之一。

 

3.   测试经理职称

    测试经理很少需要亲自作具体的测试工作事项,比如编写和执行测试用例。但每一个在测试领域的人,无论他是什么级别,都会亲自动手找软件的缺陷。测试经理仍然需要懂得技术,但要求他们多注重建立测试的流程和工具,而不是在具体的功能测试上。

----------------------------------------------------------------------------------------------------------------------

个人看法:

1.  关于测试人员是否需要懂开发的问题是许多测试人员讨论的问题,个人看法,当测试走到一定深度就会有瓶颈,要想做的更远,学习开发是一个突破口,我觉得不懂 开发的测试犹如“隔衣挠痒”,什么感觉?自己体会!提示并一定要精通开发,但一定要有开发思想。也许微软的产品特殊,所以他们所有测试人员都整成了 SDET(软件测试开发工程师),既然存在就有它的意义,而且还是在那么牛叉的公司存在,希望和我一样的小初级测试员它当做一个目标去努力。

2.  微软的工程师转管理职位是“平级”的,而且要转管理一定在技术上优于同事,可见微软把技术看的很重要,就目前我所知道的测试人员相对来说比较浮躁,工作内 容散而不深,工资相对开发人员低,尤其刚入行的测试员,好多公司没有给出很好的定位,职业发展比较迷茫,这是我们测试行业的现状,但我还是希望各位平心专 注于技术上。

目录
相关文章
|
28天前
|
人工智能 搜索推荐 数据管理
探索软件测试中的自动化测试框架选择与优化策略
本文深入探讨了在现代软件开发流程中,如何根据项目特性、团队技能和长期维护需求,精准选择合适的自动化测试框架。
85 8
|
2月前
|
测试技术
软件测试的艺术:探索式测试的实践与思考
在软件开发的广阔海洋中,测试是确保航船稳健行驶的关键。本文将带你领略探索式测试的魅力,一种结合创造性思维和严格方法论的测试方式。我们将一起揭开探索式测试的神秘面纱,了解其核心概念、实施步骤和带来的效益。通过实际代码示例,你将学会如何将探索式测试融入日常的软件质量保证流程中,提升测试效率与质量。
|
1月前
|
测试技术 持续交付
探索软件测试中的自动化测试策略
随着软件开发周期的加速和市场需求的不断增长,传统的手动软件测试方法已难以满足现代软件开发的高效性和准确性要求。本文旨在探讨自动化测试在软件测试中的重要性、实施策略及其对提高软件质量的影响。通过分析自动化测试的优势与挑战,以及提供实用的自动化测试工具和框架选择指南,旨在帮助读者理解并应用自动化测试以提升软件开发效率和产品质量。
|
1月前
|
机器学习/深度学习 人工智能 监控
软件测试中的自动化测试策略与最佳实践##
在当今快速发展的软件行业中,自动化测试已成为确保软件质量和加速产品上市的关键工具。本文将探讨自动化测试的重要性,分析不同类型的自动化测试工具和框架,并深入讨论实施自动化测试的最佳实践。通过案例研究和数据分析,我们将揭示如何有效整合自动化测试到软件开发生命周期中,以及它如何帮助团队提高测试效率和覆盖率。 ##
60 1
|
2月前
|
机器学习/深度学习 前端开发 测试技术
探索软件测试中的自动化测试框架选择与优化策略####
本文深入探讨了在当前软件开发生命周期中,自动化测试框架的选择对于提升测试效率、保障产品质量的重要性。通过分析市场上主流的自动化测试工具,如Selenium、Appium、Jest等,结合具体项目需求,提出了一套系统化的选型与优化策略。文章首先概述了自动化测试的基本原理及其在现代软件开发中的角色变迁,随后详细对比了各主流框架的功能特点、适用场景及优缺点,最后基于实际案例,阐述了如何根据项目特性量身定制自动化测试解决方案,并给出了持续集成/持续部署(CI/CD)环境下的最佳实践建议。 --- ####
|
2天前
|
机器学习/深度学习 人工智能 自然语言处理
MarS:微软开源金融市场模拟预测引擎,支持策略测试、风险管理和市场分析
MarS 是微软亚洲研究院推出的金融市场模拟预测引擎,基于生成型基础模型 LMM,支持无风险环境下的交易策略测试、风险管理和市场分析。
26 8
MarS:微软开源金融市场模拟预测引擎,支持策略测试、风险管理和市场分析
|
2月前
|
测试技术 UED 开发者
软件测试的艺术与科学:探索有效的测试策略
在软件开发的宇宙中,测试是一颗璀璨的星辰,它不仅保障着产品的质量,也指引着项目的方向。本文将带你穿梭于测试的银河系,从基础的单元测试到复杂的集成测试,再到全面的系统测试,我们将一探究竟。你会发现,每一个测试阶段都是一次对代码深度和广度的挑战,也是一次对开发者耐心和智慧的考验。准备好了吗?让我们开始这段探索之旅,看看如何通过精心设计的测试案例来确保我们的软件能够在现实世界中稳健运行。
|
1月前
|
Java 测试技术 API
探索软件测试中的自动化测试框架
本文深入探讨了自动化测试在软件开发中的重要性,并详细介绍了几种流行的自动化测试框架。通过比较它们的优缺点和适用场景,旨在为读者提供选择合适自动化测试工具的参考依据。
|
1月前
|
数据管理 测试技术 持续交付
软件测试中的自动化测试策略与最佳实践
在当今快速迭代的软件开发环境中,自动化测试已成为确保软件质量和加速产品上市的关键手段。本文旨在探讨软件测试中的自动化测试策略,包括选择合适的自动化测试工具、构建有效的自动化测试框架以及实施持续集成和持续部署(CI/CD)。通过分析自动化测试的最佳实践,本文为软件开发团队提供了一系列实用的指南,以优化测试流程、提高测试效率并减少人为错误。
69 4
|
1月前
|
监控 测试技术 定位技术
探索软件测试中的自动化测试框架选择与实施###
本文不概述传统意义上的摘要内容,而是直接以一段对话形式引入,旨在激发读者兴趣。想象一下,你是一名勇敢的探险家,面前摆满了各式各样的自动化测试工具地图,每张地图都指向未知的宝藏——高效、精准的软件测试领域。我们将一起踏上这段旅程,探讨如何根据项目特性选择合适的自动化测试框架,并分享实施过程中的关键步骤与避坑指南。 ###
46 4