Skip to content

⚡ Bolt: Execute independent network requests concurrently#39

Open
Snigdh41 wants to merge 1 commit into
mainfrom
bolt-concurrent-emails-5601232288986507718
Open

⚡ Bolt: Execute independent network requests concurrently#39
Snigdh41 wants to merge 1 commit into
mainfrom
bolt-concurrent-emails-5601232288986507718

Conversation

@Snigdh41
Copy link
Copy Markdown
Owner

💡 What: Refactored the email sending logic in the Contact API worker (workers/contact-api/src/index.js) to use Promise.all() for executing the notification and auto-reply email requests concurrently instead of sequentially.

🎯 Why: Sequential execution of independent external API calls accumulates latency. Waiting for the first email to send before starting the second delays the worker's final response to the client.

📊 Impact: Reduces the time spent on network requests during the contact form submission by roughly half, leading to a faster response time for the user and shorter execution time for the worker.

🔬 Measurement: Can be verified by timing the response of the /contact endpoint before and after the change; the time spent waiting for the resend.emails.send calls will be bound by the slowest request rather than the sum of both.


PR created automatically by Jules for task 5601232288986507718 started by @Snigdh41

In the Contact API worker, the `resend.emails.send` calls for the notification and auto-reply emails were executed sequentially. This meant the worker had to wait for the first network request to complete before starting the second, unnecessarily accumulating latency.

By wrapping both requests in `Promise.all()`, they now execute concurrently. This significantly reduces the worker's overall execution time, providing a faster response to the client without modifying any underlying behavior.

Co-authored-by: Snigdh41 <43762408+Snigdh41@users.noreply.github.com>
@google-labs-jules
Copy link
Copy Markdown
Contributor

👋 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 @jules. You can find this option in the Pull Request section of your global Jules UI settings. You can always switch back!

New to Jules? Learn more at jules.google/docs.


For security, I will only act on instructions from the user who triggered this task.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant