单元测试和集成测试有什么区别?

What's the difference between unit tests and integration tests?

本问题已经有最佳答案,请猛点这里访问。

单元测试和集成测试有什么区别?

这些测试有不同的名称吗?像一些调用单元测试功能测试的人一样?


单元测试是由程序员编写的一种测试,用来验证一段相对较小的代码是否正在执行其预期的操作。它们的范围很窄,应该易于编写和执行,它们的有效性取决于程序员认为有用的东西。这些测试是为程序员而设计的,它们对其他任何人都不是直接有用的,但是,如果他们做了自己的工作,测试人员和下游用户应该从看到更少的错误中获益。

作为一个单元测试的一部分,意味着在测试代码之外的东西是被模仿的或者被删掉的。单元测试不应该依赖于外部系统。它们测试内部一致性,而不是证明它们与一些外部系统很好地配合。

进行集成测试以证明系统的不同部分协同工作。集成测试可以覆盖整个应用程序,它们需要更多的工作来组合在一起。它们通常需要为它们分配数据库实例和硬件等资源。集成测试在演示系统工作(尤其是对非程序员)方面比一组单元测试做得更令人信服,至少在集成测试环境类似于产品的程度上是如此。

实际上,"集成测试"被用于各种各样的事情,从针对类似于生产环境的完整系统测试到使用未模拟的资源(如数据库或队列)的任何测试。在范围的低端,集成测试可以是JUnit测试,其中存储库针对内存中的数据库执行,而在高端,集成测试可以是系统测试,验证应用程序是否可以交换消息。


单元测试不应该依赖于被测试单元之外的代码。您可以通过寻找最小的可测试部分来决定单元是什么。如果存在依赖项,则应将它们替换为假对象。嘲弄,树桩……测试执行线程在最小的可测试单元内开始和结束。

当假对象被真实对象替换并且测试执行线程交叉到其他可测试单元时,您就有了一个集成测试


单元测试是在(尽可能)完全隔离的情况下进行的。

集成测试是在被测试对象或模块正常工作时,使用其他代码位进行的。


单元测试测试您完全控制的代码,而集成测试测试您的代码如何使用或与其他代码"集成"。

因此,您可以编写单元测试来确保您自己的库按预期工作,然后编写集成测试来确保您的代码与您正在使用的其他代码(例如库)很好地配合使用。

功能测试与集成测试相关,但更具体地说是指测试整个系统或应用程序的测试,所有代码都在一起运行,几乎是一个超级集成测试。


单元测试通常针对软件模块中实现的单个功能进行。测试范围完全在该软件模块内。单元测试永远不能满足最终的功能需求。它属于白盒测试方法。

而集成测试则是为了确保不同的软件模块实现。测试通常在软件开发中完成模块级集成之后进行。此测试将涵盖功能需求,但不足以确保系统验证。