工作 5 年,后 3 年都重复着前 2 年?写在离职百度之际(QA 篇)

2021-04-02 14:26:16 +08:00
 iyaozhen

最近各种原因换了个工作,回想起来校招(实习)就进百度了,一晃 5 年多了。最近又宣传“十四五”,也想着自己确实得好好总结下这五年,而且市面上做 QA 的比较少,希望能对新同学有些帮助。

原文链接: https://iyaozhen.com/work-first-5years.html

重新 review 下工作

做程序员这一块,可能都会遇到第一个瓶颈,工作前 2 两年成长很快(特别是 QA,都是现学),但后面就慢了,感觉重复着之前的工作。这里以“捕鼠器案例”为引子,重新捋一下 QA 的工作:

工作第 1 年

刚工作接到的任务一般比较简单、直接,比如导师可能叫你去放一下捕鼠器。这个时候你一般看看文档,多观察下,就知道捕鼠器是用来捕老鼠的,你只要不给它挂在墙上就行。甚至前人已经放过捕鼠器了,你只要依样画葫芦隔一段距离放一下就行了。

这个时候你就要稍微总结下了,放捕鼠器为什么有时没捕到老鼠,你可以会观察录像,看别人的捕鼠器怎么做的,这个时候稍作改进就会效果明显。具体的到 QA 的工作,你现在已经非常熟悉这块的业务,每次小功能的测试都游刃有余,而且通过学习你还会了 API/UI 自动化测试,效率也变高了。

工作第 2 年

由于表现还不错,你已经晋升为 T4 了。这个时候你会发现只放好老鼠夹子效果还是不好,具体到工作可能会发现线上还是有很多问题。你一想,捕鼠器是干啥,消灭老鼠,但消灭老鼠,不仅仅只有捕鼠器一种方法,或者说一种方法不够。

当一个人从完成任务到解决问题,能够再问一步,这个问题关联的问题是什么,进而去提出新的问题,这就是关键的突破点。

你可能会发现老鼠药更管用。类比测试工作上来说,你引入了更多的测试方法:diff 测试、性能测试、稳定性测试、兼容性测试、安全测试、ET 测试等,工作开始变的顺风顺水。

工作第 3-5 年

这个时候你测试环节已经做的很不错了,能负责一个系统或者业务方向的测试了,一般的话也晋升为 T5 (高级测试工程师)之列了。但这个时候就开始重复之前的工作了,项目不停迭代、新功能测也测不完。而且随着需求积累,回归测试也很多了,因此对于 QA 来说这种重复的感觉比 RD 、FE 更强烈。

这个时候还得回到原点来,捕老鼠是为了什么?为了保护粮食。那 QA 找 Bug 是为了什么?是为了“质量”。这个时候引入一个非常重要的概念:全流程质量保障。作为 QA ( Quality Assurance,质量保障),自己把自己定位成测试是不行的。

全流程质量保障

可能每个公司的项目流程都不一样,但都会包含以下几部分,当你跳出“测试”来看,就会发现能做的事情还有很多。

需求阶段

有些同学觉得需求不都是 PM 、RD 的事情嘛,QA 能干啥。往小了说,参与需求评审能了解需求的来龙去脉,方便我们设计测试 case 。往大了说,有时候 Bug 多、上线 delay,是需求不靠谱,PM 可能只考虑自己这块的功能,实现起来需要复杂的周边改造配合,不必要的提高了整体复杂度,这时可以建议 PM,换个思路来满足用户的需求。

开发阶段

大量工程经验告诉我们,Bug 发现的越早,修复成本越低。我们不光要督促 RD 做好单测,还得深入参与方案设计评审、code review,提供完善的自测 case 帮助 RD 自测,总的来说就是尽早的发现问题。

测试阶段

此时才到具体的测试,除了做好测试本身外。我们更多的可以关注到 CI (持续集成)来,比如我们的自动化 case,可以在 RD change 代码阶段就运行一些核心 case,拦截低级问题,合入后运行完整的测试 case 。并不断的提高测试覆盖率( case 运行完后覆盖了 RD 代码多少分支)。还可以性能测试例行化,发现版本间性能变化。最终能做到只要流水线通过,就能有底气让 RD 直接上线。

发布阶段

发布肯定也不只是 RD 、OP 的事情,别的不说,上线后的验证 case,就需要 QA 提供完善。发布流程上也有很多提升质量的方式,比如灰度、A/B 测试、众测、单节点 /单机房小流量等,还有完善的回滚机制。这样问题即使出现也能控制影响范围。

线上稳定性

前面都做的很好,但线上问题(可能不是直接的 Bug )多,这更直接影响用户体验,更体现质量差,所以线上稳定性 QA 也需要重点关注。

发现问题要快,相关业务拨测、日志监控是否完善?一般公司都有相关平台,没有的话需要推进建设。 定位问题要快,比如相关日志 logid 是否能够串接起来,日志信息打印是否规范?不求找出确切问题,但需要知道大体原因,方便执行下一步策略。 兜底策略时候完善,线上问题往往来势汹涌,还来不及查问题就已经挂了。这个时候如果近期有代码变更,回滚策略是否完善(线上问题止损第一位)。上下游重试 /熔断机制是否合理?机房切流是否有预案?

