测试金字塔将测试分为不同的类别,如下图所示
单元测试在金字塔的底部。大部分测试都是单元测试,它们编写成本代、执行速度快且执行结果高度确定。通常,越往金子塔的上层走,测试变得越复杂,运行速度越慢,并且越难保证执行结果的确定性。
一个常见的技巧是明确说明要运行哪种测试。例如,在项目生命周期的不同阶段,我们可能只想运行单元测试或者运行与项目相关的所有测试。不对测试进行分类意味着可能会浪费时间和精力,并且会丧失测试的准确性。
1. build 标识
最常见的区分测试种类的方法就是使用 build 标识。build 标识是一个出现在 Go 文件首行的特殊注释,它后面需要跟一个空行。
/go:build foo
package bar
这个文件包含 foo 标识。需要指出的是,一个包可能包含多个具有不同 build 标识的文件。
build 标识有两个主要的使用场景。第一个,我们可以使用 build 标识作为构建应用程序的条件选项:例如,如果希望仅在启用 cgo 时才包含某个源文件(cgo是让 Go 包调用 C 代码的一种方法),我们可以添加 //go:build cgo 这个 build 标识。第二个,如果想将某个测试归类为集成测试,可以添加一个特定的标识,例如, integration。
下面