首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
宝塔
V2EX  ›  问与答

单元测试要测试错误的流程么?

  •  
  •   m939594960 · 2018-03-22 10:37:18 +08:00 · 1216 次点击
    这是一个创建于 609 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如用户输入的金额为负数的时候抛出异常这种的测试需要进行么?

    因为我看主流的开源项目好像基本都是测试正确的流程,没见过有测试错误流程的代码。

    但是我感觉测试错误流程的地方也很有必要

    第 1 条附言  ·  2018-03-22 11:39:16 +08:00
    哈哈,看来这个问题很多人都有完全不同的见解。。。
    12 回复  |  直到 2018-03-22 14:33:13 +08:00
        1
    Moorj   2018-03-22 10:54:07 +08:00
    我是会测的,但我是人肉测,我不会单元测试
        2
    whypool   2018-03-22 10:58:45 +08:00
    测试正确流程,断言判断期望的正确值
    异常一般不写单元测试
        3
    hahastudio   2018-03-22 10:59:59 +08:00
    如果异常是接口约定的一部分,应该要写的吧?
        4
    dtgio   2018-03-22 11:01:37 +08:00 via iPhone
    这样不就成了单元测试的单元测试了吗?
    子子孙孙无穷尽也?
        5
    gamexg   2018-03-22 11:07:24 +08:00
    订单类绝对要测试入户输入负数的情况是否能够拦截,否则小心被人玩坏。
    记得乌云还在的时候可以看到很多负数商品数量的订单。
        6
    iyaozhen   2018-03-22 11:09:07 +08:00 via Android
    额,你见的哪个开源项目只测正常流程?
    异常流程也重要。单测指标:分支覆盖率了解一下。只测正常流程覆盖率很低的。
    输入是负数代码也应该有逻辑分支去处理,输出也是有确定预期的。
        7
    mikuazusa   2018-03-22 11:10:02 +08:00
    肯定要啊,有一条原则:“永远不要相信用户输入”,这算是测试的基础吧
        8
    chenuu   2018-03-22 11:10:57 +08:00
    前东家不同逻辑分支覆盖率要到 75%
        9
    otakustay   2018-03-22 12:58:49 +08:00
    抛异常是你预期的一部分么,是的就要测。你不预期用户会输入负数,那自然不测
        10
    airyland   2018-03-22 13:50:34 +08:00
    这类格式可以不用全部过单元测试,但是逻辑要写,类似代码逻辑可以只测试一两个确保判断的公用校验函数无 bug。其他类似的 if 格式判断,出于提高覆盖率的目的使用 istanbul ignore if。
        11
    Mutoo   2018-03-22 13:52:08 +08:00
    这是单元测试中的边界测试,非常重要。只测正确的流程,代码覆盖率很低吧。
        12
    Hstar   2018-03-22 14:33:13 +08:00
    为了测试覆盖率,只测那些有特殊异常处理逻辑的异常,一些莫名其妙抛出来的异常不管
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4110 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 25ms · UTC 03:29 · PVG 11:29 · LAX 19:29 · JFK 22:29
    ♥ Do have faith in what you're doing.