- 5.1.2. 优先内部测试再到外部测试
5.1.2. 优先内部测试再到外部测试
go tool
支持在两个地方编写 testing
包测试。假设你的包名为 http2
,您可以编写 http2_test.go
文件并使用包 http2
声明。这样做会编译 http2_test.go
中的代码,就像它是 http2
包的一部分一样。这就是内部测试。
go tool
还支持一个特殊的包声明,以 test
为结尾,即 package http_test
。这允许你的测试文件与代码一起存放在同一个包中,但是当编译时这些测试不是包的代码的一部分,它们存在于自己的包中。就像调用另一个包的代码一样来编写测试。这被称为外部测试。
我建议在编写单元测试时使用内部测试。这样你就可以直接测试每个函数或方法,避免外部测试干扰。
但是,你应该将 Example
测试函数放在外部测试文件中。这确保了在 godoc
中查看时,示例具有适当的包名前缀并且可以轻松地进行复制粘贴。
贴士:
避免复杂的包层次结构,抵制应用分类法
Go 语言包的层次结构对于go tool
没有任何意义除了下一节要说的。 例如,net/http
包不是一个子包或者net
包的子包。如果在项目中创建了不包含
.go
文件的中间目录,则可能无法遵循此建议。