--- name: wait_for_http kind: function lang: bash domain: infra version: "1.0.0" purity: impure signature: "wait_for_http [timeout_seconds] [interval_seconds]" description: "Hace polling a una URL HTTP/HTTPS hasta recibir respuesta 2xx o agotar el timeout. Util en deploys, post-restart de servicios y smoke tests." tags: [http, wait, poll, health, deploy, smoke-test] uses_functions: [] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [] params: - name: url desc: "URL completa del endpoint a sondear (debe empezar por http:// o https://)" - name: timeout_seconds desc: "Tiempo maximo de espera en segundos. Default: 30" - name: interval_seconds desc: "Intervalo entre intentos en segundos. Default: 1" output: "stdout: 'OK (s)' al primer 2xx. stderr: linea de progreso por intento y mensaje TIMEOUT si se agota. Exit 0=ok, 1=timeout, 2=URL invalida, 5=curl no instalado." tested: false tests: [] test_file_path: "" file_path: "bash/functions/infra/wait_for_http.sh" --- ## Ejemplo ```bash source bash/functions/infra/wait_for_http.sh # Esperar hasta 60 segundos con sondeo cada 2 segundos wait_for_http https://api.example.com/health 60 2 # Uso tipico en un pipeline de deploy wait_for_http http://localhost:8080/health || { echo "servicio no arranco"; exit 1; } ``` ## Notas Acepta cualquier codigo 2xx (200, 201, 204...) como OK. Los codigos 3xx se tratan como "no listo" — el servicio debe responder directamente con 2xx, no redirigir. curl se invoca con `--max-time 5` para no bloquear el loop si la conexion tarda. Los errores de curl (DNS, conexion rechazada) se tratan como "no listo" y el loop continua. Salida de progreso va a stderr para no contaminar pipelines que capturen stdout. ---