Commit cfee910
authored
fix: retry unprocessed requests in RequestQueue.add_request (#1976)
### Description
`RequestQueue.add_request` (singular) made a single best-effort
`add_batch_of_requests([request])` call and, if the storage client
returned the request as *unprocessed*, just logged a warning and
returned `None` — silently dropping the request. `add_requests` (plural)
already retries unprocessed requests via `_process_batch`, so the two
adds had inconsistent durability against best-effort backends (e.g. the
Apify platform's `batch_add_requests` endpoint, which may legitimately
return a request as unprocessed).
This makes a single add as durable as a batched one:
- `_process_batch` now returns an `AddRequestsResponse` aggregating the
requests processed across all attempts plus any still unprocessed after
the retries are exhausted (it previously returned `None`).
- `add_request` routes its single request through `_process_batch` and
returns `processed_requests[0]`, returning `None` only after retries are
exhausted.
The `ProcessedRequest | None` return contract and the blocking semantics
are preserved (for one request, `add_requests` already runs the first
batch synchronously), and the retry is safe because adds are idempotent
by `unique_key`.
Note: on the failure path `add_request` is now blocking-with-backoff
(worst case a few seconds of retry sleeps before returning `None`),
where it previously returned immediately. That is the intended trade —
durability over a fast silent drop.
### Issues
- Closes: #1975
- Surfaced as an intermittent e2e flake in apify/apify-sdk-python#1000
### Testing
- Added `test_add_request_retries_unprocessed` (a request reported
unprocessed on the first attempt is retried and survives) and
`test_add_request_returns_none_after_exhausting_retries` (stays
unprocessed across all attempts → returns `None`, 1 initial + 5
retries). Both fail on `master` and pass with this change.
- `uv run poe lint`, `uv run poe type-check`, and the
`tests/unit/storages/test_request_queue.py` suite all pass.1 parent 8c635e8 commit cfee910
2 files changed
Lines changed: 116 additions & 30 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
11 | 11 | | |
12 | 12 | | |
13 | 13 | | |
| 14 | + | |
14 | 15 | | |
15 | 16 | | |
16 | 17 | | |
| |||
181 | 182 | | |
182 | 183 | | |
183 | 184 | | |
184 | | - | |
| 185 | + | |
| 186 | + | |
185 | 187 | | |
186 | 188 | | |
187 | 189 | | |
188 | 190 | | |
189 | | - | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
190 | 194 | | |
191 | | - | |
192 | | - | |
193 | | - | |
194 | | - | |
195 | | - | |
196 | | - | |
| 195 | + | |
| 196 | + | |
197 | 197 | | |
198 | 198 | | |
199 | 199 | | |
| |||
352 | 352 | | |
353 | 353 | | |
354 | 354 | | |
355 | | - | |
356 | | - | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
357 | 362 | | |
358 | 363 | | |
359 | 364 | | |
360 | | - | |
361 | | - | |
362 | | - | |
363 | | - | |
364 | | - | |
365 | | - | |
366 | | - | |
367 | | - | |
368 | | - | |
369 | | - | |
370 | | - | |
371 | | - | |
372 | | - | |
373 | | - | |
374 | | - | |
375 | | - | |
376 | | - | |
377 | | - | |
378 | | - | |
379 | 365 | | |
380 | | - | |
381 | 366 | | |
382 | 367 | | |
383 | 368 | | |
384 | 369 | | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
| 392 | + | |
| 393 | + | |
| 394 | + | |
| 395 | + | |
| 396 | + | |
| 397 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
311 | 311 | | |
312 | 312 | | |
313 | 313 | | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
| 349 | + | |
| 350 | + | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
| 356 | + | |
| 357 | + | |
| 358 | + | |
| 359 | + | |
| 360 | + | |
| 361 | + | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
| 365 | + | |
| 366 | + | |
| 367 | + | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
| 377 | + | |
| 378 | + | |
| 379 | + | |
| 380 | + | |
| 381 | + | |
| 382 | + | |
| 383 | + | |
| 384 | + | |
| 385 | + | |
| 386 | + | |
314 | 387 | | |
315 | 388 | | |
316 | 389 | | |
| |||
0 commit comments