-
For a major or minor release, create a release branch.
Release branches are initialized with a commit from
main
, and namedrelease-x.y
wherex.y
is the major and minor version. Patch version changes are committed to the release branch matching their major and minor version. -
Create two version bump PRs:
-
One PR should be to the
release-x.y
branch and do the following:-
Bump the version of all crates in the workspace to
x.y.z
. Workspace crate versions are specified in./Cargo.toml
.Here is a command to help find all the Cargo.toml files that need to be updated
grep -rl '^version = "' --include=Cargo.toml --exclude-dir='./lib' --exclude-dir='./examples' --exclude-dir='./ffi/guests' --exclude-dir='./target' .
-
Update the version string in contracts that contain it:
contracts/src/groth16/RiscZeroGroth16Verifier.sol
contracts/src/RiscZeroSetVerifier.sol
-
Update references to the
main
branch- Search for
risc0/risc0-ethereum/refs/heads/main
- Search for
-
Update
steel/CHANGELOG.md
to ensure it details the changes to be released. -
Remove the note at the top of
README.md
about being on themain
branch. -
Update
risc0
crate dependencies. In all workspaces:You can find the workspaces with
grep -rl --include="Cargo.toml" '\[workspace\]' --exclude-dir=./lib
- Change the reference for
risc0
crates (e.g.risc0-zkvm
,bonsai-sdk
) to the latest monorepo release. - Run
cargo update
. You can use.github/scripts/cargo-update.sh
to do this.
Here is a nifty oneliner to do that
grep -rl --include="Cargo.toml" '\[workspace\]' --exclude-dir=./lib | sort -u | xargs -n1 cargo check --manifest-path
- Change the reference for
-
Remove
Cargo.lock
from.gitignore
and commit all lock files.
-
-
The other PR should:
- Bump the version on the
main
branch to the next, unreleased, minor versionx.y+1.0-alpha.1
. - Update the version string in contracts that contain it:
contracts/src/groth16/RiscZeroGroth16Verifier.sol
contracts/src/RiscZeroSetVerifier.sol
- Update
steel/CHANGELOG.md
to start a new section for the next release. - Update the value of
RISC0_MONOREPO_REF
in.github/workflow
files to the matching monorepo branch.
- Bump the version on the
-
-
Tag the release as
vX.Y.Z
, and add release on GitHub.Also tag the release as
steel-v0.X.Y
, as long as Steel is pre-1.0 and so on a different version than the rest of the crates.Include a summary of the changes in the release notes.
-
Publish crates to
crates.io
Crates currently published to
crates.io
are:-
risc0-steel
NOTE: risc0-steel currently cannot be published to crates.io. See #202
-
risc0-build-ethereum
-
risc0-ethereum-contracts
NOTE: When publishing a new crate, make sure to add github:risc0:maintainers as an owner.
# Log in to crates.io. Create a token that is restricted to what you need to do (e.g. publish update) and set an expiry. cargo login # Dry run to check that the package will publish. Look through the output, e.g. at version numbers, to confirm it makes sense. cargo publish -p $PKG --dry-run # Actually publish the crate cargo publish -p $PKG
See the Cargo docs for more details.
-
-
When changes have been made to the verifier contract, deploy a new verifier contract and add it to the verifier router on each supported chain.
Refer to contracts/script/README.md for instructions on the steps involved.
-
Deploy the verifier contract and schedule the update.
-
After the timelock delay has passed (7 days on mainnet chains and 1 second on testnet), finish the operation to add the new verifier to the router.
-
Run the deployment tests to confirm that the state recorded in
deployment.toml
matches the state of the contracts deployed on-chain.You can run the tests against a single chain with the following command:
# In the contracts directory. FOUNDRY_PROFILE=deployment-test forge test -vv --fork-url="$RPC_URL"
You can run the tests against all supported chains with the following oneliner:
# In the contracts directory. for rpcurl in $(yq eval -e ".chains[].rpc-url" deployment_secrets.toml); do FOUNDRY_PROFILE=deployment-test forge test -vv --fork-url="$rpcurl"; done
-
Document the new addresses and version in the
dev.risczero.com
docs.
Use [contracts/generate_contract_address_table.py] to generate the tables. Python 3.11+ is required.
https://dev.risczero.com/api/blockchain-integration/contracts/verifier
-
-
Open a PR to risc0-foundry-template updating the references in
Cargo.toml
and in thelib/risc0
submodule to point to the new release branch.