GoLang 테스트 코드 구성 모범 사례: 파일 구조: 각 패키지의 테스트 코드는 _test.go 접미사로 끝나는 별도의 파일에 배치되어야 합니다. 테스트 함수 이름 지정: func Test
GoLang 함수에 대한 테스트 코드를 구성하는 방법
머리말
Go에서 테스트 코드를 작성하는 것은 함수가 예상대로 작동하는지 확인하는 데 중요합니다. 잘 구성된 테스트 코드를 사용하면 코드 기반을 더 쉽게 유지 관리하고 확장할 수 있습니다. 이 기사에서는 GoLang 기능을 테스트하기 위한 코드 구성에 대한 모범 사례를 살펴보겠습니다.
1. 파일 구조
테스트할 각 패키지에 대해 _test.go
접미사로 끝나는 별도의 테스트 파일을 만드는 것이 좋습니다. 이는 테스트 파일이 패키지의 다른 소스 파일과 동일한 디렉터리에 있음을 의미합니다. _test.go
后缀结尾。这意味着您的测试文件将与包中的其他源文件位于同一目录中。
2. 测试函数命名
每个测试函数都应该有一个清晰而简洁的名称,描述它正在测试的内容。通常使用以下约定:
func Test<FunctionName>_<TestType>()
例如,对于 Add
函数,您可以使用以下测试函数名称:
func TestAdd_Basic() func TestAdd_EdgeCases()
3. 测试表
对于涉及多个输入或输出值的情况,测试表是一种组织测试用例的便捷方式。您可以创建一个结构或类型来表示测试表中的每一行。
4. 基准测试
如果你需要评估函数的性能,可以使用 Go 语言中的基准测试功能。基准测试可以测量函数运行所需的时间。
5. 模拟
在某些情况下,您可能需要模拟函数的依赖关系以测试其行为。标准库提供了多种模拟库,例如 testify/mock
。
实战案例:测试一个简单的计算函数
让我们考虑一个简单的计算函数 Sum
,它接受两个整数并返回它们的总和。让我们编写一个测试文件来测试此函数:
package main import "testing" func Sum(a, b int) int { return a + b } func TestSum_Basic(t *testing.T) { tests := []struct { a, b, expected int }{ {1, 2, 3}, {0, 0, 0}, {5, -2, 3}, } for _, tt := range tests { actual := Sum(tt.a, tt.b) if actual != tt.expected { t.Errorf("Sum(%d, %d) = %d, expected %d", tt.a, tt.b, actual, tt.expected) } } }
在这个测试文件中,我们使用了测试表来表示不同的测试用例。我们还使用了 Errorf
Add
함수의 경우 다음 테스트 함수 이름을 사용할 수 있습니다. 🎜rrreee🎜🎜3 테스트 테이블 🎜🎜🎜다중 입력이 포함된 경우 또는 출력 값, 테스트 테이블은 테스트 케이스를 구성하는 편리한 방법입니다. 테스트 테이블의 각 행을 나타내는 구조나 유형을 만들 수 있습니다. 🎜🎜🎜4. 벤치마킹🎜🎜🎜함수의 성능을 평가해야 한다면 Go 언어의 벤치마킹 기능을 사용할 수 있습니다. 벤치마크는 함수가 실행되는 데 걸리는 시간을 측정합니다. 🎜🎜🎜 5. 모의 🎜🎜🎜 어떤 경우에는 함수의 동작을 테스트하기 위해 함수의 종속성을 모의해야 할 수도 있습니다. 표준 라이브러리는 testify/mock
과 같은 다양한 모의 라이브러리를 제공합니다. 🎜🎜🎜실용 사례: 간단한 계산 함수 테스트🎜🎜🎜두 개의 정수를 받아들이고 그 합계를 반환하는 간단한 계산 함수 Sum
을 고려해 보겠습니다. 이 기능을 테스트하기 위해 테스트 파일을 작성해 보겠습니다. 🎜rrreee🎜 이 테스트 파일에서는 테스트 테이블을 사용하여 다양한 테스트 사례를 나타냈습니다. 또한 실패한 테스트를 보고하기 위해 Errorf
메서드를 사용합니다. 🎜위 내용은 golang 함수의 테스트 코드를 어떻게 구성하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!