⚡ Bolt: Memoize static Printify API calls to prevent N+1 network requests#67
⚡ Bolt: Memoize static Printify API calls to prevent N+1 network requests#67merg357 wants to merge 1 commit into
Conversation
…ests Co-authored-by: merg357 <221854052+merg357@users.noreply.github.com>
|
👋 Jules, reporting for duty! I'm here to lend a hand with this pull request. When you start a review, I'll add a 👀 emoji to each comment to let you know I've read it. I'll focus on feedback directed at me and will do my best to stay out of conversations between you and other bots or reviewers to keep the noise down. I'll push a commit with your requested changes shortly after. Please note there might be a delay between these steps, but rest assured I'm on the job! For more direct control, you can switch me to Reactive Mode. When this mode is on, I will only act on comments where you specifically mention me with New to Jules? Learn more at jules.google/docs. For security, I will only act on instructions from the user who triggered this task. |
💡 What: Added
@functools.lru_cachetoget_variantsfunctions acrosscreate_merch.py,merch_factory.py, andprintify_manager.pyto memoize repetitive network calls. Replaced returned lists with immutable tuples to guarantee safety.🎯 Why: Within iterative product creation loops, querying the identical blueprint variants on each iteration resulted in a severe N+1 bottleneck. Since blueprint variants are static, redundant queries needlessly blocked execution.
📊 Impact: Eliminates N+1 network requests. Measurably speeds up bulk product creation processing.
🔬 Measurement: Re-run a bulk product creation command and observe significantly reduced total script execution time and network I/O.
PR created automatically by Jules for task 7782794411154088461 started by @merg357