性能方向职业发展

市场上有各式各样的IT培训,其中门槛低易上手的就是软件测试。就业的学员通常都以功能手工测试为切入点,掌握一些基本测试理论,学会设计测试用例,能够操作缺陷管理工具,熟悉一些业务就可以开始测试工作了。大家觉得这样有技术含量吗?没有技术含量就容易被替代,你的职业就会有危机,有想过如何改变这种困境吗?下面先说说为什么要选择测试行业。

为什么选择软件测试

首要原因是薪水还不错,IT互联网快速发展增长了很多的测试工作岗位,相对其他实体经济行业薪水要高不少,拿一线城市的制造业来说,2年工作经验技术从业人员在相同的体力和脑力的工作强度下,制造业的薪水一般在30008000元,而软件测试在600018000元,2倍不止。工资回报不错,进入门槛又低,所以越来越多的人涌入这个行业。
其次大量的IT从业人员并不善长做研发或者说没有人聘用你做研发,或者并不想赚研发的辛苦钱,退而求其次选择更轻松点的测试工作。
另外还有一部分来自于开发团队,大齡女员工由开发转测试的不在少数,随着年龄的增加,结婚生子后没有过多的精力集中在研发工作上,转向工作强度轻一点,待遇还不错的测试行业。
当然也有一部分就是工作岗位需要而从事测试工作的,久而久之就停留在这个行业。

软件测试痛处

就目前国内情况来看,大多数的测试人员并没有开发和运维的技术功底,选择测试这个行业仅仅是因为高薪和入门门槛低。近年来互联网和P2P的神话,快速抬高了测试平均工资, 却没能快速提高这个行业的技术水平。在北上广深这些一线城市,从事测试特别是手工测试的从业者长期处在测试职业发展的初期阶段,容易被替代,薪资水平固定。职业生涯基本到尽头。

时常我们也能听到许多测试同学的抱怨:
(1)地位低,不受重视;
(2)待遇差,成就感低;
(3)压力大,加班,提升难;
(4)不稳定。
地位高低在任何行业都是由所掌握的技能或资源的核心价值决定,易替代、无技术含量的职位自然地位低。对于不受重视,大家不妨换位思考下,如果你是餐厅老板,你会重视大厨还是餐厅服务员更多一些呢?
相对于开发来说,测试职位的薪资水平较低,这是由工作产出决定的,工作价值高,自然收获多。但相对于传统产业来说,这个薪水已经不低。由于测试是开发后的附加工作,并没有方便量化可见的产出,自然关注者少;自己也不能左右一个项目或者产品的方向、技术、工期,在项目中并没有里程碑式的贡献,自然成绩很难突出,成就感自然不强。除非你掌握复杂的业务知识,如SAP,如财务知识,能够为项目进程提供有力支持;或者你找到了一些重大的直接影响项目上线进度的缺陷,将会避免一些损失。

工作压力大,经常加班多通常有下面几个原因:
(1)需求难以驾驭
信息社会,唯快不破,产品经理或需求人员需要高超技能与悟性来快速把握用户与客户的需求,但往往并不是这样,所以需求的朝定夕改常有发生,不仅测试工作浪费,开发工作同样浪费。时间压缩,测试无法全覆盖,迫切需要加班赶工,长时间的加班工作效率低,身体也会撑不住,还会担心问题逃逸,自然压力大。
(2)岗位处在工作流末端
软件项目研发的流程:需求调研分析-概要设计-详细设计-编码-测试软件交付准备-验收。
测试流程处在末端,工期会因为需求频繁变动而延误,也会因为开发技术问题或者态度问题而导致缺陷过多,修改过程或多或少占用了测试时间,所以测试时一般很少有充足的时间,在不增加测试资源的情况下加班赶工在所难免,学习自然成为一种奢望,还谈什么提升呢?

软件测试发展路线

前面我们谈到了测试职业的一些困境,其实大可不必悲观,因为测试的可塑性很强,还有很多其他方向可以发展,同样能够创造更高的价值,下面我们谈谈软件测试职业的发展路线。

