[SOLVED] run(powershell script.ps1) timeout

Questions about WAPT Packaging / Requêtes et aides autour des paquets Wapt.
Règles du forum
Règles du forum communautaire
* English support on www.reddit.com/r/wapt
* Le support communautaire en français se fait sur ce forum
* Merci de préfixer le titre du topic par [RESOLU] s'il est résolu.
* Merci de ne pas modifier un topic qui est taggé [RESOLU]. Ouvrez un nouveau topic en référençant l'ancien
* Préciser version de WAPT installée, version complète ET numéro de build (2.2.1.11957 / 2.2.2.12337 / etc.) AINSI QUE l'édition Enterprise / Discovery
* Les versions 1.8.2 et antérieures ne sont plus maintenues. Les seules questions acceptées vis à vis de la version 1.8.2 sont liés à la mise à jour vers une version supportée (2.1, 2.2, etc.)
* Préciser OS du serveur (Linux / Windows) et version (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019)
* Préciser OS de la machine d'administration/création des paquets et de la machine avec l'agent qui pose problème le cas échéant (Windows 7 / 10 / 11 / Debian 11 / etc.)
* Eviter de poser plusieurs questions lors de l'ouverture de topic, sinon il risque d'être ignorer. Si plusieurs sujet, ouvrir plusieurs topic, et de préférence les uns après les autres et pas tous en même temps (ie ne pas spammer le forum).
* Inclure directement les morceaux de code, les captures d'écran et autres images directement dans le post. Les liens vers les pastebin, les bitly et autres sites tierces seront systématiquement supprimés.
* Comme tout forum communautaire, le support est fait bénévolement par les membres. Si vous avez besoin d'un support commercial, vous pouvez contacter le service commercial Tranquil IT au 02.40.97.57.55
swbsf
Messages : 8
Inscription : 27 juil. 2017 - 09:50

27 juil. 2017 - 10:05

Bonjour,
Je tente ma chance ici.
Je crée un paquet de post-installation qui me configurera les postes en exécutant un script powershell. Alors pour répondre tout de suite à une éventuelle question du "pourquoi je ne fais pas cette post-install en pure python?" : parce que j'ai déjà le script en powershell et qu'il est trèèès long. Et puis il n'y a pas de raison qu'on ne puisse pas exécuter du powershell!
Donc quel que soit le script, il timeout, il semblerait que psutils.Popen ne détecte pas le code de sortie du script.
Pour l'exemple j'ai testé avec un script des plus simple :

Code : Tout sélectionner

echo "coucou" > c:\tmp\fichier.txt
exit
Puis dans Python :

Code : Tout sélectionner

run('powershell -NoProfile -NonInteractive -File c:/tmp/test.ps1')
Je constate que le code est bien exécuté, mais l'instruction ne termine jamais, ou plutôt au timeout=600.
Une idée? Quelle autre solution? J'ai aussi testé avec la même erreur :

Code : Tout sélectionner

with open('test.ps1','r') as f:
   data=f.read()
run_powershell(data)
Et c'est encore plus biscornu.
Par avance merci!
Dernière modification par swbsf le 01 août 2017 - 09:28, modifié 1 fois.
swbsf
Messages : 8
Inscription : 27 juil. 2017 - 09:50

27 juil. 2017 - 11:44

Pour info, le problème est contourné avec un :

Code : Tout sélectionner

import subprocess
cmd="powershell -NoProfile -NonInteractive -File c:\\tmp\\test.ps1"
proc = subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE)
proc.wait()
stdo,stde = proc.communicate()
print(stdo,stde)
Avatar de l’utilisateur
sfonteneau
Expert WAPT
Messages : 1787
Inscription : 10 juil. 2014 - 23:52
Contact :

27 juil. 2017 - 11:49

Avez vous la version 3 de powershell sur le poste ??

https://lists.tranquil.it/pipermail/wap ... 02340.html
swbsf
Messages : 8
Inscription : 27 juil. 2017 - 09:50

31 juil. 2017 - 09:01

C'est un Windows 10, donc oui.

Code : Tout sélectionner

    PS C:\Windows\system32> $PSVersionTable.PSversion
     
    Major  Minor  Build  Revision
    -----  -----  -----  --------
    5      0      10586  122
swbsf
Messages : 8
Inscription : 27 juil. 2017 - 09:50

01 août 2017 - 09:27

Bon je reviens sur ce que j'ai dis. L'erreur était bien liée à la version de powershell < 3.0. D'un côté c'était PS 2.0 et de l'autre, juste une machine lente donc timeout=3 était trop court pour lancer une simple commande PS.
Merci pour votre aide précise :)
Verrouillé