Go 테스트에서 로그 액세스
Go 테스트에서 함수의 로그 출력을 확인하는 것은 어려울 수 있으며, 특히 함수 자체가 로그를 기록하는 경우에는 더욱 그렇습니다.
로그 출력을 캡처하기 위한 일반적인 해결 방법은 함수를 실행하기 전에 기본 로그 출력을 버퍼로 리디렉션하는 것입니다. 테스트 중입니다.
예:
다음 readByte 함수를 고려하세요.
func readByte(/*...*/) { if err != nil { fmt.Println("ERROR") log.Print("Couldn't read first byte") return } }
로그 출력을 테스트하려면 다음 접근 방식을 사용할 수 있습니다. 테스트 파일에서:
package main import ( "bytes" "testing" "github.com/stretchr/testify/assert" ) func TestReadByte(t *testing.T) { var buf bytes.Buffer log.SetOutput(&buf) defer func() { log.SetOutput(os.Stderr) }() readByte() output := buf.String() assert.Contains(t, output, "Couldn't read first byte") }
이 예에서는 we:
위 내용은 Go 테스트에서 로그 출력을 캡처하고 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!