有哪个开源项目,单元测试用例覆盖的比较全的?

2020-06-16 10:04:02 +08:00
fff333  fff333
希望参考下,做个模版。
7184 次点击
所在节点   Java  Java
37 条回复
asanelder
asanelder
2020-06-16 18:33:12 +08:00
@hantsy 俺在国内一下大厂的某部门待过,RD 真的是基本不写测试的(无论是不是业务逻辑),看兄台是在国外干过?国外这方面要好一些么?
lenqu
lenqu
2020-06-16 18:51:06 +08:00
我个人认为现在的单元测试 IDE 插件没有参数化的那种,如果有,写单元测试就没那么多时间消耗,而且对于项目是有益的,何乐而不为呢,主要原因是项目压太短,多一事不如少一事。
hantsy
hantsy
2020-06-16 21:08:39 +08:00
@asanelder 没有。

现在 Freelancer 多年,只接海外项目。国外绝大部分都要求写测试,有些项目明确要求,如果你没有写测试同等没完成交付。

我对测试要求只能算是一般。

1. 开发一定要写测试。不要求写测试的项目,特别是多人合作的,我不谈的。以前国内的滥泥一样开发过程让我明白,在多人协作环境下,写测试是必不可少的,不然你一天的工作 70%时间都是为一些比较渣的人擦屁股。
2. 但是不一定严格的执行 TDD, 我大部分时间是后写测试。
3. 我个人不要求 100% COV,但必须覆盖所有的业务路径,业务上的正常和异常路径,各权限都是必须用测试体现出来。

遇到过一些比较偏执的,以前一个项目本来 API 开发,用 Spring 的话自带测试工具已经可以应付。老外坚持要用 JBehave 进行 BDD 测试,费了好多力才让他接受 RestAssured (同样支持 BDD 类似的语法),当然如果是现在,我觉得 Spock 更好一些。
fuyufjh
fuyufjh
2020-06-16 21:16:39 +08:00
居然没人说 SQLite ? 14 万行代码,9000 万测试代码,100%分支覆盖率。再加上各种丧心病狂的随机测试和故障注入
death00
death00
2020-06-16 22:02:15 +08:00
入职一个大厂半年多,之前还会写一些,最近也不怎么写 UT 了。
虽然公司也要求写 UT,但在各个组内推行的比较慢。
感觉有这么几点:
1 、因为之前就没有写,对于陌生的事务,大家本能的有一种抗拒。
2 、写 UT 需要时间。每次一个需求过来,虽然排期比较宽松,但每天肯定也会处理各种各样的问题,因此开发时间也不够用。
3 、效果收益( KPI )。我感觉这个是最重要的,如果没有产生明显收益,很多人也是不会去做的。无论是你的领导还是你的组员,都背着相应的 KPI,如果没有收益,怎么汇报成果,这个可能也要和制度有一定关系。
4 、项目未来不一定是自己维护。现在大家跳槽频繁,很多项目虽然会持续很长时间,但后面不一定是自己维护,所以短期内的质量,大家感觉可以自己保障。(吐槽一点,很多连注释都没有的代码,就更不敢奢谈 UT 了)
CoderGeek
CoderGeek
2020-06-16 22:49:51 +08:00
高级脚手架 很全面
fff333
fff333
2020-06-16 22:51:24 +08:00
@CoderGeek jhipster?
hantsy
hantsy
2020-06-16 23:01:50 +08:00
@death00 我可以忍受代码没有注释,前提你写的是代码(类名,包名,方法名,参数名自身能够 Self Documentation ),但绝对不能忍受代码没有写测试。

测试不在项目一开始引入 ,基本后面是不可能再引入 ,人的惰性很难改变。一旦形成了惯性思维,几乎很难接受其他理论和实践。国内唯一可以有效的方法就是把测试纳入绩效,挠痒痒式的要求写测试肯定没人执行啦。

很人认为写测试仅仅测试代码逻辑正确性。其实嘛 ,当你写测试的过程,很多的时候是以 API Caller 身份在调用你的写的程序,最初设计的不合理的 API,在测试的调用也不方便,所以写测试(和不断重构)的过程也是一个代码优化(构架提升)的过程。

