Skip to content

fix(cloudflare): Use TransformStream to keep track of streams#20452

Merged
JPeer264 merged 2 commits intodevelopfrom
jp/cloudflare-streaming-span-fix
Apr 22, 2026
Merged

fix(cloudflare): Use TransformStream to keep track of streams#20452
JPeer264 merged 2 commits intodevelopfrom
jp/cloudflare-streaming-span-fix

Conversation

@JPeer264
Copy link
Copy Markdown
Member

closes #20409
closes JS-2233

Problem

The issue is that we had a waitUntil?.(streamMonitor); that waited until the stream was done. streamMonitor could potentially live forever, while waitUntil has a limit of 30 seconds until it is getting cancelled. With the current approach we allow streams only being open for 30 seconds - then the waitUntil would cancel the request. This can only be reproduced when deployed, that is the reason why we didn't notice in our test cases.

Solution

By removing the waitUntil there is no hard limit, but we still have to wait until the stream is over in order to end our spans and flush accordingly. This can be achieved with TransformStream, where we simply use the stream body from the client and pipe it through our transformer. With flush and cancel we know exactly when the stream would end or be cancelled - which is the only thing we need.

There is btw no reason to add integration of E2E tests, as miniflare doesn't have this limitation and it couldn't be reproduced, so the tests would always succeed. The unit tests are kinda simulating that by checking if waitUntil is getting called or not.

I also figured that the client isn't getting disposed and would leak memory - this PR is also fixing that (see screenshots).

Some evidence

repro: https://github.com/JPeer264/sentry-repros/tree/issue-20409

cloudflare logs before:

image

cloudflare logs after:

image

Sentry trace: https://sentry-sdks.sentry.io/explore/traces/trace/29a307b1272e48dbb3a87c270c487e5a/

Screenshot 2026-04-22 at 15 03 32

@JPeer264 JPeer264 requested review from logaretm and s1gr1d April 22, 2026 13:07
@JPeer264 JPeer264 self-assigned this Apr 22, 2026
@linear-code
Copy link
Copy Markdown

linear-code Bot commented Apr 22, 2026

Comment thread packages/cloudflare/src/request.ts
@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Apr 22, 2026

size-limit report 📦

Path Size % Change Change
@sentry/browser 25.88 kB - -
@sentry/browser - with treeshaking flags 24.35 kB - -
@sentry/browser (incl. Tracing) 43.81 kB - -
@sentry/browser (incl. Tracing + Span Streaming) 45.5 kB - -
@sentry/browser (incl. Tracing, Profiling) 48.73 kB - -
@sentry/browser (incl. Tracing, Replay) 82.98 kB - -
@sentry/browser (incl. Tracing, Replay) - with treeshaking flags 72.5 kB - -
@sentry/browser (incl. Tracing, Replay with Canvas) 87.67 kB - -
@sentry/browser (incl. Tracing, Replay, Feedback) 99.93 kB - -
@sentry/browser (incl. Feedback) 42.7 kB - -
@sentry/browser (incl. sendFeedback) 30.55 kB - -
@sentry/browser (incl. FeedbackAsync) 35.55 kB - -
@sentry/browser (incl. Metrics) 27.16 kB - -
@sentry/browser (incl. Logs) 27.29 kB - -
@sentry/browser (incl. Metrics & Logs) 27.98 kB - -
@sentry/react 27.62 kB - -
@sentry/react (incl. Tracing) 46.05 kB - -
@sentry/vue 30.71 kB - -
@sentry/vue (incl. Tracing) 45.62 kB - -
@sentry/svelte 25.89 kB - -
CDN Bundle 28.57 kB - -
CDN Bundle (incl. Tracing) 46.08 kB - -
CDN Bundle (incl. Logs, Metrics) 29.95 kB - -
CDN Bundle (incl. Tracing, Logs, Metrics) 47.12 kB - -
CDN Bundle (incl. Replay, Logs, Metrics) 68.92 kB - -
CDN Bundle (incl. Tracing, Replay) 83.14 kB - -
CDN Bundle (incl. Tracing, Replay, Logs, Metrics) 84.17 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback) 88.61 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback, Logs, Metrics) 89.69 kB - -
CDN Bundle - uncompressed 83.59 kB - -
CDN Bundle (incl. Tracing) - uncompressed 137.62 kB - -
CDN Bundle (incl. Logs, Metrics) - uncompressed 87.73 kB - -
CDN Bundle (incl. Tracing, Logs, Metrics) - uncompressed 141.03 kB - -
CDN Bundle (incl. Replay, Logs, Metrics) - uncompressed 211.31 kB - -
CDN Bundle (incl. Tracing, Replay) - uncompressed 255.06 kB - -
CDN Bundle (incl. Tracing, Replay, Logs, Metrics) - uncompressed 258.46 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback) - uncompressed 267.97 kB - -
CDN Bundle (incl. Tracing, Replay, Feedback, Logs, Metrics) - uncompressed 271.36 kB - -
@sentry/nextjs (client) 48.58 kB - -
@sentry/sveltekit (client) 44.22 kB - -
@sentry/node-core 58.35 kB +0.02% +8 B 🔺
@sentry/node 175.66 kB +0.01% +13 B 🔺
@sentry/node - without tracing 98.3 kB +0.02% +12 B 🔺
@sentry/aws-serverless 115.33 kB +0.01% +10 B 🔺

View base workflow run

@JPeer264 JPeer264 force-pushed the jp/cloudflare-streaming-span-fix branch from 75e9262 to 6de2693 Compare April 22, 2026 14:52
Comment thread packages/cloudflare/src/request.ts
@JPeer264 JPeer264 force-pushed the jp/cloudflare-streaming-span-fix branch 2 times, most recently from 6de2693 to 339219a Compare April 22, 2026 15:19
Comment thread packages/cloudflare/src/request.ts
Copy link
Copy Markdown
Member

@logaretm logaretm left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Way cleaner, that's very cool!

@JPeer264 JPeer264 merged commit 7569b10 into develop Apr 22, 2026
119 of 121 checks passed
@JPeer264 JPeer264 deleted the jp/cloudflare-streaming-span-fix branch April 22, 2026 17:31
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.

@sentry/cloudflare: root http.server span lost on streaming responses exceeding ctx.waitUntil 30s budget (regression since 10.28.0)

2 participants