Statistiques de couverture pour les tests externes
Dans Go, il est recommandé de conserver les tests dans le même package que le code qu'ils testent. Cependant, si votre base de code se compose de nombreux fichiers de test, vous préférerez peut-être une organisation plus propre en séparant ces tests dans un package différent. Cette approche restreint les tests à l'accès à l'API publique du package, favorisant ainsi une meilleure organisation et encapsulation.
Étant donné la structure suivante :
api_client: Client.go ArtistService.go api_client_tests: ArtistService.Events_test.go ArtistService.Info_test.go UtilityFunction.go
Exécution de go test bandsintown-api/api_client_tests -couverture des rapports à 100 % couverture, mais cette couverture ne concerne que UtilityFunction.go.
Solution :
Pour obtenir des statistiques de couverture pour le package api_client testé sans fusionner les packages :
go test -cover -coverpkg "api_client" "api_client_tests"
Cependant, il convient de noter que la séparation du code et des fichiers de test dans différents répertoires est en conflit avec la convention Go. Si des tests en boîte noire sont souhaités, où rien en dehors du package n'est accessible, envisagez de déplacer les tests vers un nouveau package sans réorganiser les fichiers :
api_client.go :
<code class="go">package api_client // Only accessible within the package var privateVar = 10 func Method() {}</code>
api_client_test.go :
<code class="go">package api_client_tests import "testing" func TestClient(t *testing.T) { Method() // Still accessible from another package }</code>
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!