Skip to content

Fix ENOBUFS errors in pr-status.js when fetching large CI logs#90654

Merged
sokra merged 2 commits intocanaryfrom
sokra/failing-pr-status
Mar 2, 2026
Merged

Fix ENOBUFS errors in pr-status.js when fetching large CI logs#90654
sokra merged 2 commits intocanaryfrom
sokra/failing-pr-status

Conversation

@sokra
Copy link
Member

@sokra sokra commented Feb 27, 2026

Summary

Fixes spawnSync /bin/sh ENOBUFS errors in scripts/pr-status.js when fetching large CI job logs.

The script uses execSync (which internally uses spawnSync) to fetch CI job logs via gh api .../jobs/{id}/logs. execSync has a hard maxBuffer limit (set to 50MB), and when CI job logs exceed that size, Node.js throws an ENOBUFS error. This causes the flaky test detection to silently fail, reporting 0 flaky tests.

Before:

Fetching logs for 37 failed jobs...
[stderr] Command failed: gh api "repos/vercel/next.js/actions/jobs/65135029618/logs"
spawnSync /bin/sh ENOBUFS
[stderr] Command failed: gh api "repos/vercel/next.js/actions/jobs/65135029722/logs"
spawnSync /bin/sh ENOBUFS
Found 0 flaky tests (failing on 2+ different branches)

After:

Fetching logs for 18 failed jobs...
Found 0 flaky tests (failing on 2+ different branches)

Changes

  • Added an execAsync() helper that uses child_process.spawn instead of execSync. spawn streams data through pipes with no built-in buffer limit, avoiding ENOBUFS entirely.
  • Updated getJobLogs() and the log-fetching loop in getFlakyTests() to use execAsync instead of exec.
  • All other API calls (small JSON responses) continue using the synchronous exec() helper since they are well within the 50MB limit.

Test Plan

Ran node scripts/pr-status.js 90617 against a PR with multiple failed jobs — completes successfully with no ENOBUFS errors.

Replace execSync with async spawn-based execAsync for log fetching.
execSync has a hard maxBuffer limit (50MB) causing ENOBUFS when CI job
logs exceed that size. spawn streams data through pipes with no limit.
@nextjs-bot nextjs-bot added the created-by: Turbopack team PRs by the Turbopack team. label Feb 27, 2026
@sokra sokra marked this pull request as ready for review February 27, 2026 14:46
@nextjs-bot
Copy link
Collaborator

nextjs-bot commented Feb 27, 2026

Stats from current PR

✅ No significant changes detected

📊 All Metrics
📖 Metrics Glossary

Dev Server Metrics:

  • Listen = TCP port starts accepting connections
  • First Request = HTTP server returns successful response
  • Cold = Fresh build (no cache)
  • Warm = With cached build artifacts

Build Metrics:

  • Fresh = Clean build (no .next directory)
  • Cached = With existing .next directory

Change Thresholds:

  • Time: Changes < 50ms AND < 10%, OR < 2% are insignificant
  • Size: Changes < 1KB AND < 1% are insignificant
  • All other changes are flagged to catch regressions

⚡ Dev Server

Metric Canary PR Change Trend
Cold (Listen) 456ms 456ms █▁▁▁▁
Cold (Ready in log) 453ms 452ms █▂▁▂▁
Cold (First Request) 984ms 979ms █▃▃▃▁
Warm (Listen) 457ms 458ms █▂▁▁▁
Warm (Ready in log) 451ms 452ms █▂▁▁▁
Warm (First Request) 367ms 369ms ▇▂▁▁▁
📦 Dev Server (Webpack) (Legacy)

📦 Dev Server (Webpack)

Metric Canary PR Change Trend
Cold (Listen) 456ms 455ms ▁▄▁▁▁
Cold (Ready in log) 438ms 439ms ▂▃▂▂▁
Cold (First Request) 1.920s 1.945s ▁▂▁▁▁
Warm (Listen) 456ms 456ms ▁▁▁▁▁
Warm (Ready in log) 438ms 439ms ▂▃▂▂▁
Warm (First Request) 1.967s 1.958s ▂▂▁▁▁

⚡ Production Builds

Metric Canary PR Change Trend
Fresh Build 4.355s 4.387s ▇▄▁▁▃
Cached Build 4.412s 4.406s ▇▄▁▁▃
📦 Production Builds (Webpack) (Legacy)

📦 Production Builds (Webpack)

Metric Canary PR Change Trend
Fresh Build 14.113s 14.105s ▁▂▁▁▁
Cached Build 14.188s 14.225s ▁▁▁▁▁
node_modules Size 475 MB 475 MB ▁▁▁▁▁
📦 Bundle Sizes

Bundle Sizes

⚡ Turbopack

Client

Main Bundles: **401 kB** → **401 kB** ✅ -23 B

80 files with content-based hashes (individual files not comparable between builds)

Server

Middleware
Canary PR Change
middleware-b..fest.js gzip 764 B 762 B
Total 764 B 762 B ✅ -2 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 449 B 450 B
Total 449 B 450 B ⚠️ +1 B

📦 Webpack

Client