我们暂且把软件测试职业路线分为3个方向,分别为业务路线,技术路线,管理路线; 4个象限,分别为执行层、中层、中高层过渡、高层。

  1. 业务路线
    常见业务路线的职位有QA经理、业务专家、产品经理、产品总监、行业咨询顾问等。
  2. 技术路线
    掌握编程技术,拥有业务经验,成为自动化测试工程师、性能测试工程师、软件开发工程师、安全测试工程师、系统分析师、测试总监、研发总监等。
  3. 管理路线
    积累业务知识或者提高技术储备,能够出色地完成本职工作,负责带领团队;岗位一般有测试Leader、测试主管、测试经理及测试总监。

执行层:
1.软件测试——功能(初级——专职过渡阶段)
2.软件测试——性能(专职)
3.软件测试——自动化(专职)
4.软件测试——安全(专职)
5.软件测试——白盒(专职)
6.软件测试——业务(专职)
7.软件测试——小组长、主管(管理路线)
8.软件开发(专职)
9.质量保证工程师SQA(专职——业务线)

中层,中级执行管理领导:
1.测试分析师(专职——领导过渡阶段)
2.测试架构师初级(专职——领导过渡阶段)
3.测试经理(执行领导——管理路线)
4.QA经理(执行领导——业务路线)
5.产品经理(执行领导——业务线)
6.项目经理(执行领导——技术路线)
7.系统分析师
8.测试培训师

中高层过渡:
1.测试总监(执行领导——高级领导)
2.产品总监(业务路线)
3.行业咨询顾问(业务路线)
4.研发总监(技术路线)
5.项目总监(技术路线)

高层:
1.CQO——首席质量官
2.CTO——首席技术官
3.CIO——首席信息官
4.CEO——首席执行官

不仅仅是性能测试

随着国内软件质量体系的健全,企业逐渐意识到软件测试质量不单单是满足功能流程顺畅就行,测试效率和用人成本的降低也是趋势,更要为软件的稳定和易用性等质量保障来提高产品黏性留住用户。可以这么说,一个成熟的大型产品必须有过关的性能测试把关,这不是一个简单的事情,从需求、架构、硬件、数据库、代码等层面都需要精心设计和测试。
那么如何提高职业技能和核心价值从而赚取更多的劳动报酬?后续测试的职业发展会碰到哪些问题,测试的捷径在哪里?
全栈一般是技术方面的领导者,需要涉猎广?懂得如何解决问题以及对应所需的技术和工具。但具体的细节掌握比不上某个学科精专的。但是他们有强大的学习能力,会较多依赖搜索或即时学习,会根据需求,依托自己扎实的基础功底,把某一项或者 二项技能达到接近于专科人员的能力。全栈是学习能力强,总结能力强、不断总结和融会贯通提高实战能力,善于分析因果并找到原因和解决方案的复合人才。
我个人认为全栈测试比纯测试更有未来,因为测试很多时候就是个“万油精”。虽然全栈要掌握的知识点很多,精力不够是其弊端。想要某一项做到专业级, 花费的精力更多了。但是顶尖的优秀人员永远是少数,市场的高薪也是为那些20%的人员所留。更为重要的是目前是一个复合人才,跨界人才当家的年代。越来越多从软件测试走到测试总监、技术总监、CTO等高级技术管理类复合人才的比例越来越多。

我们看看除了测试还需要掌握哪些基本功。
1、需求
我们的行业存在的根本在于实现用户的业务需求,客户或者产品的需求变化引起的系统需求的频繁变更,在项目周期本就不宽裕的情况下,间接导致测试人员工作量的增加从而导致测试人员加班现象越来越严重。
在实际的性能需求分析过程中,系统分析师必须清醒地认识到客户很难区分业务需求和用户需求的差别,搞清楚客户背后的真正的业务需求。可以说,软件工程中的“需求分析”就是确定要计算机“做什么”,要达到什么样的效果。可以说性能需求分析是做系统性能测试前必做的,不然没有方向。

2、代码
在测试过程中懂程序的人更能够深入地把程序测试好,通过走读代码发现逻辑上的缺陷、写法上的繁琐带来的性能问题等,达到事半功倍。系统难免会与数据库打交道,数据库知识也不可少;程序部署在中间件上,中间件知识也是必备的;中间件运行在操作系统上,操作系统及硬件知识也不可少。

