Testen von os.Exit-Szenarien in Go mit Coverage-Informationen (Coveralls.io/Goveralls)
Diese Frage befasst sich mit den Herausforderungen beim Testen von Routinen, die Nutzen Sie os.Exit() in Go und stellen Sie gleichzeitig sicher, dass die Abdeckungsinformationen korrekt gemeldet werden. Das Hauptproblem besteht darin, dass vorhandene Methoden, wie z. B. das erneute Aufrufen der Binärdatei, die Abdeckung nicht verfolgen können.
Modifizierter Ansatz für eine genaue Abdeckung
Um diese Einschränkung zu beheben, wurde ein modifizierter Test durchgeführt Ansatz wird vorgeschlagen. Anstatt die Binärdatei erneut aufzurufen, wird der Test durch Ändern der Funktion os.Exit() oder log.Fatalf() durchgeführt, um Exit-Codes oder Fehlerprotokolle zu erfassen.
Geändert foo/bar.go:
package foo import ( "fmt" "os" ) var osExit = os.Exit func Crasher() { fmt.Println("Going down in flames!") osExit(1) }
Geänderter Testcode: foo/bar_test.go
package foo import "testing" func TestCrasher(t *testing.T) { // Save current function and restore at the end: oldOsExit := osExit defer func() { osExit = oldOsExit }() var got int myExit := func(code int) { got = code } osExit = myExit Crasher() if exp := 1; got != exp { t.Errorf("Expected exit code: %d, got: %d", exp, got) } }
Dieser Ansatz ermöglicht es Coverage-Tools, die Ausführung von os.Exit() genau zu verfolgen und stellt sicher, dass Testfälle abgedeckt werden, in denen Routinen mit os.Exit() beendet werden die Testergebnisse.
Fazit
Der modifizierte Ansatz kombiniert effektiv Tests mit Exit-Codes und Abdeckungsinformationen und liefert eine Komplettlösung zum genauen Testen von os.Exit()-Szenarien bei gleichzeitiger Aufrechterhaltung genauer Abdeckungsberichte.
Das obige ist der detaillierte Inhalt vonWie kann ich „os.Exit()' in Go genau testen und die Codeabdeckung beibehalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!