--- name: cdp_wait_load kind: function lang: go domain: infra version: "1.0.0" purity: impure signature: "func CdpWaitLoad(c *CDPConn, timeout time.Duration) error" description: "Espera a que la pagina actual termine de cargar completamente. Hace polling de document.readyState via Runtime.evaluate cada 200ms hasta que sea \"complete\", o hasta que se agote el timeout. Retorna error inmediato si CdpEvaluate falla (la conexion puede estar rota)." tags: [chrome, cdp, browser, automation, wait, polling, devtools, readystate, load] uses_functions: [cdp_evaluate_go_infra] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [fmt, time] tested: false tests: [] test_file_path: "" file_path: "functions/infra/cdp_wait_load.go" --- ## Ejemplo ```go conn, _ := CdpConnect(9222) CdpNavigate(conn, "https://example.com") // Esperar hasta 30 segundos a que la pagina cargue por completo if err := CdpWaitLoad(conn, 30*time.Second); err != nil { log.Fatal("Timeout esperando carga:", err) } html, _ := CdpGetHTML(conn) ``` ## Notas A diferencia de `CdpWaitElement`, que ignora errores de `CdpEvaluate` durante el polling (la pagina puede aun no estar lista), `CdpWaitLoad` retorna el error inmediatamente porque un fallo en `document.readyState` indica una conexion rota, no una condicion transitoria. Si `timeout <= 0` usa 30s por defecto (mas largo que `CdpWaitElement` porque la carga completa de red puede tardar mas que la aparicion de un elemento DOM).