Menguji Fungsi Go dengan log.Fatal()
Dalam Go, mungkin mencabar untuk menguji fungsi yang menggunakan log.Fatal() , kerana ia secara langsung memanggil os.Exit(1), menyebabkan kegagalan ujian. Begini cara untuk mengatasi isu ini:
Buat pembalak tersuai yang mewarisi daripada log.Logger tetapi mengatasi log.Kaedah Fatal():
package main import ( "log" "os" ) type TestLogger struct { *log.Logger } func (l *TestLogger) Fatal(v ...interface{}) { l.Output(2, fmt.Sprint(v...)) } func (l *TestLogger) Fatalf(format string, v ...interface{}) { l.Output(2, fmt.Sprintf(format, v...)) }
Ganti pembalak standard dengan pembalak tersuai anda dalam kes ujian anda:
import ( "bytes" "github.com/YourPackage/logging" ) func TestFunctionWithLogFatal(t *testing.T) { buffer := new(bytes.Buffer) testLogger := logging.NewTestLogger(buffer) log.SetOutput(testLogger) // Call the function under test here output := buffer.String() // Assert that the output contains the expected log message }
Dengan mengatasi kaedah log.Fatal() dalam adat logger, anda boleh mengendalikan mesej log tanpa benar-benar keluar dari proses ujian. Sebaliknya, mereka ditangkap dalam objek penimbal yang disediakan untuk pengesahan. Ini membolehkan anda menguji fungsi yang menggunakan log.Fatal() dengan berkesan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menguji Fungsi Go yang Menggunakan `log.Fatal()` dengan Berkesan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!