유사한 시그니처와 반환 값으로 여러 함수를 테스트할 때 각 함수에 대해 개별 테스트를 작성하는 것은 지루한 일입니다. Go에서 리플렉션은 이러한 기능을 집합적으로 테스트하는 솔루션을 제공할 수 있습니다.
다음 시그니처가 있는 함수 세트(Func1, Func2, ...)를 고려하세요.
func YourFunction() (int, error)
목표: 이 함수 집합을 반복하고, 각각을 호출하고, 특정 조건에 대한 반환 값을 테스트하는 테스트를 작성하세요.
Reflection을 사용하면 런타임에 값과 함수에 액세스하고 조작할 수 있습니다. 수신자에 대한 Reflect.Value 객체를 생성하면 해당 함수를 찾고 Reflect.Value.MethodByName을 사용하여 호출할 수 있습니다. 그런 다음 반환된 값의 정확성을 검사할 수 있습니다.
다음은 리플렉션을 활용하여 지정된 인터페이스의 모든 기능을 테스트하는 테스트 예시입니다.
<code class="go">func TestFunc(t *testing.T) { var funcNames = []string{"Func1", "Func2", "Func3"} stype := reflect.ValueOf(s) // receiver for _, fname := range funcNames { sfunc := stype.MethodByName(fname) ret := sfunc.Call([]reflect.Value{}) val := ret[0].Int() err := ret[1] if val < 1 { t.Error(fname + " should return positive value") } if !err.IsNil() { // checks for a nil error t.Error(fname + " shouldn't err") } } }</code>
존재하지 않는 함수를 리플렉션을 사용하여 호출하면 패닉이 발생한다는 점을 명심하세요. 이를 처리하기 위해 지연된 함수와 복구를 사용하여 패닉을 포착하고 보다 유익한 오류 메시지를 제공할 수 있습니다.
리플렉션을 활용하고 예외를 적절하게 처리함으로써 다음과 같은 단일 테스트를 만들 수 있습니다. 유사한 동작으로 여러 기능을 효율적으로 테스트하여 반복적인 테스트 코드의 필요성을 줄이고 테스트의 견고성을 보장합니다.
위 내용은 Go에서 유사한 시그니처를 사용하여 여러 기능을 효율적으로 테스트하기 위해 Reflection을 어떻게 사용할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!