docs(release): add versioning and releases information (#4917)
* ci(docs): test `cargo doc` warnings and errors * ci(docs): remove minimal profile * ci(docs): revert minimal and fix component name * ci(docs): try cargo doc alone * docs(release): add versioning and releases information * dosc(release): apply suggestions from code review Co-authored-by: teor <teor@riseup.net> * docs(release): apply multiple fixes from review * docs(release): allow more flexibility with release cycles * Apply suggestions from code review Co-authored-by: teor <teor@riseup.net> Co-authored-by: teor <teor@riseup.net>
This commit is contained in:
parent
2d7ea7c043
commit
085367fc37
|
@ -1,63 +0,0 @@
|
|||
# Go/No-Go Release Criteria
|
||||
|
||||
## Alpha Release
|
||||
|
||||
In the first alpha release, we want Zebra to participate in the network and replicate the Zcash chain state.
|
||||
We also want to validate proof of work and the transaction merkle tree, and serve blocks to peers.
|
||||
|
||||
### System Requirements
|
||||
|
||||
Our CI tests that Zebra builds, passes its tests, and syncs on recent Ubuntu Linux, macOS, and Windows.
|
||||
|
||||
See the [README](https://github.com/ZcashFoundation/zebra/blob/main/README.md#system-requirements)
|
||||
for specific system requirements.
|
||||
|
||||
### Build Requirements
|
||||
|
||||
Our CI builds Zebra with:
|
||||
* Rust stable
|
||||
* recent llvm
|
||||
* recent clang
|
||||
* recent libclang
|
||||
|
||||
### Supported Platforms
|
||||
|
||||
While Zebra is still in alpha, we don't guarantee support for any particular platforms.
|
||||
|
||||
But you'll probably get the best results with a recent Ubuntu Linux, or the other platforms that our CI runs on.
|
||||
|
||||
### Go/No-Go Status: ⚠️
|
||||
|
||||
_Last updated: December 7 2020_
|
||||
|
||||
- `zebrad` Functionality
|
||||
- `zebrad` can sync to mainnet tip
|
||||
- ⚠️ under excellent network conditions (within 2 - 5 hours)
|
||||
- _reasonable and sub-optimal network conditions are not yet supported_
|
||||
- `zebrad` can stay within a few blocks of the mainnet tip after the initial sync
|
||||
- ⚠️ under excellent network conditions
|
||||
- _reasonable and sub-optimal network conditions are not yet supported_
|
||||
- ✅ `zebrad` can validate proof of work
|
||||
- ✅ `zebrad` can validate the transaction merkle tree
|
||||
- ⚠️ `zebrad` can serve blocks to peers
|
||||
- ✅ The hard-coded [checkpoint lists](https://github.com/ZcashFoundation/zebra/tree/main/zebra-consensus/src/checkpoint) are up-to-date
|
||||
- `zebrad` Performance
|
||||
- ✅ `zebrad` functionality works on platforms that meet its system requirements
|
||||
- Testing
|
||||
- ⚠️ CI Passes
|
||||
- ✅ Unit tests pass reliably
|
||||
- ✅ Property tests pass reliably
|
||||
- ⚠️ Acceptance tests pass reliably
|
||||
- ✅ Each Zebra crate [builds individually](https://github.com/ZcashFoundation/zebra/issues/1364)
|
||||
- Implementation and Launch
|
||||
- ✅ All [release blocker bugs](https://github.com/ZcashFoundation/zebra/issues?q=is%3Aopen+is%3Aissue+milestone%3A%22First+Alpha+Release%22+label%3AC-bug) have been fixed
|
||||
- ✅ The list of [known serious issues](https://github.com/ZcashFoundation/zebra#known-issues) is up to date
|
||||
- ✅ The Zebra crate versions are up to date
|
||||
- ⚠️ Users can access [the documentation to deploy `zebrad` nodes](https://github.com/ZcashFoundation/zebra#getting-started)
|
||||
- User Experience
|
||||
- ✅ Build completes within 40 minutes in Zebra's CI
|
||||
- ✅ Unused dependencies have been removed (use `cargo-udeps`)
|
||||
- ✅ `zebrad` executes normally
|
||||
- ✅ `zebrad`'s default logging works reasonably well in a terminal
|
||||
- ✅ panics, error logs, and warning logs are rare on mainnet
|
||||
- ✅ known panics, errors and warnings have open tickets
|
|
@ -0,0 +1,118 @@
|
|||
# Zebra versioning and releases
|
||||
|
||||
This document contains the practices that we follow to provide you with a leading-edge application, balanced and with stability.
|
||||
We strive to ensure that future changes are always introduced in a predictable way.
|
||||
We want everyone who depends on Zebra to know when and how new features are added, and to be well-prepared when obsolete ones are removed.
|
||||
|
||||
<a id="versioning"></a>
|
||||
|
||||
## Zebra versioning
|
||||
|
||||
Zebra version numbers indicate the level of changes that are introduced by the release.
|
||||
This use of [semantic versioning](https://semver.org/ "Semantic Versioning Specification") helps you understand the potential impact of updating to a new version.
|
||||
|
||||
Zebra version numbers have three parts: `major.minor.patch`.
|
||||
For example, version `3.1.11` indicates major version 3, minor version 1, and patch level 11.
|
||||
|
||||
The version number is incremented based on the level of change included in the release.
|
||||
|
||||
<div class="alert pre-release">
|
||||
|
||||
**NOTE**: <br />
|
||||
As Zebra is in a `pre-release` state (is unstable and might not satisfy the intended compatibility requirements as denoted by its associated normal version).
|
||||
The pre-release version is denoted by appending a hyphen and a series of dot separated identifiers immediately following the patch version.
|
||||
|
||||
</div>
|
||||
|
||||
| Level of change | Details |
|
||||
|:--- |:--- |
|
||||
| Major release | Contains significant new features, and commonly correspond to network upgrades; some technical assistance may be needed during the update. When updating to a major release, you may need to follow the specific upgrade instructions provided in the release notes. |
|
||||
| Minor release | Contains new smaller features. Minor releases are should be fully backward-compatible. No technical assistance is expected during update. If you want to use the new features in a minor release, you might need to follow the instructions in the release notes. |
|
||||
| Patch release | Low risk, bug fix release. No technical assistance is expected during update. |
|
||||
|
||||
<a id="supported-releases"></a>
|
||||
|
||||
### Supported Releases
|
||||
|
||||
Older Zebra versions are always supported until:
|
||||
* the next Zebra major, minor or patch release.
|
||||
|
||||
Initially, we can only guarantee support for the latest Zebra release. We might be able to provide support for earlier releases, or we might ask you to upgrade to the latest release.
|
||||
|
||||
Our support periods will be extended as we gain experience with supporting Zebra releases.
|
||||
|
||||
Older Zebra versions that only support previous network upgrades will never be supported, because they are operating on an unsupported Zcash chain fork.
|
||||
|
||||
<a id="updating"></a>
|
||||
|
||||
### Supported update paths
|
||||
|
||||
You can update to any version of Zebra, provided that the following criteria are met:
|
||||
|
||||
* The version you want to update *to* is supported.
|
||||
* The version you want to update *from* is within one major version of the version you want to
|
||||
upgrade to.
|
||||
|
||||
See [Keeping Up-to-Date](guide/updating "Updating your projects") for more information about updating your Zebra projects to the most recent version.
|
||||
|
||||
<a id="previews"></a>
|
||||
|
||||
### Preview releases
|
||||
|
||||
We let you preview what's coming by providing Release Candidate \(`rc`\) pre-releases for some major releases:
|
||||
|
||||
| Pre-release type | Details |
|
||||
|:--- |:--- |
|
||||
| Beta | The release that is under active development and testing. The beta release is indicated by a release tag appended with the `-beta` identifier, such as `8.1.0-beta.0`. |
|
||||
| Release candidate | A release for final testing of new features. A release candidate is indicated by a release tag appended with the `-rc` identifier, such as version `8.1.0-rc.0`. |
|
||||
|
||||
<a id="frequency"></a>
|
||||
|
||||
## Release frequency
|
||||
|
||||
We work toward a regular schedule of releases, so that you can plan and coordinate your updates with the continuing evolution of Zebra.
|
||||
|
||||
<div class="alert is-helpful">
|
||||
|
||||
Dates are offered as general guidance and are subject to change.
|
||||
|
||||
</div>
|
||||
|
||||
In general, expect the following release cycle:
|
||||
|
||||
* A major release for each network upgrade, whenever there are breaking changes to Zebra (by API, severe bugs or other kind of upgrades)
|
||||
* Minor releases for significant new Zebra features or severe bug fixes
|
||||
* A patch release every few weeks
|
||||
|
||||
This cadence of releases gives eager developers access to new features as soon as they are fully developed and pass through our code review and integration testing processes, while maintaining the stability and reliability of the platform for production users that prefer to receive features after they have been validated by Zcash and other developers that use the pre-release builds.
|
||||
|
||||
<a id="deprecation"></a>
|
||||
|
||||
## Deprecation practices
|
||||
|
||||
Sometimes "breaking changes", such as the removal of support for RPCs, APIs, and features, are necessary to:
|
||||
|
||||
* add new Zebra features,
|
||||
* improve Zebra performance or reliability,
|
||||
* stay current with changing dependencies, or
|
||||
* implement changes in the \(blockchain\) itself.
|
||||
|
||||
To make these transitions as straightforward as possible, we make these commitments to you:
|
||||
|
||||
* We work hard to minimize the number of breaking changes and to provide migration tools, when possible
|
||||
* We follow the deprecation policy described here, so you have time to update your applications to the latest Zebra binaries, RPCs and APIs
|
||||
* If a feature has critical security or reliability issues, and we need to remove it as soon as possible, we will explain why at the top of the release notes
|
||||
|
||||
To help ensure that you have sufficient time and a clear path to update, this is our deprecation policy:
|
||||
|
||||
| Deprecation stages | Details |
|
||||
|:--- |:--- |
|
||||
| Announcement | We announce deprecated RPCs and features in the [change log](https://github.com/ZcashFoundation/zebra/blob/main/CHANGELOG.md "Zebra change log"). When we announce a deprecation, we also announce a recommended update path. |
|
||||
| Deprecation period | When a RPC or a feature is deprecated, it is still present until the next major release. A deprecation can be announced in any release, but the removal of a deprecated RPC or feature happens only in major release. Until a deprecated RPC or feature is removed, it is maintained according to the Tier 1 support policy, meaning that only critical and security issues are fixed. |
|
||||
| Rust APIs | The Rust APIs of the Zebra crates are currently unstable and unsupported. Use the `zebrad` commands or JSON-RPCs to interact with Zebra. |
|
||||
|
||||
<a id="process"></a>
|
||||
|
||||
## Release candidate & release process
|
||||
|
||||
Our release checklist is available as a template, which defines each step our team needs to follow to create a new pre-release or release, and to also build and push the binaries to the official channels [Release Checklist Template](https://github.com/ZcashFoundation/zebra/blob/main/.github/PULL_REQUEST_TEMPLATE/release-checklist.md).
|
Loading…
Reference in New Issue