From 95c5b3dea0e47879136180b2d0878b6cae70d502 Mon Sep 17 00:00:00 2001 From: Hein Dauven Date: Wed, 18 Dec 2024 15:25:14 +0100 Subject: [PATCH] meta: Add RELEASE.md --- RELEASE.md | 82 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 RELEASE.md diff --git a/RELEASE.md b/RELEASE.md new file mode 100644 index 000000000..45016deff --- /dev/null +++ b/RELEASE.md @@ -0,0 +1,82 @@ +# Rusk Monorepo Release Process + +## **1. Branching Strategy** + +### `master` Branch +- **Purpose:** Active development. +- **Policy:** + - All new features behind feature flags. + - Merged only after passing CI, integration tests, and approval. + +### `devnet` Branch +- **Purpose:** Weekly snapshots from `master` for early testing. +- **Policy:** Updated weekly, deploying directly to the Devnet environment. + +### Release Branches (`rusk-release-X.Y`) +- **Purpose:** Stable releases for mainnet or testnet deployments. +- **Why We Need It:** + - **Hotfix Management:** Allows hotfixes to be applied without branching from tags. + - **Long-Term Support:** Enables long-term support and backporting of fixes. + - **Clear Release Tracking:** Provides a clear path for version progression. + +- **Creation:** Every 1-3 months or as needed. +- **Hotfixes:** Created directly on the (affected) release branch. + +## **2. Tagging and Release Strategy** + +### Libraries +- `dusk-vm-X.Y.Z` (rusk-framework release?) +- `dusk-core-X.Y.Z` (rusk-framework release?) +- `dusk-wallet-core-X.Y.Z` (rusk-framework release?) +- `w3sper.js-X.Y.Z` + +### User-Facing Apps +- `explorer-X.Y.Z` +- `rusk-wallet-X.Y.Z` +- `web-wallet-X.Y.Z` + +### Blockchain Node +- `rusk-X.Y.Z` (node binary release) +- `rusk-framework-X.Y.Z` (library releases for components such as VM, core, wallet-core) + +**Example:** `rusk-1.2.3` + +## **3. Release Lifecycle** + +1. **Day 0:** Create release branch `rusk-release-X.Y` from `master`. +2. **Day 1:** Deploy release to **Testnet**. +3. **Day 7:** Release validated and stabilized in Testnet. +4. **Day 10:** Finalize integration tests and prepare for mainnet deployment. +5. **Day 14:** Community announcement and gradual provisioners upgrade. +6. **Day 16:** Deploy `rusk-X.Y.Z` to **Mainnet**. + +## **4. Compatibility and Testing** + +### **Testing Phases** +1. **Unit Tests:** Every PR must pass. +2. **Integration Tests:** Wallet, SDKs, contracts. +3. **Network Tests:** Simulate large-scale node clusters. +4. **Compatibility Tests:** Ensure backward compatibility with previous cluster. + +## **5. Release Artifacts** + +- **Crates.io Packages:** For Rust libraries (`dusk-vm`, `dusk-core`, `dusk-wallet-core`, `rusk-wallet`). +- **NPM/JSR Packages:** For JavaScript libraries (`w3sper.js`). +- **Docker Images:** Published for node: default and archive feature. +- **GitHub Releases:** For `rusk-wallet`, `web-wallet`, `explorer`, `rusk`, and `rusk-framework`. +- **Svelte Builds:** Uploaded to production servers after integration testing. + +## **6. Release Documentation** + +- **GitHub Release Notes:** Each release includes: + - Summary of changes. + - Migration steps (if applicable). + - Framework upgrade details. +- **Changelog Management:** Use automated changelog generation from PR labels (`breaking-change`, `enhancement`, `bug-fix`). + +## **7. Environment Versioning Policy** + +- **Local Development:** `X.Y.Z-dev` +- **Devnet:** `X.Y.Z-beta` +- **Testnet:** `X.Y.Z-rc` +- **Mainnet:** `X.Y`