Go 테스트에서 로그 출력 액세스
Go에서 로그 패키지는 메시지를 기록하는 편리한 방법을 제공합니다. 그러나 로그 메시지를 생성하는 코드와 상호 작용하는 테스트를 작성할 때 이러한 메시지를 테스트하는 것이 어려울 수 있습니다.
발생 시 오류를 기록하는 다음 함수 readByte를 고려하세요.
func readByte(/*...*/) { // ... if err != nil { fmt.Println("ERROR") log.Print("Couldn't read first byte") return } // ... }
In 해당 테스트 파일이 있는 경우 다음을 사용하여 오류 출력을 확인하려고 시도할 수 있습니다.
c.Assert(OUTPUT, check.Matches, "teste")
그러나 OUTPUT 변수는 작동하지 않으므로 이 접근 방식은 작동하지 않습니다. 로그 버퍼에 액세스할 수 없습니다. 이 문제를 해결하려면 테스트 중에 로그 출력을 캡처하는 방법을 사용할 수 있습니다.
로그 출력 캡처
로그 출력을 캡처하는 한 가지 접근 방식은 로그 출력을 일시적으로 리디렉션하는 것입니다. 로그가 인쇄되는 표준 출력입니다. 이는 다음 예에서 설명한 것처럼 log.SetOutput 함수를 통해 달성할 수 있습니다.
func TestReadByte(t *testing.T) { var buf bytes.Buffer // Update output to write to the buffer log.SetOutput(&buf) // Reset output to original after test defer func() { log.SetOutput(os.Stderr) }() readByte() // Verify the buffer contains the expected log message t.Log(buf.String()) }
테스트를 실행하면 다음과 유사한 출력이 생성됩니다.
ERROR Couldn't read first byte
이는 Go 테스트 내에서 로그 출력에 효과적으로 액세스하고 확인할 수 있으므로 로그를 생성하는 코드의 동작을 철저하게 테스트할 수 있습니다.
위 내용은 Go 테스트에서 로그 출력을 캡처하고 테스트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!