Pour vérifier les journaux générés par une fonction testée, il est essentiel de les capturer et de les inspecter. Ceci peut être réalisé en redirigeant la sortie et en la comparant avec les valeurs attendues.
Dans l'exemple fourni, la fonction readByte imprime les messages du journal sur la sortie standard. Pour capturer ces messages dans le test, nous pouvons utiliser un bytes.Buffer comme indiqué ci-dessous :
package main import ( "bytes" "fmt" "io" "log" "os" "testing" ) func readByte(/*...*/) { // ... if err != nil { fmt.Println("ERROR") log.Print("Couldn't read first byte") return } // ... } func TestReadByte(t *testing.T) { var buf bytes.Buffer log.SetOutput(&buf) defer func() { log.SetOutput(os.Stderr) }() readByte() t.Log(buf.String()) }
Explication :
En examinant le contenu de buf, vous pouvez vérifier si les journaux attendus ont été générés par la fonction readByte . Cette approche vous permet de tester la sortie du journal sans modifier le code de la fonction testée.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!