OS.Exit-Szenarien in Go testen
In Go beendet die Funktion os.Exit die aktuelle Programmausführung, was das Testen erschwert Szenarien mit Programmabbruch. Ein Ansatz zur Lösung dieses Problems besteht darin, separate Prozess- und Unterprozessprüfungen zu verwenden.
Beispiel:
Betrachten Sie die folgende Funktion:
func doomed() { os.Exit(1) }
Um diese Funktion zu testen, erstellen wir einen separaten Testfall und rufen die Funktion in einem separaten Prozess auf.
Testen Fall:
import ( "os" "os/exec" "testing" ) func TestDoomed(t *testing.T) { if os.Getenv("BE_DOOMED") == "1" { doomed() return } cmd := exec.Command(os.Args[0], "-test.run=TestDoomed") cmd.Env = append(os.Environ(), "BE_DOOMED=1") err := cmd.Run() if e, ok := err.(*exec.ExitError); ok && !e.Success() { return } t.Fatalf("process ran with err %v, want exit status 1", err) }
In diesem Testfall:
Dieser Ansatz ermöglicht es uns, den os.Exit-Aufruf in einem separaten Prozess zu isolieren und so sicherzustellen, dass er keine Auswirkungen auf andere Tests hat.
Das obige ist der detaillierte Inhalt vonWie teste ich os.Exit-Szenarien in Go?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!