3、运维
测试自动化是一个趋势,不仅包括功能测试自动化,也包括性能测试自动化及测试环境自动化(持续集成),掌握运维手段也变成必要。另外,对于系统涉及的中间件、数据库、缓存等产品也要熟练运维。
所以要想在测试行业中脱颖而出的关键还是技术,流行的一句话:测试人员懂开发最好,开发人员懂测试最好,自然更受欢迎,价值更高;也就是技术不错,能够跨界。而测试的各种岗位尤以性能测试涉及的知识面最广,涉及程序开发、数据库、中间件、操作系统、硬件知识等内容,基本是照着全站测试的模板在培养,突破手工测试选择性能测试是一个好的方向,有了这个技术积累就不仅仅是做性能测试,亦开发,亦测试开发(自动化),亦架构,亦性能测试。

从招聘要求看岗位价值

下面我们看一下性能测试及性能架构师/专家的招聘要求就可以知道职位对技术的要求范围与层次。

1、金融行业
案例一 上海 某金融平台性能安全工程师
任职资格:

  • 熟练数据库编程,能熟练操作至少一种数据库,如Oracle或MySQL;
  • 精通LoadRunner、Jmeter等主流性能测试工具之一,熟练编写相应测试脚本,测试过复杂应用着尤佳;
  • 深入了解HTTP、TCP/IP等网络协议,熟悉J2EE Web系统,熟练掌握多种中间件(Tomcat、Apache、Nginx、MQ等)各项性能参数设置、监控及优化;
  • 精通各类常见的安全问题、测试方法及解决方案,对业界安全动态保持较高的敏感度;
  • 精通渗透测试,熟悉安全测试方法,熟练掌握各种安全测试工具,精通常见安全攻防技术;
  • 具备编码能力,会使用JavaBean Shell等各类脚本语言中的一种或几种进行脚本开发;
  • 优秀的分析问题和解决问题的能力,对解决具有挑战性问题充满激情。

案例二 深圳某银行支付业务初级性能
任职要求:

  • 计算机相关专业,3年以上工作经验,至少1年B/S性能测试经验;
  • 熟悉主流性能测试工具的使用,如LoadRunner、Jmeter等;
  • 熟悉Linux操作系统,掌握至少一种主流数据库的使用;
  • 精通Java/Python/Scala等其中一门开发/脚本语言,能够参与开源工具的二次开发或独立研发部分测试工具。

案例三 某银行性能测试专家(深圳)技能要求

  • 具有扎实的Java或Python语言基础;
  • 具有2年以上性能测试的经验,承担过大型系统的性能测试和调优者优先;
  • 能独立开发性能测试框架、工具和脚本;
  • 熟练使用主流的性能测试工具,至少精通一种工具,如LoadRunner、Jmeter;
  • 具备性能测试需求分析、设计规划能力和分析性能测试数据的能力;
  • 熟悉各种常见的系统和数据库性能监控工具;
  • 熟悉Linux操作系统;
  • 熟悉常见的网络协议,熟悉各种中间件服务器;
  • 熟悉MySQL和Oracle等数据库的知识及操作。

案例四 证券公司性能测试技能资格要求

  • 能够搭建性能测试平台;
  • 能够独立完成性能测试工作;
  • 能够分析数据,并编写实际有效的性能测试报告;
  • 善于发现性能瓶颈,并给出指导意见,协助完成性能调优;
  • 能够独立编写SQL、数据库脚本,并分析、优化数据库脚本;
  • 精通测试理论,流程与方法,熟练使用主流的性能测试工具,如LoadRunner/JMeter等;
  • 具备Java、PHP等编程经验,并具备Python等脚本开发经验。

2、其他行业
案例五 通信公司性能测试技术要求

  • 具有扎实的Java或Python语言基础;
  • 承担过大型系统的性能测试和调优者优先;
  • 能独立开发性能测试框架、工具和脚本;
  • 熟练使用主流的性能测试工具,至少精通一种,如LoadRunner、JMeter;
  • 具备性能测试需求分析、设计规划能力和分析性能测试数据的能力;
  • 熟悉各种常见的系统和数据库性能监控工具;
  • 熟悉Linux操作系统;
  • 熟悉常见的网络协议,熟悉各种中间件服务器;
  • 熟悉MySQL和Oracle等数据库的知识及操作。

