CtrlK
BlogDocsLog inGet started
Tessl Logo

changesets

Use when creating a changeset, preparing a release, or bumping versions. Covers which packages to reference, how to write user-facing changeset descriptions, the release automation flow, and the npm/Docker version sync requirement. (project)

86

Quality

83%

Does it follow best practices?

Impact

Pending

No eval scenarios have been run

SecuritybySnyk

Passed

No known issues

SKILL.md
Quality
Evals
Security

Changesets & Releases

This repository uses changesets to drive a fully automated release pipeline. Create a changeset whenever your change affects published packages.

Creating a Changeset

A changeset should be created when there is a change that is observable to a consumer of the @cloudflare/sandbox package. This includes:

  • Changes to the API surface area, new methods, deprecations or removals.
  • Changes to the performance or security characteristics of the SDK.
  • Bug fixes that are user visible.

Create a new file in .changeset/ (e.g. .changeset/your-feature-name.md):

---
'@cloudflare/sandbox': patch
---

Brief description of your change

Rules

Only reference @cloudflare/sandbox. Never list @repo/shared or @repo/sandbox-container — those are internal workspace packages and must not be versioned independently. Changes to them flow through the public package. Pre-commit hooks and CI enforce this.

Use patch for almost everything. The SDK is in beta:

  • patch — all normal changes (features, fixes, refactors)
  • minor — breaking changes only
  • major — never

Writing the Description

Important: Changeset files should only reference @cloudflare/sandbox, never @repo/shared or @repo/sandbox-container. These internal packages should not be versioned independently - changes to them flow through the public package. Pre-commit hooks and CI will validate this rule.

Important: Write for end users. Changeset descriptions appear in GitHub releases - they're user-facing documentation, not internal notes.

  • Focus on the problem solved and the benefit, not technical implementation details.
  • Keep it short. Each changeset entry should aim to be a couple of sentences, no more than a single paragraph.
  • Include a code example showing how to enable or use the feature when applicable.
# Bad - technical/internal focused

Add WebSocket transport for request multiplexing over a single connection

# Good - user-focused with clear benefit and usage

Add WebSocket transport to avoid sub-request limits in Workers and Durable Objects.
Enable with `useWebSocket: true` in sandbox options.

Release Automation

Releases run via .github/workflows/release.yml. There is no manual publishing step.

  1. Merge a PR that contains a changeset.
  2. The Changesets action opens (or updates) a "Version Packages" PR.
  3. Merging the Version Packages PR triggers:
    1. Version bump in package.json
    2. Docker images crane-copied from the CF registry to Docker Hub and the CF Registry public library (the exact images that passed E2E)
    3. npm package publish with the bumped version
    4. Standalone binaries extracted and uploaded to the GitHub Release

Version Synchronization

Docker image version MUST match the npm package version. This is enforced via ARG SANDBOX_VERSION in packages/sandbox/Dockerfile. Don't try to release them out of band.

  • SDK version is tracked in packages/sandbox/src/version.ts
  • Images build for linux/amd64 only, matching Cloudflare's production runtime (ARM Macs use Rosetta/QEMU locally, preserving dev/prod parity)
  • Images publish to both Docker Hub and registry.cloudflare.com/library/sandbox:{version} (with -python, -opencode, -musl, -desktop variants). Any authenticated Cloudflare customer can pull from the library/ namespace without our account ID.

Checklist

  • Filename in .changeset/ is descriptive (fix-stream-encoding.md, not patch.md)
  • Only @cloudflare/sandbox is listed
  • Bump type is patch (or minor for breaking changes)
  • Description explains the user-visible problem and benefit
  • Usage hint is included when relevant (flag name, option, method)
Repository
cloudflare/sandbox-sdk
Last updated
Created

Is this your skill?

If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.