| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 开发测试 -> 软件测试职业发展方向 -> 正文阅读 |
|
[开发测试]软件测试职业发展方向 |
大家好,我是馨馨紫,软件测试妹纸一枚,有6年的软件测试经验,混过大厂,待过创业公司,独自负责过从0到1的项目测试,也当过测试小组长,今天跟大家分享下软件测试心得,希望对大家有所启发。 文章结构如下: 一、软件测试概述 二、所需能力模型 三、职业发展方向 四、六年测试心得 一、软件测试概述 说起软件测试,很多人的印象,大概是有手就能做,「点点点」就行了。确实,大多数基础测试工程师做的都是「点点点」的工作,但是这个点呢,讲究逻辑,通过什么方式来「点点点」,能尽早暴露问题,用更少的操作覆盖更多的测试场景,从而保证产品质量,这就涉及到技巧性了。 除了「点点点」,测试同学还有很多其他的工作可以做,那么实际的测试工作是怎样的呢?馨馨紫结合6年的测试经验,给大家分享一波。 测试同学的职责无非就是两个,保证软件测试质量和提高测试效率。 为了达到这两个目标,测试同学的日常就包括:常规需求的功能测试,自动化测试,性能测试,跟踪线上反馈问题,搭建测试环境,把控项目进度和质量,开发测试平台或脚本,进行部门的管理工作等等。 1、常规需求的功能测试 包括参与需求评审会议,制定测试计划,编写测试用例,评审测试用例,执行测试用例,提交Bug,回归验证Bug,发送测试报告,进行线上验证等一系列活动。 2、进行性能测试 根据项目需求,对重要接口制定压测方案,利用Jmeter等测试工具进行压力测试,配合开发同学找到系统瓶颈,并产出压测报告。 3、进行自动化测试 利用自动化测试工具例如Robot Framework,Python+unitest/pytest,Selenium等完成页面UI自动化或接口自动化,提升测试效率,尽早暴露问题。 4、跟踪线上反馈问题 在日常测试中,线上问题不可避免,反馈过来的线上问题,需要测试同学过滤和重现,再同步给开发同学,并协助开发同学定位问题,待开发同学解决后,测试同学验证完成后上线。 5、搭建测试环境 有的测试环境由运维同学来搭建,而有些则需要测试同学来搭建,视不同的公司而定,搭建测试环境会有文档,根据文档,即可完成,一般的测试环境有Linux,Windows,而Linux偏多,因此会用到较多的Linux命令,平时学会一些基础的Linux命令是很有必要的。 6、把控项目进度和质量 对于项目中出现的Bug和不确认点,需要测试同学积极推进,及时与产品和开发同学沟通,尽快解决问题,推动项目的进展。 对于产品的质量,测试同学会对定期进行Bug统计,分析Bug原因,如果质量一直很差,就会采取一些措施来积极改进和提升。 7、培养测试新人 新人在试用期间,会分配一位导师,对其工作内容和转正考核负责,一般由测试组长承担该角色。 8、开发测试平台或脚本 有些公司有专门的测试平台,来完成Bug统计与质量分析,接口自动化统计等等功能,这部分开发工作会由测试开发工程师来承担。 9、进行部门的管理工作 管理工作由领导承担,包括各项目的人员安排,项目测试时间的评估,项目测试进度跟进,部门成员绩效考核,人员招聘,团队建设等等。 二、所需能力模型 想要做好软件测试,需要具备两方面的能力,即硬实力和软实力。 一)硬实力 硬实力,也就是测试同学需要的专业知识,具体的知识体系如下: 1、软件测试基础知识 馨馨紫在大学期间,有幸上了软件测试这门专业课,算是入了门,为后续的职业发展也打下了基础。 入门测试基础知识,主要从软件缺陷,软件开发周期模式,软件测试分类,软件测试用例设计方法等方面入手。 2、软件测试流程 业界比较规范的软件测试流程是:需求评审,制定软件测试计划,编写测试用例,进行用例评审,执行测试用例,提交Bug,验证Bug,发送测试报告,进行线上验证。 但是在实际工作中,往往不会有这么规范的流程,馨馨紫只在一家公司经历过这么规范的流程,当时刚好公司进行流程规范,请了何勉大佬,来公司专门做指导。 该大佬, 是一名资深精益产品开发顾问,专注于精益产品交付、精益创业、创新及精益产品设计等领域,曾为华为、平安科技、招行以及多家成功的创业公司建立或引入精益产品开发和创新方法,推荐大家看看他的书籍 《精益产品开发:原则、方法与实施》。 大多数不规范的流程主要分为以下几种: 1)没有需求评审,开发完直接提测 需求由开发同学口述或者在邮件中进行简单的说明,测试同学就开始介入测试。 在需求不明确的情况下进行测试,测试同学往往在沟通需求的过程中花费很多时间,而且最后可能会背锅。 这种情况下,测试同学则需要记录好已经测试的点,并与开发和产品同学确认清楚范围,只能保证当前已经测试功能的正确性,其他未测功能风险未知,并在测试报告上做明确说明,万一以后线上有Bug,可以拿测试报告说话。 2)没有用例评审环节 用例评审,即测试,开发,产品三方一起,确认测试点,旨在避免遗漏测试点,在比较复杂的系统中会有该环节,对于逻辑很简单的系统,就没有必要了。 做好用例评审,要把握好评审的粒度,如果粒度太细了,与会的同学会比较疲,参与感会越来越弱,所以把握好粒度很重要,列出测试点即可,不用特别详细。 3)没有Bug管理工具 在Bug管理系统上记录,有利于质量分析,同时Bug库也是一个很好的测试用例库,很多Bug具有普适性,在不同的项目中可以相互借鉴。 有的公司没有Bug管理系统,直接用文档记录,或者发在群里,Bug比较少还好管理,但是Bug一旦多起来,就容易混乱,前后端的Bug需要不同的人员认领,修复了没有地方去更新状态,最后也不利于质量分析。 有的公司则是有Bug管理系统,但是由于开发人员的KPI与Bug数量有关,内部默认不记录Bug,直接用IM沟通,手动记录。 理论上来说,Bug管理系统是很有必要的,不仅能节省沟通成本,还有助于质量分析,大家如果合理利用,能带来很大的价值。 3、常用的测试工具 1)测试用例工具 编写测试用例的工具有很多,常见的有Xmind,Excel,TAPD,Testlink,Zentao等,在实际工作中,因为Xmind的简单和便捷性,用到的是最多的。 2)项目管理工具 常用的项目管理工具,有Zentao,TAPD,Teambition,Coding,Jira,企业自研工具。 在实际工作中,接触的到主要有Jira和企业自研工具,在何勉老师精益指导的过程中,用到的就是Jira,对于每一个需求,开发和测试同学,都会认领一个task,task的周期从开始到结束,每天站会沟通后,及时更新task的状态,在每个季度末,统计每个需求所花费的时间,做项目管理分析。 3)Bug管理工具 常见的Bug管理工具,有Jira,TAPD,Zentao等。 Bug是一个很有价值的系统,定期进行整理和分析,不仅能发掘很多测试点,还能评估项目的提测质量。 4)自动化测试工具 常见的自动化测试工具,有Jmeter,Appium,Postman,Selenium,Robot Framework,Python+unitest/pytest。 Jmeter,大多数时候用来做压力测试,偶尔也用来做接口自动化测试。 Appium,用来做移动端的自动化。 Postman,用于接口测试。 Selenium,用于Web应用的自动化。 Robot Framework,用于UI或接口自动化。 Python+unitest/pytest,用于接口自动化。 自动化,分为接口自动化和UI自动化,性价比相对较高的是接口自动化,接口的变化比较小,相对好维护一些,而UI自动化,页面变化快,维护成本高,所以很多项目都不考虑做UI自动化。 对于实际的项目经验,馨馨紫最熟悉的还是Jmeter和Robot Framework,曾经利用Robot Framework完成了项目从0到1的UI自动化和接口自动化,接口自动化覆盖率达到90%,并集成至CI上,每天自动跑,有问题及时发送邮件,大大提升了冒烟测试效率。 5)抓包工具 常见的抓包工具有Fiddler,Charles,Wireshark,这三种都比较常用。 抓包,也是为了更好的协助开发同学排查问题,出现了Bug,通过抓包,可以更清晰地排查是前端问题还是后端问题,比如未发送请求,或者传参错误,字段取值错误等都是前端问题,接口返回报错或者返回字段值错误等则是后端问题。 6)辅助工具 常用的辅助工具有Navicat,Xshell,Wiki,F12等等。 Navicat主要用来连接数据库,可查看数据库的字段,或通过SQL进行数据报表的测试等等。 Xshell主要用来远程连接Linux服务器,对服务器做一些基本的操作,在目录查看文件,启动服务,安装软件等等。 Wiki,主要用于公司内部的文档沉淀,例如编写接口文档,测试文档等等。 F12,抓取接口信息,查看接口请求和返回,区分前后端Bug。 4、基本的SQL语句 在实际测试过程中,例如一些列表或数据报表的展示,需要用到基本SQL语句的增删改查,所以掌握一些基础的SQL语句是很有必要的。 5、基础的Linux命令 在部署Linux环境,做压测等会用到Linux命令,熟悉一些文件管理,压缩与解压,性能监控,系统管理,用户管理,软件安装等命令就满足日常工作的需要了。 6、架构相关知识 架构知识需要结合实际的项目,在日常测试中,可以与开发同学多多沟通,了解下架构相关的知识,主要从语言,框架,部署等方面入手。 一个好的架构具有高可用,高性能,可伸缩,可拓展等特性。 二)软实力 大家不要忽略软实力,软实力有时候甚至比硬实力更重要。 软实力包括沟通协调能力,自主学习能力,文档输出能力,团队管理能力等等。 1、自主学习能力在测试日常中,与产品,研发同学沟通必不可少,要是沟通能力不行,比如需要确认的需求点说不清楚导致线上问题,与开发同学的测试范围确认不清楚而导致漏测,这无形会给日常的测试工作增加难度。 自主学习能力,这点很重要,我们生在互联网行业,大家知道,技术更新是日新月异的,时常关注行业新框架,新技术和新动态是很有必要的。 2、文档输出能力文档输出能力,编写测试报告,编写邮件等等都涉及到文档输出能力,这些报告和邮件是平时测试的成果,在业绩考核中也占有一定的比重,如果只会埋头干活,不会表达成果,升职加薪也是有难度的。 3、团队管理能力团队管理能力,有句话说的好,学而优则仕。的确,大家不可能永远待在基层岗位,大多数人都会慢慢往管理岗靠近,团队管理能力的重要性不言而喻。 三、职业发展方向 软件测试工程师的职业发展,可以分为四个方向: 一)业务测试工程师 业务测试工程师,在测试群体中这个比例是非常大的,这是最接近用户的一个群体,这部分的测试工程师主要负责常规需求的功能测试,接口测试,自动化测试,性能测试等。 涉及的业务主要有电商,金融,在线教育等等,不限于Web,客户端,移动端的测试。 馨馨紫待过测开比1:10的团队,也待过1:1的团队,具体的比例取决于业务形态和公司的资源,有的项目逻辑简单,开发周期短,出事故的概率低,造成的损失低,测试人员就会配置的少一些,而项目逻辑复杂,盈利多,开发周期长,测试人力就会配置的充足些。 在微软,测开比一般为1:1,在谷歌,测开比则为1:10,还是那句话,现状决定流程。 二)测试开发工程师 测试开发工程师,主要开发公司内部的测试平台/测试工具,也为业务测试工程师解决一些技术问题,例如搭建自动化测试框架,编写一些提升效率的自动化测试脚本。 测试开发的要求比业务测试工程师高一些,需要写得了代码,测得了需求,也就是即会开发,又会测试的同学。 一些小公司是没有测试开发工程师这个岗位的,一是没有自研的测试平台,而是由业务测试的同学偶尔做做补充,业务测试的同学也可以写点小脚本和小工具,所以就没有设置专门的岗位了。 测试开发的人员比例,馨馨紫经历过的公司大概是1:10,2个测试开发工程师,服务于20个业务测试工程师,具体比例取决于目前公司的现状。 三)管理岗 主要是进行部门的管理工作,包括各项目的人员安排,项目测试时间的评估,项目测试进度跟进,部门成员绩效考核,人员招聘,团队建设等。 1、入门级 很多同学是校招或者社招转行进入软件测试,初入软件测试的前两年,职位一般是初级测试工程师,大家都做着最基本的测试工作,主要是进行功能测试,熟悉业务,能保证上线的产品不出大问题即可。 2、3年左右 业务组长,作为项目的主测人员,重点在测试计划的制定和执行,测试任务的安排以及估期,保证项目能按期交付,线上不出现重大的事故,管理人数大约在3~5人。 3、5年左右 测试主管/测试经理,该阶段的工作主要包含测试计划的制定,更多的是关注重难点项目,且需要掌握更多项目管理的知识,深入理解项目的价值,做好项目管理,成本管理,风险管理和人力管理,同时也会参与一些招聘,员工绩效,质量管理,风险管理的工作。 4、8年或以上 测试总监,该阶段需要理解产品的商业目标,直接对产品成功负责。该阶段的主要工作包含管理测试团队,进行人员招聘,带好整个团队的节奏,优胜劣汰,留住核心人员,淘汰达标的人员,提升团队战斗力。 同时需要负责资源的计划和分配,持续改进测试能力,提升测试效率,保证产品质量,从测试的角度对交付的产品和质量负责。 四)转型 如果对测试没有很大的兴趣,觉得自己的沟通能力还不错,更喜欢与人打交道,可以转型到产品岗。 在业界,有很多从测试成功转型为产品的同学,他们后续发展的非常好,因为测试对于产品功能是非常熟悉的,产品需要的能力与测试有较多的重合,所以相对来说,转型的难度不高。 如果热衷于技术,追求技术带来的成就感,可以转到开发岗,在实际职场中,测试转开发的比率是很小的,测试同学要求的知识面是广而浅,开发同学要求的是精而深,个人兴趣和技术难度可能是转型少的一个原因。 其实还有好多选择,可以转型做测试咨询,创业,滴滴司机,或者外卖小哥等等都可以的,遵循自己的内心,选择想要的岗位。 四、六年软件测试心得 一)面试篇 1、多面试 不管有没有换工作的想法,建议每年都出去试一试,一方面可以多看看机会,另一方面可以结合外面的要求,查找自己的不足,让自己始终保持竞争力,不至于在公司突然裁员的时候,束手无策。 介绍几个面试的小技巧: 1)突出展示擅长项 有的同学擅长接口自动化测试,可以在面试前深度梳理,在面试中着重表现,例如熟悉Robot Framework测试框架,完成了项目从0到1的自动化测试,从环境搭建,用例编写,到CI集成,邮件发送测试报告等等,尝试引导面试官不断深入自己会的知识点。 有的同学擅长脚本的编写或测试平台的开发,项目经验可以着重描述开发的测试平台包含的功能,解决的问题,运用的技术,提升的效率等等。 有的同学擅长业务测试,对各种业务烂熟于心,项目经验则可以着重描述接触过的业务,运用的测试方法,上线质量等等。 2)用数据说话 数据,用来展示测试成果,是很有说服力的。 有的同学会自动化测试,展示成果的时候,可以描述自己实现了多少模块的自动化测试,共计多少条用例,测试覆盖率达到多少,效率提升了多少。 有的同学善于项目管理,改善项目流程,提升整个项目团队的交付能力,可以描述自己帮助多少个团队,规范了项目流程,项目交付能力提升了多少。 3)项目经验或技术能力与面试公司尽量匹配 在招聘过程中,大多数公司偏向于招与当前岗位匹配度高的人,因为来了可以快速上手,节省学习成本。 在实际工作过程中,我们接触的项目可能很多,但是在面试过程中,尽量说与当前岗位匹配度高的项目。如果项目业务不匹配,技术能力栈匹配的也可以,能增加面试的通过率。 总之,就是尽量往JD上的要求靠。 2、看面经 如果想进大厂,可以先看看大厂的JD,再去网上找对应的面经,有些面经写的很仔细,值得参考。 常见的渠道有:牛客网,知乎,公众号,简书,CSDN,测试论坛,知识星球等等。 3、投简历 投简历,建议不要海投,能内推最好了,内推拿到面试的机会是很高的,可以找自己身边的朋友,同学,师哥师姐,球友等等内推。 4、慎选择 有的人对于大厂有一种情怀,但是不是大厂的每一个部门都是很好的。进大厂,最好选择大厂的核心业务部门或项目组,不要去边缘化的小组,否则理想和现实的差别很大。 在进厂之前,建议提前找内部的人员了解,或者在面试的时候,主动询问,充分权衡好之后,再做选择。 二)日常篇 1、主动沟通 平时的工作中,尽量主动一点,比如多与开发同学沟通,可以加深对项目的理解,而不仅仅局限于对功能的测试,比如实现语言,框架,技术方案等等都可以学习。 多与产品同学沟通,而不是纯粹做一个需求文档的阅读者,多问几个为什么,比如产品的商业价值,用户的使用习惯,交互设计的逻辑等等,这些,都是我们可以精进的地方。 多与领导或部门小伙伴沟通,与领导沟通,主动表达述求,对自己的工作保持一点想法。如果自己对工作任务,或者发展方向有困惑,一定要及时与领导沟通,向领导表达自己的想法,这样,领导在分配任务的时候,会优先考虑主动申请的人。 比如有同学一直在做纯粹的业务测试,很少涉及到自动化或性能测试,而自己又想往这方面发展,可以向领导表明自己的想法,这样,后续有这方面的任务,领导会优先考虑,亲测有效。 如果有想法但是从来不向上反馈,领导也不知道我们目前的想法,就会默认对于目前的工作安排比较满意,所以有好的机会也不会轮到自己头上,还是那句话,主动就会有故事。 2、勤于分享 在工作中,分享是一项很加分的技能。 有的同学热衷于研究自动化测试框架或脚本,亦或是一些能提升测试效率的小工具,但是很少分享,只有自己在那捣鼓,独乐乐不如众乐乐,分享出来,大家一起用,既提升团队测试效率,又能在领导面前留个好印象,一举两得。 分享,其实也是打造个人影响力的一种表现,你很NB是一种本事,让大家都知道你NB,才是真的NB。 每年的分享,很多公司会作为测试人员年终KPI考核的一项指标,所以,多分享,没错了。 3、及时总结 总结,其实是一个复盘的过程,也是一个自我改进提升的过程。 测试过的项目,用到的测试工具,思想和方法,碰到的难点以及解决方法等等都可以总结记录,并以文档的形式输出沉淀,都是一个很好的积累过程。 在下次碰到同样的问题,可以有自己的一套思路,或者分享至博客,记录在公司WIKI,对他人来说,可以避免踩同样的坑,利他即利己。 今天的分享就到这里,希望对软件测试职业道路上的你有所启发,在此特别感谢@闫小林的支持和帮助,也感谢大家的互相鼓励和支持。 |
|
开发测试 最新文章 |
pytest系列——allure之生成测试报告(Wind |
某大厂软件测试岗一面笔试题+二面问答题面试 |
iperf 学习笔记 |
关于Python中使用selenium八大定位方法 |
【软件测试】为什么提升不了?8年测试总结再 |
软件测试复习 |
PHP笔记-Smarty模板引擎的使用 |
C++Test使用入门 |
【Java】单元测试 |
Net core 3.x 获取客户端地址 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/18 4:48:56- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |