Skip to content

Commit

Permalink
Merge pull request #881 from sgibson91/xref-eng-review
Browse files Browse the repository at this point in the history
Cross-link review and merge guidelines from infrastructure docs
  • Loading branch information
sgibson91 authored Jul 24, 2024
2 parents 8bc0340 + a319a38 commit 1fed157
Showing 1 changed file with 1 addition and 36 deletions.
37 changes: 1 addition & 36 deletions engineering/reviewing.md
Original file line number Diff line number Diff line change
@@ -1,39 +1,4 @@
(development:merge-policy)=
# Merge and Code Review policy

The sections below describe major policies around merging and reviewing depending on the kind of change being made.
There are some extra policies for changes that **affect actively-running infrastructure**.
See the section below for details.

Not all of them are followed strictly, though some are more important than others, and are marked with **REQUIRED**.

- **Always make a Pull Request**. (REQUIRED).
All changes to 2i2c repositories should be made via a Pull Request.
This should be enforced by setting the `main`/`master` branch of each repository to be "protected".
- **PRs should reference (and close) issues**.
A pull request should almost always be related to an issue.
Ideally, the issue should be tightly-scoped enough that the PR will close it when merged.
If you have an idea that *doesn't* yet have an issue, open an issue first and then make the PR to close it.
This ensures that the team has context around Pull Requests, and a chance to discuss before we implement.
- **Use GitHub's `Request Review` feature**.
Add specific team members so that it is clear who is needed to review the PR.
- **Be explicit about what feedback you want**.
When you open a PR, include some language about specific things you'd like feedback with, if applicable.
This helps others focus their attention.
- **Use the review column on sprint boards**.
When a PR needs review, move any relevant issues to the {kbd}`Review` column of the active [Sprint Board](coordination:deliverables-backlog) so others notice it.
- **Merge after one approval**.
If there is at least one approval on a PR, then anybody, including the PR author, may merge the PR.
PR authors should not hesitate to merge their own PR after an approval if they think it is ready to go!
- **Merging without review is discouraged, but not forbidden**.
For changes that are minor, very straightforward, and do not affect actively-running infrastructure, it is acceptable to self-merge a PR without getting an approval.
If you don't believe that your PR requires an approval before merging, make it clear in your PR or in a comment that you plan to merge it in 24 hours.
- **Leave PRs open for at least 24 working hours**.
This helps ensure that others on the team have a chance to look at the PR and give their thoughts (by working hours we mean hours during a weekday).


## Policy for changes to running infrastructure

Changing active infrastructure is a bit different from developing technology that is not immediately in production.
As such, we follow some more specific guidelines for these kinds of changes.
See {external+infra:ref}`infrastructure:review`.
[See the Review and Merge Guidelines document for 2i2c engineers in the infrastructure documentation.](https://infrastructure.2i2c.org/contributing/code-review/)

0 comments on commit 1fed157

Please sign in to comment.