[RESUELTO] tiempo de espera de ejecución (script de powershell.ps1)

Preguntas sobre paquetes WAPT / Solicitudes y ayuda sobre paquetes WAPT.
Reglas del foro
Reglas del foro de la comunidad
* Soporte en inglés en www.reddit.com/r/wapt
* El soporte de la comunidad en francés está disponible en este foro
* Por favor, anteponga [RESUELTO] al título del tema si está resuelto.
* Por favor, no edite un tema que esté etiquetado como [RESUELTO]. Abra un nuevo tema haciendo referencia al anterior.
* Especifique la versión de WAPT instalada, la versión completa y el número de compilación (2.2.1.11957 / 2.2.2.12337 / etc.), así como la edición Enterprise/Discovery.
* Las versiones 1.8.2 y anteriores ya no son compatibles. Las únicas preguntas aceptadas sobre la versión 1.8.2 están relacionadas con la actualización a una versión compatible (2.1, 2.2, etc.).
* Especifique el sistema operativo del servidor (Linux/Windows) y la versión (Debian Buster/Bullseye - CentOS 7 - Windows Server 2012/2016/2019).
* Especifique el sistema operativo de la máquina de administración/creación de paquetes y de la máquina con el agente problemático, si corresponde (Windows 7/10/11/Debian 11/etc.).
* Evite hacer varias preguntas al abrir un tema, ya que podría ser ignorado. Si hay varios temas, ábralos por separado, preferiblemente uno tras otro y no todos a la vez (es decir, no sature el foro con spam).
* Incluya fragmentos de código, capturas de pantalla y otras imágenes directamente en la publicación. Los enlaces a Pastebin, Bitly y otros sitios de terceros serán eliminados sistemáticamente.
* Como en cualquier foro comunitario, el soporte es proporcionado voluntariamente por los miembros. Si necesita soporte comercial, puede comunicarse con el departamento de ventas de Tranquil IT al 02.40.97.57.55.
Bloqueado
swbsf
Mensajes: 8
Inscripción: 27 de julio de 2017 - 09:50

27 de julio de 2017 - 10:05

Buen día,
Estoy probando suerte aquí.
Estoy creando un paquete posterior a la instalación que configurará las estaciones de trabajo mediante la ejecución de un script de PowerShell. Para responder de inmediato a la posible pregunta de "¿por qué no hago esto después de la instalación en Python puro?": porque ya tengo el script de PowerShell y es muy largo. Además, ¡no hay ninguna razón por la que no podamos ejecutar PowerShell!
Entonces, sea cual sea el script, se agota el tiempo de espera; parece que psutils.Popen no está detectando el código de salida del script.
Para este ejemplo, lo probé con un script muy simple:

Código: Seleccionar todo

echo "coucou" > c:\tmp\fichier.txt
exit
Luego en Python:

Código: Seleccionar todo

run('powershell -NoProfile -NonInteractive -File c:/tmp/test.ps1')
Observo que el código se ejecuta correctamente, pero la instrucción nunca termina, o mejor dicho, en timeout=600.
¿Alguna idea? ¿Qué otras soluciones hay? También lo probé con el mismo error:

Código: Seleccionar todo

with open('test.ps1','r') as f:
   data=f.read()
run_powershell(data)
Y es aún más extraño.
¡Gracias de antemano!
Última edición realizada por swbsf el 1 de agosto de 2017 a las 09:28; editado 1 vez.
swbsf
Mensajes: 8
Inscripción: 27 de julio de 2017 - 09:50

27 de julio de 2017 - 11:44

Para su información, el problema se soluciona con:

Código: Seleccionar todo

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 usuario
Sfonteneau
Experto en WAPT
Mensajes: 2312
Registrado: 10 de julio de 2014 - 23:52
Contacto :

27 de julio de 2017 - 11:49

¿Tiene instalada la versión 3 de PowerShell en esta máquina?

https://lists.tranquil.it/pipermail/wap ... 02340.html
swbsf
Mensajes: 8
Inscripción: 27 de julio de 2017 - 09:50

31 de julio de 2017 - 09:01

Es Windows 10, así que sí.

Código: Seleccionar todo

    PS C:\Windows\system32> $PSVersionTable.PSversion
     
    Major  Minor  Build  Revision
    -----  -----  -----  --------
    5      0      10586  122
swbsf
Mensajes: 8
Inscripción: 27 de julio de 2017 - 09:50

1 de agosto de 2017 - 09:27

De acuerdo, retiro lo dicho. El error sí estaba relacionado con que la versión de PowerShell era inferior a la 3.0. Por un lado, era PS 2.0, y por otro, simplemente era un equipo lento, por lo que el tiempo de espera de 3 segundos era demasiado corto para ejecutar un comando simple de PS.
Gracias por su ayuda detallada :)
Bloqueado