单元测试验证函数方法,集成测试检查组件协作,通过构建标签和Makefile统一管理执行流程。

在Go项目中,单元测试和集成测试结合的关键是合理组织代码结构、使用构建标签隔离测试类型,并通过统一的测试命令协调执行。这样既能保证核心逻辑的快速验证,又能确保组件协作的正确性。
单元测试聚焦函数和方法
单元测试用于验证独立的函数或方法是否按预期工作,通常不依赖外部系统如数据库、网络服务等。
将测试文件放在对应包目录下,使用标准 testing 包编写测试用例:
- 测试文件命名以 _test.go 结尾,例如 user_test.go- 使用表驱动测试(table-driven tests)覆盖多种输入情况
- 通过接口抽象依赖,用模拟对象(mocks)替代真实实现
示例:对一个简单计算器进行单元测试
立即学习“go语言免费学习笔记(深入)”;
func TestAdd(t *testing.T) {tests := []struct {
a, b, expected int
}{{1, 2, 3}, {0, 0, 0}, {-1, 1, 0}}
for _, tt := range tests {
if result := Add(tt.a, tt.b); result != tt.expected {
t.Errorf("Add(%d, %d) = %d, want %d", tt.a, tt.b, result, tt.expected)
}
}
}
集成测试验证组件协作
集成测试关注多个模块或服务之间的交互,比如数据库操作、HTTP接口调用等。
建议将集成测试放在独立的包或目录中(如 integration_test),并通过构建标签控制执行。
- 使用 //go:build integration 注释标记集成测试- 在 Makefile 或 CI 脚本中通过 -tags=integration 单独运行
- 避免频繁运行耗时操作,可设置环境变量控制是否启用
示例:测试用户存储层与数据库的交互
//go:build integrationfunc TestUserRepository_Create(t *testing.T) {
if testing.Short() {
t.Skip("skipping integration test")
}
// 连接真实数据库或启动测试容器
repo := NewUserRepository(testDB)
user := &User{Name: "alice"}
err := repo.Create(user)
if err != nil {
t.Fatalf("failed to create user: %v", err)
}
}
统一管理测试执行流程
通过 Makefile 或脚本统一调度不同类型的测试,便于本地开发和CI/CD使用。
- make test 执行所有单元测试- make test-integration 运行集成测试
- make test-all 合并两者
示例 Makefile:
test:go test -v ./...
test-integration:
go test -v -tags=integration ./...
test-all:
go test -v ./...
go test -v -tags=integration ./...
这样可以在提交前运行快速单元测试,在CI流水线中再执行完整的集成验证。
基本上就这些。关键在于职责分离和自动化控制,让两种测试各司其职又协同工作。