我从来不认为国内的大厂在软件工程方面有什么值得加分地方或者建树,相反一些非常恶劣的做法都引起其他公司的效仿,国内有少量注重 Engineering 基本都是小公司,开发一些小产品。
asanelder
asanelder
2020-06-17 00:32:22 +08:00
@death00 #25 强烈认同
asanelder
asanelder
2020-06-17 00:41:40 +08:00
@hantsy #28 强烈认同

1. 注释是说明意图的,能够 self documentation 最好,不能的一定要说明意图(俺看之前的遗留代码各种魔幻,可惜人已离职,你也不知道为啥添加这一段代码,改是绝对不敢碰的

2. 俺也觉得测试三大作用。一是明确验证程序行为,二是给你信心进行重构,三是站在使用者和易测试角度去设计 api,得到的 api 往往更灵活,更有好。还有一点,测试也可以做某种意义上的文档,后人来维护时,看你测试,能看到这个 api 如何使用,以及行为是什么。

3. 俺工作以前以为大厂为重视这些,但起码在俺呆过的大厂的某个组是完全不 care 的,是的,完全不 care,测试这种东西全交给 QA,RD 从不提这些。

4. 俺很后悔在学校看了一些什么软件质量的洗脑书,如果不知道这些的话,俺做牛做马,心里应该舒服很多。可现在不行了,心里还是过不了这个砍
js8510
js8510
2020-06-17 08:53:25 +08:00
据说 chrome 的覆盖 100%. 另外所有 c++ sanitizer(ASAN, UBSAN, etc) 全开。求 googler 证实。chromium 也很高,核心部分 80% 左右 https://analysis.chromium.org/p/chromium/coverage
Egfly
Egfly
2020-06-17 09:15:21 +08:00
有没有 PHP 的开源项目,单元测试覆盖比较全面的
hantsy
hantsy
2020-06-17 10:14:56 +08:00
@Egfly 多的是啊,PHP 近几年都是延袭 Java 的一套风格,特别 5.6 后,PHP 的 OOP 基本与 C#,Java 在一条线上了。很多 Java 产品都是在 PHP 世界开始 Clone, 这些优秀的框架都有完整的测试。

Java 的 Spring,EIP 在 Symfony,ZendFramework (现在改名了,一直记不住新名字,现在是 Linux 基金下的一个项目了)得到体现。
Hibernate 和 Hibernate Validator 都是 Doctrine 上克隆了。
JUnit 本身也有 PHPUnit Clone.
warcraft1236
warcraft1236
2020-06-17 14:44:36 +08:00
问个问题,如果是爬虫项目,单测都需要做啥呢?
death00
2020-06-20 11:47:34 +08:00
@hantsy
你的说法我也很认同,但对于"国内唯一可以有效的方法就是把测试纳入绩效"这点,我感觉实行起来或许有些困难。
因为如果作为绩效考核点,一定要有明确的标准和定义,这个培训成本预估也会挺大的,需要公司有决心和能力。
death00
2020-06-20 11:48:34 +08:00
@asanelder
可以往好的方面想,至少知道了一种保证工程质量的方法,而且未来也有可能可以用上。
hantsy
2020-06-20 12:12:37 +08:00
@death00 只是说说,开玩笑而已。不是别的,国内外程序员对待工作差别太大了,国内公司上班员工基本上是认同家长命令式的管理,上面怎么说就怎么做,感觉错与对的结果与他没太大的关系,当然我一直认为这是跟我们大环境有很大关系。

上层没有发话的很少人在一些事情上有自己的主见,往不好听说,有一半人上班是磨子一样,推一下转一下,有那么 10%的人连磨子都不是,怎么都推不转(这个话我前几年在创业公司说过的)。

而参与在国外的项目一些讨论才知道什么叫扁平管理,每周例会,一些要做的任务经过简单的讨论,很多都是自己认领,很少 Assign 。

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

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

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

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

© 2021 V2EX