案例六 旅游行业某知名旅游公司测试技能资格要求

  • 熟练掌握LoadRunner/Jmeter等至少一种主流性能测试工具,有丰富的HTTP/Web Service/Java User协议经验;
  • 熟练Oracle/MySQL/SQL Server等至少一种数据库,能够使用工具观察数据库性能;
  • 熟练使用Linux系统;
  • 优秀的分析问题和解决问题的能力,沟通表达顺畅,能够承受较大的工作压力,有大型网站性能监控经验者优先。

案例七 某著名游戏公司技能资格要求

  • 熟练使用常见性能测试工具,如LoadRunner、JMeter;
  • 熟练HTTP、Web Server、TCP等常用协议;
  • 具备良好沟通能力;
  • 具备团队精神、富有工作热情和责任感;
  • 有游戏行业从业经验者优先。

案例八 某影视平台测试技能资格要求

  • 熟练使用LoadRunner/JMeter/Ngrinder等性能测试工具,有二次开发经验优先;
  • 掌握业内常用的监控工具,例如Nmon、Nagios等,能够通过脚本实现特殊指标采集监控;
  • 熟练使用Linux系统;
  • 熟练掌握MySQL、mongodb等常用数据库系统的操作,能熟练编写复杂SQL语句;
  • 能够独立完成工作,有很强的责任心,做事严谨,良好的书面表达和工作总结能力;
  • 较强的沟通、协调能力、分析问题和解决问题能力;
  • 有大型网站性能测试经验者优先。

从上面的招聘条件可以看到,作为一个高级的性能测试工程师,我们需要掌握的基本技能很多,需要掌握如下知识:

  • 精通测试理论;
  • 熟练使用性能测试工具;
  • 熟练Linux操作系统及相关服务器的监控工具及配置管理;
  • 具备Java、Python开发经验,最好能开发性能框架、工具等;
  • 熟练数据库SQL或ETL,能够进行SQL调优,能熟练操作至少一种数据库(Oracle、MySQL等);有NoSQL数据库(Redis Hadoop等)经验优先;
  • 熟练常见的网络协议;
  • 熟练各种中间件服务器;
  • 熟练数据分析、善于发现性能瓶颈,并给出指导意见,协助完成性能调优;
  • 有UI自动化、接口自动化、App自动化测试经验的优先。

性能测试技能树

测试工具

通过测试工具能提高测试软件开发速度,腾出时间专注于问题分析。主流工具有LoadRunner与JMeter,当然了,工具也不能解决所有问题,有时候还是需要自己编写程序来实现测试脚本。很多初学者认为这2个工具只能用来做性能测试,其实能做性能测试的工具也可以做功能自动化回归、API和UI测试等都可以实现。不是非得Selenium、WebDriver等才能做自动化测试。

  常见难点
  1.用户和业务模型分析搭建;
  2.合适的脚本开发(大部分初学者不根据用户和业务模型来开发脚本,认为要回归成功即可);
  3.合适的需求分析转化为场景设计(大部分初学者不知道如何根据需求进行场景设计);
  4.大容量系统的数据生成和使用;
  5.大型系统的性能压力负载和实施;
  6.云计算的负载生成和实施。

测试基础

性能测试是一门富有挑战性的、有深度的、综合性的学科。
很多性能测试初学者总觉得性能测试就是写个脚本,弄几台机器压一压,出个报告就行了。通常关注“并发多少”“响应时间多少”“能跑通吗”这些问题。认为并发越大,响应时间越快,那性能一定就越好。
性能测试不仅仅是录制脚本或者编写程序,基本的性能理论、性能执行的原则还是要了解的。同样的脚本,不同的人员执行,不同的针对点,测试结果会大相径庭。
实际上我们需要对系统进行一系列复杂的需求分析,以及一系列性能测试计划和设计的工作才能开始性能测试执行。经过N次回归,找到瓶颈的具体原因,并优化。掌握性能理论基础才能驾驭那些性能测试工具等,没有掌握性能理论基础直接操作好比开车找不到目标,盲目原地打转或离目标越来越远。
自动化测试的目的是为了提高工作效率,目前,功能测试与性能测试都朝着这个方向发展,这些都是持续集成的一份子。
鉴于目前行业内普遍项目时间紧,性能测试架构师在公司担任性能测试、自动化测试等多种角色,那么减少加班和追求高效益和搞成就是我们全栈性能测试工作者的追求了。

  常见难点
  1.评估需求;
  2.负载建模(用户与业务模型);
  3.性能压力生成的原理和并发等之间的关系;
  4.性能测试用例;
  5.新系统需求分析;
  6.容量规划;
  7.性能测试策略。