数据说话

研发质量、效率,产品效果有时候比较主观,虽然不支持唯分数( KPI )论,但基本的数据分析和度量还是要有的。比如功能埋点数据如何上报,如何保障用户隐私,如何测试埋点数据能满足 PM 的需求。研发质量如何度量?比如可以分析发现 Bug 的类型,是否可以针对性改进,发现 Bug 的阶段是否靠后导致 RD 修复风险大,提测打回率,漏测率等等。线上运行情况如何,比如可以建立 SLA 体系,及时或者定时报告质量情况。还可以结合日志平台,收集各个模块调用数据,能全盘看见整个微服务的情况。方方面面还有很多,更广的就涉及到了 BI ( Business Intelligence )、EE ( Efficiency Engineering )的范畴了。

这部分没有强调某个技术具体怎么做的,比如百度 QA 自动化测试怎么做的,因为 QA 发展了那么多年,特别是在 BAT 这种大厂,自动化测试各类的技术已不是高阶 QA 主要能力瓶颈和测试技术短板。更看重产品的全生命周期的质量保障,从尽早发现问题,到缺陷预防,到减少发布后遗漏问题的影响都是 QA 投入的重点,也是在百度(或者公司)不可或缺的核心价值。整个流程粗略一看能提升质量的地方就很多,干好其中几项自然就升到 T6 了。这里一定要注意不要为了晋升而做事情,晋升应该是水到渠成的。

到了这时,其实我们可以再想想一开始的问题,保障质量最终又是为了什么呢?

所以说再往上,你可以跟更高的目标去对齐,你的能力,你发挥的作用也会更大。首先需要了解目标是什么,评估方法是什么,怎样去改进,走成一个正循环。

机遇和努力

当前互联网环境还是偏浮躁,很多新同学会问,机遇和努力哪个更重要呢?答案肯定是机遇更重要,但机遇是可遇而不可求的,因此我们只能更加努力。保持一颗平常心,吃饭时好好吃饭,睡觉时好好睡觉(毕竟现在想着年前为什么不把基金卖了也没啥用),先把当前的事情做好,仰望星空,脚踏实地,有助于我们克服“内卷”的焦虑。

参考资料

见原文链接


广告分割线(大家友善讨论,主要还是想分享点个人感悟)

虽然说机遇不可求,但我们还是可以选择的,我现在所在的团队(字节跳动-飞书),大量招测试开发工程师,各个级别都需要(含实习生),leader 也需要,全国大城市可选。yaozhen.00@bytedance.com

PS:最近换 logo 和造车的小米公司就是用的飞书哦。

7905 次点击
所在节点    程序员
30 条回复
revalue
2021-04-02 22:13:41 +08:00
小厂 觉得和 大厂差不多,思想方法论也差不多,但是大厂更规范。大厂工作流程基本具备,qa 可以更加专注于工作和目标,没有那么苦逼
revalue
2021-04-02 22:15:34 +08:00
大厂只要想做,基本上都能开绿灯,最多就是求人求领导,只不过是时间的问题。小厂想做一点长远的东西极其缺乏资源,就要求天求地了
iyaozhen
2021-04-02 22:30:38 +08:00
@revalue 这么说也是的。大厂就怕你没想法,还得找一些技术方向来做
hugo54
2021-04-03 00:36:40 +08:00
目前百度校招 QA 第一年,从入职一开始团队就强调全流程质量保障,看到楼主的文章很共鸣的。
楼主提到的每一个阶段对于 QA 来说都大有可为, 只是身在业务部门,日常测试工作繁忙,时常感到有心无力。
clip
2021-04-03 11:25:07 +08:00
同组 be 帮顶
iyaozhen
2021-04-03 15:26:47 +08:00
@hugo54 你这第一年不急,总是要先做好事情,建立信任,让导师、组内高工看见你有能力和意愿干一些大事。

说个不恰当的,“一将成名万骨枯”,现在百度 QA 几乎没有做平台的组了,都下放到业务了,必然大部分人还是得抗业务压力,QA 做个什么高大上的东西,但最终的价值也要体现在对业务的贡献。
iyaozhen
2021-04-03 15:34:19 +08:00
@clip 哎呀 刚来,好多还不知道,后面工作中多照顾。
godbasin
2021-04-06 09:59:27 +08:00
@evilStart 还好哇,除了周三早下班六点半,其他时间比较自由,自己忙完了就走了
d873139022
2021-04-06 16:10:24 +08:00
QA 真的要有同级的开发水平嘛,感觉小公司的话,这不直接转到开发序列了嘛
iyaozhen
2021-04-06 19:20:22 +08:00
@d873139022 这个稍微夸张了一点,但至少 QA 负责人是和同级别 RD 差不多的。我内部转过 RD,对方特别欢迎,都面试和双方 HR 通过了,但最后没去

薪资 QA 可能略微比 RD 低一点,但工作内容上各有各的好,就像前面说的社会主义建设分工不一样。这个就看个人了。

当前这一切都是在 TOP N 的大厂前提下

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/767544

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX