From daaf4d048ee7be6c77d47fe9375f092f1ccc8331 Mon Sep 17 00:00:00 2001 From: b3nw Date: Thu, 12 Feb 2026 02:24:40 +0000 Subject: [PATCH] fix: initialize credentials before usage managers to resolve tier=None The _run() method was calling initialize_usage_managers() before _initialize_credentials(), so tier caches were empty when UsageManager read them. Swapping the order ensures project_tier_cache is populated before tiers are assigned to CredentialState objects. --- src/rotator_library/background_refresher.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/rotator_library/background_refresher.py b/src/rotator_library/background_refresher.py index acc66c89..ed945f34 100644 --- a/src/rotator_library/background_refresher.py +++ b/src/rotator_library/background_refresher.py @@ -267,9 +267,10 @@ async def _run_provider_background_job( async def _run(self): """The main loop for OAuth token refresh.""" - await self._client.initialize_usage_managers() - # Initialize credentials (load persisted tiers) before starting + # Initialize credentials first to populate tier/project caches await self._initialize_credentials() + # Then initialize usage managers which reads from those caches + await self._client.initialize_usage_managers() # Start provider-specific background jobs with their own timers self._start_provider_background_jobs()