聊一聊前端单元测试(unit test)

单元测试 unit test

单元测试是测试中最常见的也是最基础的一种测试模式,对于前端代码来说,这个“单元"的边界粒度可以是某一个组件或者某一个工具函数;在服务端代码,就可以是针对某一个接口或一个中间件进行测试编写

为什么要写测试?

保证重构时代码的正确性、程序的安全性。 举个例子:某一天需要对原有代码模块进行修改,改完之后不确定是否会对其他模块造成影响,或者破坏原有的逻辑,跑一遍单元测试就能自动地帮助开发者校验代码逻辑的正确性。
帮助开发者完善代码逻辑。 举个例子:在编写一个函数代码的时候,可能开发者只考虑了最基本的情况,并在项目运行时通过了,就主观地认为程序是正确的了。然后在写单元测试,编写测试案例的时候,就得考虑一些边界情况、异常情况等等,这个时候返回去看之前的代码时候,就能发现之前遗漏的一些逻辑并进行完善。

怎么编写单元测试?
  • 首先要确定好单元的范围,单元测试必须是针对独立模块的测试
  • 编写测试案例(test case),在我看来测试案例可以分为几种等级:
    • 最基础的案例就是输入一个正确的参数时,能够得到正确的输出;
    • 再升级一点的案例,就是在输入参数导致代码异常时,能够得到处理异常后的结果,而不是让代码错误的结果直接是系统异常而出现;
    • 再再升级一点的话,可以针对极端情况和边界情况进行编写测试案例。
  • 代码分支(branch),代码分支最简单的理解就是代码里的if else,不同的判断条件能够得到不同的输出结果,那么在进行测试编写的时候,不同分支的结果都要覆盖到
  • mock数据,单元测试执行过程中,如果遇到一些网络请求、文件I/O等副作用函数,建议使用mock模拟返回数据。最主要的是不能出现因为网络异常的情况,导致测试挂掉了,测试挂掉的情况一定要是代码程序出问题,而不是外界条件出的问题。
哪些代码需要写测试
  • 我的观点是:并非所有代码都需要写测试,并且不同模块代码写测试时,所需要的测试案例的等级可以是不同的。
  • 核心模块的代码,测试案例等级必须很高,而相对没那么重要或者逻辑并不复杂的模块,可以降低测试案例等级;而一些特殊模块,比如我们暴露给k8s的健康探针(仅仅是一个hello world的简单接口)完全可以不用写测试了。
  • 但这些模块优先级,完全是开发人员在针对自己维护的系统,自己来决定了。
测试覆盖率
  • 这项指标并不能和项目质量直接挂钩,100%的覆盖率并不能保证你重构代码时完全没问题。
  • 要求严格一点的话,可以在CI/CD中可以把覆盖率作为检验指标设置上去,具体阙值可以针对项目交付压力和人员情况做具体调整。
  • 不要为了测试覆盖率数据好看,而去写一些意义不大的测试,针对具体情况去写测试
测试框架和工具库
  • 顺便再说说我之前用过的一些前端测试框架和工具:
    • jest自带断言库的测试框架,有对应测试typescript代码的ts-jest
    • sinon模拟接口返回
    • mocha一个更容易扩展的测试框架,需要另外单独安装断言库(一般使用chai)
写在最后
  • 对技术有追求的人都会觉得写测试是理所当然的,没有任何测试代码的项目绝对不是一个高质量的项目
  • 但是写测试的时候也要考虑成本,比如创业项目在需要迅速上线并且开发资源紧张的时候,是否一定要写测试,那也是需要进行权衡的
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269