> 백엔드 개발 > Golang > Go에서 로그인을 사용하는 함수의 출력을 테스트하는 방법은 무엇입니까?

Go에서 로그인을 사용하는 함수의 출력을 테스트하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-22 08:18:12
원래의
465명이 탐색했습니다.

How to Test Output from Functions that Use Logging in Go?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