Main Bundles
Canary PR Change
5528-HASH.js gzip 5.54 kB N/A -
6280-HASH.js gzip 58.4 kB N/A -
6335.HASH.js gzip 169 B N/A -
912-HASH.js gzip 4.59 kB N/A -
e8aec2e4-HASH.js gzip 62.6 kB N/A -
framework-HASH.js gzip 59.7 kB 59.7 kB
main-app-HASH.js gzip 255 B 254 B
main-HASH.js gzip 39.1 kB 39.1 kB
webpack-HASH.js gzip 1.68 kB 1.68 kB
262-HASH.js gzip N/A 4.59 kB -
2889.HASH.js gzip N/A 169 B -
5602-HASH.js gzip N/A 5.55 kB -
6948ada0-HASH.js gzip N/A 62.6 kB -
9544-HASH.js gzip N/A 59.1 kB -
Total 232 kB 233 kB ⚠️ +702 B
Polyfills
Canary PR Change
polyfills-HASH.js gzip 39.4 kB 39.4 kB
Total 39.4 kB 39.4 kB
Pages
Canary PR Change
_app-HASH.js gzip 194 B 194 B
_error-HASH.js gzip 183 B 180 B 🟢 3 B (-2%)
css-HASH.js gzip 331 B 330 B
dynamic-HASH.js gzip 1.81 kB 1.81 kB
edge-ssr-HASH.js gzip 256 B 256 B
head-HASH.js gzip 351 B 352 B
hooks-HASH.js gzip 384 B 383 B
image-HASH.js gzip 580 B 581 B
index-HASH.js gzip 260 B 260 B
link-HASH.js gzip 2.5 kB 2.5 kB
routerDirect..HASH.js gzip 320 B 319 B
script-HASH.js gzip 386 B 386 B
withRouter-HASH.js gzip 315 B 315 B
1afbb74e6ecf..834.css gzip 106 B 106 B
Total 7.97 kB 7.97 kB ✅ -2 B

Server

Edge SSR
Canary PR Change
edge-ssr.js gzip 125 kB 125 kB
page.js gzip 254 kB 255 kB
Total 379 kB 379 kB ⚠️ +306 B
Middleware
Canary PR Change
middleware-b..fest.js gzip 617 B 615 B
middleware-r..fest.js gzip 156 B 155 B
middleware.js gzip 43.8 kB 43.9 kB
edge-runtime..pack.js gzip 842 B 842 B
Total 45.4 kB 45.5 kB ⚠️ +103 B
Build Details
Build Manifests
Canary PR Change
_buildManifest.js gzip 715 B 718 B
Total 715 B 718 B ⚠️ +3 B
Build Cache
Canary PR Change
0.pack gzip 4.02 MB 4.03 MB 🔴 +9.64 kB (+0%)
index.pack gzip 103 kB 102 kB
index.pack.old gzip 101 kB 102 kB
Total 4.23 MB 4.24 MB ⚠️ +9.57 kB

🔄 Shared (bundler-independent)

Runtimes
Canary PR Change
app-page-exp...dev.js gzip 320 kB 320 kB
app-page-exp..prod.js gzip 170 kB 170 kB
app-page-tur...dev.js gzip 320 kB 320 kB
app-page-tur..prod.js gzip 170 kB 170 kB
app-page-tur...dev.js gzip 316 kB 316 kB
app-page-tur..prod.js gzip 168 kB 168 kB
app-page.run...dev.js gzip 317 kB 317 kB
app-page.run..prod.js gzip 168 kB 168 kB
app-route-ex...dev.js gzip 70.8 kB 70.8 kB
app-route-ex..prod.js gzip 49.2 kB 49.2 kB
app-route-tu...dev.js gzip 70.9 kB 70.9 kB
app-route-tu..prod.js gzip 49.3 kB 49.3 kB
app-route-tu...dev.js gzip 70.4 kB 70.4 kB
app-route-tu..prod.js gzip 49 kB 49 kB
app-route.ru...dev.js gzip 70.4 kB 70.4 kB
app-route.ru..prod.js gzip 49 kB 49 kB
dist_client_...dev.js gzip 324 B 324 B
dist_client_...dev.js gzip 326 B 326 B
dist_client_...dev.js gzip 318 B 318 B
dist_client_...dev.js gzip 317 B 317 B
pages-api-tu...dev.js gzip 43.2 kB 43.2 kB
pages-api-tu..prod.js gzip 32.9 kB 32.9 kB
pages-api.ru...dev.js gzip 43.2 kB 43.2 kB
pages-api.ru..prod.js gzip 32.9 kB 32.9 kB
pages-turbo....dev.js gzip 52.6 kB 52.6 kB
pages-turbo...prod.js gzip 38.5 kB 38.5 kB
pages.runtim...dev.js gzip 52.6 kB 52.6 kB
pages.runtim..prod.js gzip 38.5 kB 38.5 kB
server.runti..prod.js gzip 61.9 kB 61.9 kB
Total 2.82 MB 2.82 MB ✅ -3 B
📎 Tarball URL
next@https://vercel-packages.vercel.app/next/prs/90654/next

Address review feedback: use spawn(prog, args) instead of
spawn('/bin/sh', ['-c', cmd]) to avoid unnecessary shell invocation.
@nextjs-bot
Copy link
Collaborator

nextjs-bot commented Feb 28, 2026

Tests Passed

@sokra sokra requested a review from lukesandberg March 1, 2026 06:33
@sokra sokra merged commit 2075383 into canary Mar 2, 2026
285 of 287 checks passed
@sokra sokra deleted the sokra/failing-pr-status branch March 2, 2026 07:56
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

created-by: Turbopack team PRs by the Turbopack team.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants