From 950ca5535ba52de3aafd861fd00a75d5c0bf0125 Mon Sep 17 00:00:00 2001 From: Blaine Bublitz Date: Fri, 3 Feb 2023 13:17:20 -0700 Subject: [PATCH] feat(docs): Introduce Conventional Commits & release process docs (#717) chore(docs): Move community involvement docs to SUPPORT file feat(ci): Change release workflow to use release-please --- .github/workflows/release.yml | 92 ++++++++-------- CONTRIBUTING.md | 202 +++++++++++++++++++++++++++++++--- Cargo.toml | 2 + SUPPORT.md | 32 ++++++ 4 files changed, 262 insertions(+), 66 deletions(-) create mode 100644 SUPPORT.md diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 7e047dd0f32..076bea08525 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,58 +1,54 @@ -name: Publish -# --- -# For esoteric targets, there is probably a succint way to do it with a target array -# Alternatively, we can wait for action-rs to get a v2, where we can input 'targets' +name: Release on: push: - tags: - - 'v*' + branches: + - master jobs: - publish: - name: Publish for ${{ matrix.os }} - runs-on: ${{ matrix.os }} - strategy: - matrix: - name: [ - linux, - windows, - macos - ] - - include: - - name: linux - os: ubuntu-20.04 - artifact_name: nargo - asset_name: nargo-linux - - name: windows - os: windows-latest - artifact_name: nargo.exe - asset_name: nargo-windows - - name: macos - os: macos-latest - artifact_name: nargo - asset_name: nargo-macos + release-please: + name: Create Release + outputs: + release-pr: ${{ steps.release.outputs.pr }} + runs-on: ubuntu-latest + steps: + - name: Run release-please + id: release + uses: google-github-actions/release-please-action@v3 + with: + release-type: simple + package-name: noir + bump-minor-pre-major: true + bump-patch-for-minor-pre-major: true + pull-request-title-pattern: "chore(noir): Release ${version}" + extra-files: | + Cargo.toml + update-lockfile: + name: Update lockfile + needs: [release-please] + if: ${{ needs.release-please.outputs.release-pr }} + runs-on: ubuntu-latest steps: - - uses: actions/checkout@v1 + - name: Checkout release branch + uses: actions/checkout@v3 + with: + ref: ${{ fromJSON(needs.release-please.outputs.release-pr).headBranchName }} + + - name: Setup toolchain + uses: dtolnay/rust-toolchain@1.65.0 - - name: 'Get Previous tag' - id: previoustag - uses: "WyriHaximus/github-action-get-previous-tag@master" - - - uses: actions-rs/toolchain@v1 - with: - profile: minimal - toolchain: stable + - name: Update lockfile + run: | + cargo update --workspace - - name: Build - run: cargo build --release --locked + - name: Configure git + run: | + git config user.name github-actions[bot] + git config user.email 41898282+github-actions[bot]@users.noreply.github.com - - name: Upload binaries to release - uses: svenstaro/upload-release-action@v1-release - with: - repo_token: ${{ secrets.GITHUB_TOKEN }} - file: target/release/${{ matrix.artifact_name }} - asset_name: ${{ matrix.asset_name }}-${{ steps.previoustag.outputs.tag }} - tag: ${{ github.ref }} + - name: Commit updates + run: | + git add Cargo.lock + git commit -m 'chore: Update lockfile' + git push diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index eaa89357fd9..a9cddd50c55 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,36 +1,202 @@ # Contributing to Noir -Thank you for your interest in contributing to Noir! There are many ways to contribute and we appreciate all of them. +Thank you for your interest in contributing to Noir! We value your contributions in making Noir better. -## Asking Questions +This guide will discuss how the Noir team handles [Commits](#commits), [Pull Requests](#pull-requests), [Merging](#merging), [Releases](#releases), and the [Changelog](#changelog). -The best place to ask general questions about Noir is in the #noir channel on the [Aztec discord](https://discord.gg/aztec). +__Note:__ We won't force external contributors to follow this verbatim, but following these guidelines definitely helps us in accepting your contributions. -It might also be helpful to review existing and previous Github issues to see if your question has been answered already. +## Commits -For specific technical questions, submitting an issue in this repo may be the best place to ask. +We want to keep our commits small and focused. This allows for easily reviewing individual commits and/or splitting up pull requests when they grow too big. Additionally, this allows us to merge smaller changes quicker and release more often. -## Giving Feedback +When committing, it's often useful to use the `git add -p` workflow to decide on what parts of the changeset to stage for commit. When making the commit, write the commit message as a Conventional Commit. -Feedback is a gift. The #noir channel on Discord is a great synchronous channel for feedback. Reporting issues that you encounter is also a great channel for sharing feedback. +### Conventional Commits -## Submitting Issues +As of the [126ca26](https://github.com/noir-lang/noir/commit/126ca26aaa955bbb002db90308223916a998179f) commit, Noir follows the [Conventional Commits (v1.0.0)](https://www.conventionalcommits.org/en/v1.0.0/) specification. Following this convention allows us to provide an automated release process that also generates a detailed Changelog. -Submitting an issue in this repository is a great way to contribute and get help with problems that you run into. -When submitting an issue, please include as much detail as possible about the error message, your environment (OS, version numbers, etc) and the steps to reproduce the error. +As described by the specification, our commit messages should be written as: -## Creating a Pull Request +``` +[optional scope]: -Before you create a pull request, create an issue that thoroughly describes the problem that the PR solves if it doesn't already exist. Reference the issue in your PR and follow PR template guidelines. +[optional body] -## Contributing to the Standard Library +[optional footer(s)] +``` -Noir is still very new and there are many cryptographic primitives that we have yet to build that will be useful for the community. If you have other ideas, please reach out on the [Aztec Discord](https://discord.gg/aztec) to discuss. You can find the current list of requested primitives in the [issues section](https://github.com/noir-lang/noir/labels/noir-stdlib) marked with the label `noir-stdlib`. +Some examples of this pattern include: -## Funding Opportunities +``` +feat(syntax): Implement String data type (#123) +``` -Aztec is offering grants to people and teams that want to use, test or build Noir. You can find more information about the grants program [here](https://aztec.network/grants). +``` +feat: Add support for wasm backend (#234) -## Full-time Contributors +Introduces a new backend to nargo that allows the wasm backend to be enabled via a flag. +``` -Aztec is hiring a wide variety of software engineers, so if you would like to work on Noir full-time consider applying for an [open role](https://aztec.network/careers). +``` +feat(syntax): Implement String data type (#123) + +Co-authored-by: Blaine +``` + +The `[optional body]` can also be used to provide more Conventional Commit messages for the Changelog: + +``` +feat(syntax): Add Boolean type + +fix(optimizer): Compile Boolean to u1 type +``` + +### Conventional Commits: Types + +Generally, we want to only use the three primary types defined by the specification: + +- `feat:` - This should be the most used type, as most work we are doing in the project are new features. Commits using this type will always show up in the Changelog. +- `fix:` - When fixing a bug, we should use this type. Commits using this type will always show up in the Changelog. +- `chore:` - The least used type, these are **not** included in the Changelog unless they are breaking changes. But remain useful for an understandable commit history. + +### Conventional Commits: Breaking Changes + +Annotating **BREAKING CHANGES** is extremely important to our release process and versioning. To mark a commit as breaking, we add the `!` character after the type, but before the colon. For example: + +``` +feat!: Rename nargo build to nargo check (#693) + +feat(nargo)!: Enforce minimum rustc version +``` + +### Conventional Commits: Scopes + +Scopes significantly improve the Changelog, so we want to use a scope whenever possible. If we are only changing one part of the project, we can use the name of the crate, like `(nargo)` or `(noirc_driver)`. If a change touches multiple parts of the codebase, there might be a better scope, such as using `(syntax)` for new language features. + +``` +feat(nargo): Add support for wasm backend (#234) +``` + +``` +feat(syntax): Implement String data type (#123) +``` + +## Pull Requests + +Before you create a pull request, search for any issues related to the change you are making. If none exist already, create an issue that thoroughly describes the problem that you are trying to solve. These are used to inform reviewers of the original intent and should be referenced via the pull request template. + +Pull Requests should be focused on the specific change they are working towards. If prerequisite work is required to complete the original pull request, that work should be submitted as a separate pull request. + +This strategy avoids scenarios where pull requests grow too large/out-of-scope and don't get proper reviews—we want to avoid "LGTM, I trust you" reviews. + +The easiest way to do this is to have multiple Conventional Commits while you work and then you can cherry-pick the smaller changes into separate branches for pull requesting. + +### Reviews + +For any repository in the noir-lang organization, we require code review & approval by **one** Noir team member before the changes are merged, as enforced by GitHub branch protection. Non-breaking pull requests may be merged at any time. Breaking pull requests should only be merged when the team has general agreement of the changes and is preparing a breaking release. + +### With Breaking Changes + +Sometimes, we don't merge pull requests with breaking changes immediately upon approval. Since a breaking change will cause Noir to bump to the next "minor" version, we might want to land some fixes in "patch" releases before we begin working on that next breaking version. + +## Merging + +Once approved by the required number of team members, the pull request can be merged into the `master` branch. Sometimes, especially for external contributions, the final approver may merge the pull request instead of the submitter. + +We use "squash merging" to merge all pull requests. This will cause all commits to be combined into one commit—another reason we want to keep pull requests small & focused. + +### Squash Merging + +When squash merging, we can keep intermediate Conventional Commits by adding them to the body of the commit message; however, the GitHub UI adds a `*` character before each commit message and our releaser bot won't parse that. + +When squashing, you want to update both the title of the commit to be a good Conventional Commit and adjust the body to contain any other Conventional Commits that you want to keep (not prefixed with `*`) and delete any extra information. We also keep any "Co-authored-by:" lines at the bottom of the commit if the change was done by multiple authors. If "Co-authored-by:" lines appear due to accepted PR suggestions, it's good to delete them so the author gets full credit for the change. + +Our overall approach to squashing is to be mindful of the impact of each commit. The commits populate our Changelog, so it's important to properly convey to Noir consumers what changes have happened. It is also a record that we and others will review in the future. Thus, we want to attribute the change to its correct authors and provide useful information that future contributors need. + +For example, given the default squash commit message: + +``` +feat(syntax): Implement first-class functions (#123) + +* clippy + +* formatting + +* chore(ci): Use correct rust version + +* review comment changes + +* Accepted suggestion from @john + +* clippy +``` + +The person merging would remove extraneous messaging and keep only the relevant Conventional Commits: + +``` +feat(syntax): Implement String data type (#123) + +chore(ci): Use correct rust version +``` + +Additional Conventional Commits can be added before squashing if they improve the Changelog or commit history: + +``` +feat(syntax): Implement String data type (#123) + +chore(ci): Use correct rust version +chore(clippy): Update all print calls to use single argument syntax +``` + +### Merge Checklist + +Before merging, you should mentally review these questions: + +- Is continuous integration passing? +- Do you have the required amount of approvals? +- Does anyone else need to be pinged for thoughts? +- Will this cause problems for our release schedule? For example: maybe a patch release still needs to be published. +- What details do we want to convey to users in the Changelog? + +## Releases + +Noir releases are managed by [Release Please](https://github.com/googleapis/release-please) which runs in a GitHub Action whenever a commit is made on the `master` branch. + +Release Please parses Conventional Commit messages and opens (or updates) a pull request against the `master` branch that contains updates to the versions & Changelog within the project. If it doesn't detect any breaking change commits, it will only increment the "patch" version; however, if it detects a breaking change commit, it will increment the "minor" version number to indicate a breaking release. + +When we are ready to release the version, we approve and squash the release pull request into `master`. Release Please will detect this merge and generate the appropriate tags for the release. Additional release steps may be triggered inside the GitHub Action to automate other parts of the release process. + +## Changelog + +Noir's Changelog is automatically managed by Release Please and informed by the Conventional Commits (as discussed above). + +Given the following commits: +- `feat(syntax): Implement String data type (#123)` +- `chore(ci): Use correct rust version` +- `fix(optimizer): Compile Boolean to u1` +- `feat(nargo): Add support for wasm backend (#234)` +- `feat!: Rename nargo build to nargo check (#693)` +- `feat(nargo)!: Enforce minimum rustc version` + +Release Please would generate add the following to the Changelog: + +```markdown +## [0.2.0](https://github.com/noir-lang/noir/compare/noir-v0.1.0...noir-v0.2.0) (2023-01-25) + +### ⚠ BREAKING CHANGES + +* **nargo:** Enforce minimum rustc version +* Rename nargo build to nargo check (#693) + +### Features + +* **nargo:** Enforce minimum rustc version +* Rename nargo build to nargo check (#693) +* **nargo:** Add support for wasm backend (#234) +* **syntax:** Implement String data type (#123) + +### Bug Fixes + +* **optimizer:** Compile Boolean to u1 +``` diff --git a/Cargo.toml b/Cargo.toml index 6abd49313a1..4bf2c85356c 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -15,7 +15,9 @@ members = [ default-members = ["crates/nargo"] [workspace.package] +# x-release-please-start-version version = "0.1.0" +# x-release-please-end authors = ["The Noir Team "] edition = "2021" rust-version = "1.64" diff --git a/SUPPORT.md b/SUPPORT.md new file mode 100644 index 00000000000..82d585937e4 --- /dev/null +++ b/SUPPORT.md @@ -0,0 +1,32 @@ +# Participating in the Noir community + +Thank you for your interest in Noir! There are many ways to participate in the community and we appreciate all of them. + +## Asking Questions + +The best place to ask general questions about Noir is in the #noir channel on the [Aztec discord](https://discord.gg/aztec). + +It might also be helpful to review existing and previous Github issues to see if your question has been answered already. + +For specific technical questions, submitting an issue in this repo may be the best place to ask. + +## Giving Feedback + +Feedback is a gift. The #noir channel on Discord is a great synchronous channel for feedback. Reporting issues that you encounter is also a great channel for sharing feedback. + +## Submitting Issues + +Submitting an issue in this repository is a great way to contribute and get help with problems that you run into. +When submitting an issue, please include as much detail as possible about the error message, your environment (OS, version numbers, etc) and the steps to reproduce the error. + +## Contributing to the Standard Library + +Noir is still very new and there are many cryptographic primitives that we have yet to build that will be useful for the community. If you have other ideas, please reach out on the [Aztec Discord](https://discord.gg/aztec) to discuss. You can find the current list of requested primitives in the [issues section](https://github.com/noir-lang/noir/labels/noir-stdlib) marked with the label `noir-stdlib`. + +## Funding Opportunities + +Aztec is offering grants to people and teams that want to use, test or build Noir. You can find more information about the grants program [here](https://aztec.network/grants). + +## Full-time Contributors + +Aztec is hiring a wide variety of software engineers, so if you would like to work on Noir full-time consider applying for an [open role](https://aztec.network/careers).