fix(browser_tool): fall through to autodetect on config read failure

This commit is contained in:
Wesley Simplicio 2026-05-09 15:18:09 -03:00 committed by Teknium
parent 3170c8d448
commit 48bf0ea249
2 changed files with 12 additions and 7 deletions

View file

@ -447,19 +447,24 @@ def _get_cloud_provider() -> Optional[CloudBrowserProvider]:
)
return None
except Exception as e:
# Config file may be temporarily unreadable; still try auto-detect so
# env-based / managed-gateway credentials can resolve. Don't pin cache.
logger.debug("Could not read cloud_provider from config: %s", e)
return None
if resolved is None:
# Prefer Browser Use (managed Nous gateway or direct API key),
# fall back to Browserbase (direct credentials only).
fallback_provider = BrowserUseProvider()
if fallback_provider.is_configured():
resolved = fallback_provider
else:
fallback_provider = BrowserbaseProvider()
try:
fallback_provider = BrowserUseProvider()
if fallback_provider.is_configured():
resolved = fallback_provider
else:
fallback_provider = BrowserbaseProvider()
if fallback_provider.is_configured():
resolved = fallback_provider
except Exception: # pragma: no cover - defensive: never poison cache
logger.debug("Cloud provider auto-detect failed", exc_info=True)
return None
if resolved is None:
# Transient None — credentials may self-heal. Don't poison the cache.