Fonctionnement du code de retour PowerShell

Vous savez que le support de Windows 2003 Server prend fin le 14 juillet prochain. A cette occasion, je fais un peu d’archéologie en reprenant des scripts VBS et Batch (incluant du Shell) avec PowerShell. Rien de mieux pour approfondir le fonctionnement du code de retour PowerShell.

Par convention, le code de retour vaut 0 si tout s’est bien passé. Les autres valeurs sont des erreurs. Il est possible d’avoir un tableau de description pour les codes de retour.

En Batch, le code de retour se trouve dans %ERRORLEVEL%.

En PowerShell, le code de retour se trouve dans $LASTEXITCODE. En plus de cela, nous disposons de $? qui permet de savoir si la dernière commande s’est déroulée convenablement.

Comme rien ne vaut un exemple, nous allons exécuter un script PowerShell depuis l’invite de commande classique et PowerShell. Le script en question – test.ps1 – possède 3 comportements (normal, exception non catchée, exception catchée). Un modulo 3 des secondes au moment de l’exécution détermine le comportement.

Pour modifier la valeur du retour, il faut utiliser la commande exit.

Attention : return permet de retourner une valeur mais ne modifie ni %errorlevel% ni $LASTEXITCODE

Try
{
   $modRes = $(Get-Date).Second % 3
   switch ($modRes)
   {
      1 {
           throw 'axe'
        }
      2 {
           throw [System.IO.FileNotFoundException] "$file not found."
        }
      0 { exit 0 }
   }
}
Catch [System.IO.FileNotFoundException]
{
   exit 33
}

Premièrement l’appel du script depuis l’invite de commande.

#OK
> POWERSHELL.EXE –FILE test.ps1
> %ERRORLEVEL%
0

#FILENOTFOUND
> POWERSHELL.EXE –FILE test.ps1
> %ERRORLEVEL%
33

#AXE
> POWERSHELL.EXE –FILE test.ps1
> %ERRORLEVEL%
0

#AXE
> POWERSHELL.EXE –Command .test.ps1
> %ERRORLEVEL%
1</pre>

Comme vous le voyez avec le cas l’exception non catchée, il faut faire attention à utiliser **powershell.exe -command** afin d’être sûr d’avoir un code de retour consistant.

Ensuite l’appel du script depuis l’invite de commande PowerShell pour voir le fonctionnement de $? et $LASTEXITCODE.

<div class="highlight"><pre style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4"><code class="language-powershell" data-lang="powershell"><span style="color:#75715e">#OK</span>
&amp;gt; .Test.ps1
&amp;gt; $?
True
&amp;gt; $LASTEXITCODE
0

<span style="color:#75715e">#FILENOTFOUND</span>
&amp;gt; .Test.ps1
&amp;gt; $?
False
&amp;gt; $LASTEXITCODE
33

<span style="color:#75715e">#AXE</span>
&amp;gt; .Test.ps1
&amp;gt; $?
False
&amp;gt; $LASTEXITCODE
1</code></pre></div>

Maintenant vous savez comment fonctionne le code de retour PowerShell – **$LASTEXITCODE** – et son ami état de l’exécution – **$?**. Vous avez même le petit plus qui permet de conserver la cohérence lors de l’appel d’un script PowerShell depuis l’invite de commande ( **-command** au lieu de -file).

**Références :**

[Fin de support de Windows 2003 Server][1]

 [1]: http://www.microsoft.com/fr-fr/server-cloud/products/windows-server-2003/ "Fin de support Windows 2003 Server"