La recherche et la rĂ©solution des bogues dans le code peuvent ĂȘtre frustrantes, en particulier lorsque vous ĂȘtes un nouveau dĂ©veloppeur. Heureusement, des outils comme GitHub Copilot permettent d'identifier et d'Ă©liminer rapidement les bogues, ce qui vous permet de vous concentrer sur un travail plus crĂ©atif et plus intĂ©ressant.
Prérequis
Les exemples de cet article supposent que vous utilisez GitHub Copilot pour déboguer un projet Python dans Visual Studio Code. (VS Code). Pour suivre les exemples, vous devez :
- Compléter la configuration de Visual Studio Code avec Copilot. dans la documentation Visual Studio Code.
- Télécharger Python.
- Installer lâextension Python pour Visual Studio Code.
Apprendre à déboguer à l'aide d'exemples
Il y a deux situations principales que vous rencontrerez lorsque vous essaierez d'exécuter un code bogué :
- Votre code sâarrĂȘte avant quâil ne sâexĂ©cute, et vous recevez un message dâerreur.
- Votre code sâexĂ©cute sans erreur, mais la sortie est diffĂ©rente de ce que vous attendiez.
Heureusement, Copilot peut vous aider à déboguer votre code dans les deux cas. Pour commencer, passez en revue les exemples suivants.
Débogage d'une erreur avec GitHub Copilot
Lorsque vous exĂ©cutez un code boguĂ©, vous recevez souvent un message d'erreur. Le message vous indique le fichier et la ligne oĂč lâerreur sâest produite et dĂ©crit briĂšvement ce qui sâest passĂ©. Toutefois, les messages dâerreur peuvent ĂȘtre dĂ©routants. Pour bien comprendre et corriger le problĂšme, nous pouvons demander de l'aide Ă Copilot.
Essayons avec un exemple de référentiel : new2code/debug-with-copilot
.
Clonage du rĂ©fĂ©rentiel dâexemples
Tout dâabord, nous devons crĂ©er une copie locale du rĂ©fĂ©rentiel :
- Commencer à cloner le référentiel new2code/debug-with-copilot dans VS Code.
- Choisissez un emplacement pour enregistrer le référentiel sur votre ordinateur, puis cliquez sur Sélectionner comme destination du référentiel.
- Lorsque vous y ĂȘtes invitĂ©, ouvrez le rĂ©fĂ©rentiel.
Exécution du fichier bogué
à présent, nous allons exécuter le fichier bugged_dice_battle.py
. Ce programme simule une bataille de dés entre deux joueurs.
-
Dans VS Code, ouvrez et passez en revue le fichier
bugged_dice_battle.py
. -
Ouvrez la Palette de commandes en appuyant sur Ctrl+Maj+P (Windows/Linux) ou Cmd+Maj+P (Mac).
-
Tapez
Terminal: Create New Terminal
, puis appuyez sur Entrée. -
Dans lâonglet terminal, collez la commande suivante.
Windows :
Shell py bugged_dice_battle.py
py bugged_dice_battle.py
Mac ou Linux :
Shell python bugged_dice_battle.py
python bugged_dice_battle.py
-
Appuyez sur la touche Entrée pour exécuter le programme.
Malheureusement, nous obtenons un texte d'erreur dans notre terminal qui se termine par le message suivant :
TypeError : ne peut concatĂ©ner quâune chaĂźne (str) (pas un entier « int ») Ă une chaĂźne (str)
Débogage du fichier
Pour comprendre ce que signifie cette erreur, ouvrez Copilot Chat dans VS Code, puis collez et envoyez le prompt suivant :
Explain in depth why my code produces the following error and how I can fix it: TypeError: can only concatenate str (not "int") to str
Explain in depth why my code produces the following error and how I can fix it:
TypeError: can only concatenate str (not "int") to str
Copilot répondra que l'erreur se produit parce que nous essayons de concaténer les entiers. die_1
et die_2
à des chaßnes, et vous ne pouvez concaténer que des chaßnes à des chaßnes.
Il fournira également une version mise à jour de notre code qui corrige le bogue en utilisant la fonction str()
pour convertir les entiers en chaßnes avant de les concaténer. Exercez-vous à la derniÚre étape du débogage en appliquant la suggestion de Copilot au fichier.
Débogage d'une sortie incorrecte avec GitHub Copilot
Parfois, le code en attente sâexĂ©cute sans gĂ©nĂ©rer dâerreurs, mais la sortie est clairement incorrecte. Dans ce cas, le dĂ©bogage peut ĂȘtre plus difficile car VS Code ne peut pas vous indiquer l'emplacement ou la description du bogue.
Pour ces bogues « invisibles », Copilot est particuliĂšrement utile. Passons Ă la pratique avec lâautre fichier de notre rĂ©fĂ©rentiel dâexemple : bugged_factorial_finder.py
. Il s'agit dâun programme Python censĂ© calculer une factorielle.
Exécution du fichier bogué
Tout dâabord, exĂ©cutons le programme pour observer le rĂ©sultat incorrect :
-
Ouvrez et passez en revue le fichier
bugged_factorial_finder.py
. -
Dans le terminal que vous avez créé précédemment, collez la commande suivante. Windows :
Shell py bugged_factorial_finder.py
py bugged_factorial_finder.py
Mac ou Linux :
Shell python bugged_factorial_finder.py
python bugged_factorial_finder.py
-
Appuyez sur la touche Entrée pour exécuter le programme.
Malheureusement, le code ne fonctionne pas comme prévu. Nous voulons qu'il retourne 720
, la valeur correcte de la factorielle 6, mais le résultat est beaucoup plus élevé que cela.
Débogage du fichier
Pour comprendre ce qui nâa pas fonctionnĂ©, ouvrez Copilot Chat et envoyez le prompt suivant :
Why is the output of this code so much higher than expected? Please explain in depth and suggest a solution.
Why is the output of this code so much higher than expected? Please explain in depth and suggest a solution.
Copilot indiquera que, parce que nous utilisons l'opérateur *=
nous multiplions en fait factorial
par les deux i
et factorial
. En dâautres termes, nous multiplions par un factorial
supplémentaire pour chaque itération de la boucle.
Pour corriger cette erreur, Copilot suggérera un code qui supprime l'élément supplémentaire factorial
de l'équation, ou qui modifie *=
l'opérateur à =
. Effectuez cette modification maintenant !
Débogage de votre propre projet
Maintenant que vous vous ĂȘtes exercĂ© Ă dĂ©boguer quelques programmes simples avec Copilot, vous pouvez utiliser les mĂȘmes mĂ©thodologies pour trouver et corriger les bogues qui se cachent dans votre propre travail.
Par exemple, pour déboguer un message d'erreur généré par votre code, envoyez Copilot l'invite suivante :
Explain in depth why my code produces the following error and how I can fix it: YOUR-ERROR-MESSAGE
Explain in depth why my code produces the following error and how I can fix it:
YOUR-ERROR-MESSAGE
Sinon, si vous déboguez une sortie incorrecte, demandez Copilot pourquoi la sortie est incorrecte et comment vous pouvez la corriger. Pour obtenir les meilleurs résultats, fournissez autant de contexte que possible sur la façon dont la sortie diffÚre de vos attentes.
Avec ces tactiques, vous ĂȘtes bien Ă©quipĂ© pour commencer Ă Ă©craser les bogues dans votre projet !
Ătapes suivantes
Au fur et à mesure que vous coderez, vous rencontrerez probablement des scénarios de problÚmes spécifiques et des erreurs difficiles à déboguer. Pour une liste des problÚmes potentiels et des exemples de prompts Copilot Chat pour les corriger, consultez Erreurs de débogage.