>백엔드 개발 >Golang >Go 테스트에서 로그 출력을 캡처하고 확인하는 방법은 무엇입니까?

Go 테스트에서 로그 출력을 캡처하고 확인하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-16 16:48:03955검색

How to Capture and Verify Log Output in Go Tests?

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:

  • 로그 출력을 캡처할 버퍼를 생성합니다.
  • log.SetOutput(&buf)를 사용하여 기본 로그 출력을 버퍼로 리디렉션합니다.
  • 다음을 실행합니다. readByte 함수.
  • 후속 작업에 영향을 주지 않도록 defer func()를 사용하여 기본 로그 출력을 os.Stderr로 복원합니다. 테스트합니다.
  • testify/assert를 사용하여 예상 로그 메시지를 확인합니다.

위 내용은 Go 테스트에서 로그 출력을 캡처하고 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.