代码

作为IT部门的一员不可避免地要和开发代码打交道,了解编程知识既能提高测试内涵,还能提高交流沟通的效果。更重要的是,做自动化测试、单元测试、性能测试、安全测试都离不开代码。所以我们还是要掌握一些普及率高的编程语言和脚本语言。这里我们推荐Java、Python等。
Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,目前也是国内公司使用的相对普及的语言。
Python具有丰富和强大的库。它常被称为胶水语言,能够把用其他语言制作的各种模块(尤其是C/C++)很轻松地联结在一起。Python是目前国内测试行业比较热门的一门语言,很容易上手,也可以搜索公共库的代码来缩减自己写代码的工作量和时间。

服务器性能诊断知识

不管我们的程序如何高大上,不管我们用什么语言实现,最终还是要依赖服务器硬件,依赖数字信号,依赖模拟电路。服务器硬件是性能之本,所有性能都会反映到硬件指标上来,我们想要分析性能,服务器知识少不得。服务器几大件,如CPU、存储、内存、网络的性能指标,监控方法都需要熟练掌握。管理这些硬件的操作系统的原理,性能配置参数也需要掌握。要掌握这部分需要学习很多运维和开发知识。
了解操作系统及其内核对于系统分析是至关重要的。作为性能测试工程师来说我们需要进行对系统行为做分析:系统调用是如何执行的、CPU是如何调度线程、有限大小的内存是如何影响性能的,或者是文件系统是如何处理I/O的,这些都是我们判断系统瓶颈的依据和线索。

1、Linux
Linux是一套免费使用和自由传播的类UNIX操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了UNIX以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。越多越多的企业用这个系统作为服务器的操作系统,所以作为性能测试从业者来说,是必须掌握的系统之一,搭建环境、性能诊断是离不开它的。
目前Linux/UNIX的分支很多,普及率比较多的有CENTOS、Ubuntu、RedHAT、Red HatHP-UX、AIX、Solaris等。

2、Windows Server
Windows Server 是 Microsoft Windows Server System(WSS)核心,是服务器操作系统。目前使用比较多的都是中小型公司,目前2008和2012版本相对比较多。

数据库是我们系统存储处理的最重要的手段,很大一部分性能问题都牵扯到数据库。所以我们需要深入地了解掌握数据库的语言SQL,以及常规的性能诊断和调优手法。
数据库目前有很多,关系型的如DB2、Oracle、SQLSercer、MySQL等,更有非关系型临时键值存储(memcached、Redis)、永久性键值存储(ROMA、Redis)、面向文档的数据库(MongoDB、CouchDB)、面向列的数据库(Cassandra、HBase)Hadoop等。

3、Oracle
Oracle Database,简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的适应高吞吐量的数据库解决方案。

4、MySQL
MySQL是Oracle收购的一个轻量型开源数据库,越来越多的公司为应对日益增长的数据库规模,在原有的基础上二次开发分布式数据库,也是目前国内比较流行的数据库。很多大型公司也在MySQL的基础上进行了分布式的开发,MySQL的能力被大大增强。

