To cut a new release, first create a pull request from dev
into main
with the semver naming convention. For example 1.0.0-rc1
. This will enter wider team review and further testing where necessary to ensure bug-free code and presentableness to public.
Run tests and coverage:
$ yarn test
$ yarn coverage
Manual testing using hardhat tasks and public testnets are encouraged.
Mock development by using the library is also encouraged (or the use of bug bounties).
Enter the contracts directory:
$ cd contracts
Test the npm package with:
$ yarn pack
Ensure the resulting tarball includes all files that you expect the package to have.
Then create a new folder with a test project and install your package:
$ mkdir test-project
$ cd test-project
$ npm init
$ npm install <path/to/contractsdir>
The package should now be installed in your project's node_modules
and the contracts should be accessible through imports import "@violetprotocol/extendable/extendable/Extendable.sol";
Once checks and reviews pass, the release can be merged to main
and then tagged with the normal release number without the release candidate tagging e.g. 1.0.0
.
Then perform the publishing step to npm:
$ cd contracts
$ yarn prepare
$ npm login --scope=@violetprotocol
$ npm publish --access public --tag <version>
Ensure that the tag includes a changelog that documents the feature changes/additions/fixes that were included in the version that diff from the previous release.