bun-runtime▌
affaan-m/everything-claude-code · updated Apr 8, 2026
Bun is a fast all-in-one JavaScript runtime and toolkit: runtime, package manager, bundler, and test runner.
Bun Runtime
Bun is a fast all-in-one JavaScript runtime and toolkit: runtime, package manager, bundler, and test runner.
When to Use
- Prefer Bun for: new JS/TS projects, scripts where install/run speed matters, Vercel deployments with Bun runtime, and when you want a single toolchain (run + install + test + build).
- Prefer Node for: maximum ecosystem compatibility, legacy tooling that assumes Node, or when a dependency has known Bun issues.
Use when: adopting Bun, migrating from Node, writing or debugging Bun scripts/tests, or configuring Bun on Vercel or other platforms.
How It Works
- Runtime: Drop-in Node-compatible runtime (built on JavaScriptCore, implemented in Zig).
- Package manager:
bun installis significantly faster than npm/yarn. Lockfile isbun.lock(text) by default in current Bun; older versions usedbun.lockb(binary). - Bundler: Built-in bundler and transpiler for apps and libraries.
- Test runner: Built-in
bun testwith Jest-like API.
Migration from Node: Replace node script.js with bun run script.js or bun script.js. Run bun install in place of npm install; most packages work. Use bun run for npm scripts; bun x for npx-style one-off runs. Node built-ins are supported; prefer Bun APIs where they exist for better performance.
Vercel: Set runtime to Bun in project settings. Build: bun run build or bun build ./src/index.ts --outdir=dist. Install: bun install --frozen-lockfile for reproducible deploys.
Examples
Run and install
# Install dependencies (creates/updates bun.lock or bun.lockb)
bun install
# Run a script or file
bun run dev
bun run src/index.ts
bun src/index.ts
Scripts and env
bun run --env-file=.env dev
FOO=bar bun run script.ts
Testing
bun test
bun test --watch
// test/example.test.ts
import { expect, test } from "bun:test";
test("add", () => {
expect(1 + 2).toBe(3);
});
Runtime API
const file = Bun.file("package.json");
const json = await file.json();
Bun.serve({
port: 3000,
fetch(req) {
return new Response("Hello");
},
});
Best Practices
- Commit the lockfile (
bun.lockorbun.lockb) for reproducible installs. - Prefer
bun runfor scripts. For TypeScript, Bun runs.tsnatively. - Keep dependencies up to date; Bun and the ecosystem evolve quickly.
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.5★★★★★33 reviews- ★★★★★Chaitanya Patil· Dec 20, 2024
bun-runtime fits our agent workflows well — practical, well scoped, and easy to wire into existing repos.
- ★★★★★Aisha Li· Dec 20, 2024
Keeps context tight: bun-runtime is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Sofia Jain· Dec 4, 2024
We added bun-runtime from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Arya Malhotra· Nov 23, 2024
bun-runtime reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Piyush G· Nov 11, 2024
Registry listing for bun-runtime matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Arjun White· Nov 11, 2024
bun-runtime has been reliable in day-to-day use. Documentation quality is above average for community skills.
- ★★★★★Sofia Diallo· Oct 14, 2024
Registry listing for bun-runtime matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Shikha Mishra· Oct 2, 2024
bun-runtime reduced setup friction for our internal harness; good balance of opinion and flexibility.
- ★★★★★Mei Sethi· Oct 2, 2024
Solid pick for teams standardizing on skills: bun-runtime is focused, and the summary matches what you get after install.
- ★★★★★Yash Thakker· Sep 21, 2024
bun-runtime is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
showing 1-10 of 33