Developer Ready: A comprehensive template. Works out of the box for most Bun.js projects. This project is intended to be used with the latest active LTS release of Bun.js.
Instant Value - All basic tools included and configured:
- π Typescript >= 5.3
- π§ Bun.js >= 1.0.26
- π§ Use Bun as package manager
- π ESM
- π§ͺ Biome for code formatting and linting
- β Jest or Bun test for fast unit testing and code coverage
- π Type definitions for Bun.js and Jest
- βοΈ EditorConfig for consistent coding style
- π¦ NPM scripts for common operations
- π οΈ Example configuration for GitHub Actions
- π Simple example of TypeScript code and unit test
- π Run tasks with Grunt (example for backup)
- π Build faster
- π₯οΈ Ungit for version control (git) with a GUI
- π Runtime library for TypeScript helpers with tslib
- ποΈ Utility functions for working with ts-api-utils
To use this template, use the following commands:
bun create github.com/RajaRakoto/bun-boilerplate <project-name>
cd <project-name>
bun run pkg-upgrade # to upgrade outdated dependencies in interactive mode
NOTE 1: I employ the
MIT license
for this starter kit, which includes my name and GitHub profile. Please remember to adjust or remove it if deemed unnecessary.
NOTE 2: In order to help you better understand the structure of this boilerplate, there is a
README.md
file in each subdirectory of src.
NOTE 3: For certain configurations in the
package.json
file, you need to modify them to tailor them to your project (e.g: name, description, author, keywords, main, repository, ...).
Start
- π
start
- Run your application with bun. - π
start:smol
- Run your application with bun and a flag which configures the JavaScriptCore heap size to be smaller and grow slower. - π
start:bin
- Run your standalone binary app.
Clean
- π
clean
- Remove coverage data, prod, build.
Development
- π
dev
- Launch your application in development mode with bun. - π
dev:watch
- Interactive watch mode to automatically transpile source files with bun in development. - π
dev:hot
- Hot reloading of source files with bun in development. - π
dev:smol:watch
- Interactive watch mode to automatically transpile source files with bun in development, while using --smol flag. - π
dev:smol:hot
- Hot reloading source files with bun in development, while using --smol flag.
Build
- π
build
- Transpile and bundle source files with bun. - π
build:watch
- Interactive watch mode to automatically transpile source files with bun. - π
build:bin
- bun's bundler implements a --compile flag for generating a standalone binary from a TypeScript or JavaScript file, use this in your production environment to ensure optimal execution of your app.
Testing
- π
test
- Run bun test. - π
test:watch
- Interactive watch mode to automatically re-run tests with bun.
Linting and Formatting
- π
biome:start
- Starts the Biome daemon server. You can specify a custom configuration file path using the--config-path
option. - π
biome:stop
- Stops the Biome daemon server. - π
biome:fix
- Runs a source code check and applies automatic fixes (linter & formatter) according to the defined rules. - π
biome:unsafe
- Works likebiome:fix
, but may apply more invasive or risky changes.
Backup and Dependency Management
- π
backup
- Backup files with Grunt. - π
pkg-check
- Check useless dependencies with depcheck. - π
pkg-upgrade
- Upgrade outdated dependencies (interactive mode) with npm-check-updates.
Versioning
- π
versioning
- Start ungit server.
NPM Commands
- π
npm-version:major
- Increments the major version number of your project using npm. - π
npm-version:minor
- Increments the minor version number of your project using npm. - π
npm-version:patch
- Increments the version patch number of your project using npm.
When using the build.js file in this boilerplate, it's important to note the significance of the target option. By default, if the target option is not specified in the build.js file, it will be set to browser
. However, for projects utilizing the bun.js
runtime environment, it's imperative to explicitly set the target to bun
. This guarantees compatibility with the bun
shell environment and prevents unexpected behavior. Furthermore, it's noteworthy that the target
supports three possible values: browser
, bun
, and node
, providing flexibility in defining the build target according to specific project requirements.
You can also check out my other starter projects:
- π node-boilerplate
- π react-boilerplate
- π next-boilerplate
- π qwik-boilerplate
- π vscode-boilerplate
- π cli-boilerplate