5、NoSQL数据库
NoSQL,泛指非关系型的数据库。随着互联网Web2.0网站的兴起,应对超大规模和高并发的网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题。NoSQL有很多种类型,我们来一起了解。

  1. 键值数据库——Redis
    支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,它提供多种语言的API。其特点是每次存储一个数据时,是根据Key进行索引存储的。Redis适用于数据变化快且数据库大小可预见的应用程序,股票、数据分析、实时数据搜集、通信等。7月阿里云宣布推出了自己的Redis云数据库KVStore for Redis,应用于游戏、电商、社交等行业。
  2. 列存储数据库——Cassandra
    最初由Facebook开发,于2008年转成开源项目。它是混合型的非关系数据库,在网络社交云计算方面应用较理想,读操作比写操作快很多,较适用于银行、金融、数据分析等领域。
  3. 文档型数据库——MongoDB、CouchDB
    文档型数据库的灵感来自于Lotus Notes办公软件,而且它同第一种键值存储类似。该类型的数据模型是版本化的文档,半结构化的文档以特定的格式存储,如JSON。文档型数据库可以看作是键值数据库的升级版,允许之间嵌套键值。而且文档型数据库比键值数据库的查询效率更高。

图形结构的数据库同其他行列以及刚性结构的SQL数据库不同,它是使用灵活的图形模型,并且能够扩展到多个服务器上。许多NoSQL数据库都有REST式的数据接口或者查询API,如Neo4J、InfoGrid、Infinite Graph。

  常见难点
  1.进程、线程任务之间的区别?
  2.线程的中断优先和原理?
  3.进程的生命周期?
  4.上下文切换?
  5.I/O密集型和CPU密集型工作负载之间有什么区别?
  6.生产环境和测试环境之间换算?
  7.关系型数据库体系结构和逻辑优化与非关系型数据库体系结构和逻辑优化?
  8.事务数据库和分析数据库的使用?
  9.数据关系建模与设计?
  10.TOP N SQL 诊断和优化(执行路径、索引和表链接优化等)?
  11.阻击和根治阻塞和死锁?
  12.热点防范和定位优化?
  13.业务数据批量缓存化异步化?
  14.数据库配置优化?

性能调优技能

面对一个性能不佳且复杂的系统,我们做的是建立性能数据分析模型、收集相关资源和指标信息、分析这些数据背后可能的原因。很多人说性能测试最难的就是定位性能瓶颈,笔者赞同这种看法。这需要扎实的全栈IT技术基础和业务敏感度以及解决经验。
另外性能优化是一个系统工程,内容涉及系统各方面,从上到下有软件产品(项目)、中间件、虚拟机、操作系统、硬件。软件产品有系统架构、业务设计、代码实现、数据库物理设计及数据库各种配置等。所以想要做好性能调优,不仅仅是一个人的事,而是整个项目团队的事。
对于测试来说,不管是脚本实现,还是测试过程中的网络监测,都需要针对通信协议;常见的HTTP/HTTPS、Socket/WebSocket、WebService(Soap)等协议运用广泛,自然要熟悉。

  常见难点
  1.系统硬件资源(CPU、网络、内存、IO)相互之间的关系及原理;
  2.选择可靠性能指标及指标之间的关联和判定方法;
  3.永不宕机的实现原理和常见错误;
  4.排队系统与延迟及缓存的优化关系;
  5.优化的成本和性价比;
  6.业务优化的操作实施;
  7.多系统串联原理及测试隔离。

自动化/持续集成

当下流行的持续集成工具有Jenkins、Git/SVN、Maven、Ant等
利用Jekins、Hudson等持续集成工具将我们性能测试搭建环境、执行等时间大幅缩短,无效率工作重复次数也大幅降低。持续集成可以帮助我们自动化代码集成、环境集成、自动测试执行和储存和整理测试报告。

云计算及虚拟化

通常基于虚拟化技术,允许一个用户或多个用户共享一个物理服务器。虽然给我们中小企业带来很多的便利,但这会引起资源的竞争以及性能测试的难度。架构的不确定性、其他网络等硬件资源的成本限制、云上性能负载机的额外开销等。部分云服务商提供新型云服务收费性能测试工具,我们可以在本地开发测试完毕后,再部署到云上。

小结

科技是第一生产力,选择技术方向的从业者来说技术是第一生产力,不妨碍着全站测试行进,可以先从性能测试入手,目前对性能测试工程师的要求就是全栈的要求,可以看到性能测试的招聘条件中往往都包含了测试开发,自动化开发要求,这充分说明了这个岗位对于测试的重要性。这样的技术要求决定了你在整个测试团队中必须是高能力者,至于工作回报自然丰厚。

原文地址:https://www.cnblogs.com/TD1900/p/12889809.html