Go 테스트에서 로그인을 사용하는 함수의 출력을 테스트하는 방법
fmt.Println( ) 또는 log.Print()를 사용하려면 테스트 내에서 해당 함수에 의해 생성된 출력에 액세스해야 합니다.
이를 달성하려면 다음 단계를 수행하면 됩니다.
readbyte_test.go와 같은 테스트 파일에서 bytes.Buffer 및 log.SetOutput()을 사용하여 로깅 함수의 출력을 버퍼로 리디렉션합니다.
import ( "bytes" "log" "os" "testing" ) func TestReadByte(t *testing.T) { var buf bytes.Buffer log.SetOutput(&buf) defer func() { log.SetOutput(os.Stderr) }() readByte() t.Log(buf.String()) }
다른 테스트 또는 후속 테스트에 대한 잠재적인 간섭을 피하기 위해 defer 함수에서 로그 출력을 os.Stderr로 복원해야 합니다. code.
readByte()를 호출한 다음 t.Log()를 사용하여 버퍼의 내용을 로깅하면 테스트 중인 함수에서 생성된 실제 출력을 검사할 수 있습니다. 이 기술을 사용하면 함수 코드 자체를 수정하지 않고도 예상되는 오류 메시지나 기타 기록된 정보를 확인할 수 있습니다.
위 내용은 Go에서 로그인을 사용하는 함수의 출력을 테스트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!