你的项目该不该写单元测试?

我经历过的项目中有完全不写的,也有必须覆盖80%的,它们之间的区别是什么?(个人的经验可能不具备典型性,欢迎大家拍砖)

  • 项目A:先说说我开始写JSP的时候,后端struts、前端jsp,做好的一个功能,在jsp页面上刷新测试。项目也这样如期上线了,也没感觉到哪里不对。
  • 项目B:做ios和android APP开发的时候,写好一个功能后,点击run,然后在手机或模拟器上点击验证刚才写的代码。一个手机app也如期上线了,也没感觉到哪里不对。
  • 项目C:做手机游戏后台开发的时候,服务器需要向手机端提供restfull API,这个时候开始对每个API写了TDD(Test-driven development)的测试用例,每个api都必须要写。前后端是不同的人开发,这样后端开发人员在没有前端开发配合的情况下也独立完成了后端的开发。
  • 项目D:做华为外包项目时,项目很大,每个模块都是打成jar包,每个类的单元测试覆盖要达到80%。

前面几个项目差别非常大,项目A为企业信息管理系统,项目B是B2C的手机APP,项目C是手游,项目D是SaaS项目。从项目规模上来看,越大的项目越需要写单元测试,项目组中的开发人员越多,单元测试的重要性越大。从技术成熟度上看,越是成熟的开发语言和开发框架,单元测试的支持越好,比如iOS7之前估计没人写单元测试,现在估计也很多团队不写单元测试。从项目的发起者角度来看,越是大公司的项目越需要写单元测试,小公司可能由于时间和成本的原因就没写。

那你现在的项目要不要写单元测试呢,如果前后端分离的项目,后端必须要写api的黑盒测试。如果项目规模很大,模块与模块之间的API的层次很多,黑盒和白盒都需要写了。如果是一个人独立完成的简单项目,根据个人喜好来决定。

你可能感兴趣的:(你的项目该不该写单元测试?)