Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Change merge policy #16

Open
3 of 4 tasks
durandom opened this issue Jan 21, 2021 · 22 comments
Open
3 of 4 tasks

Change merge policy #16

durandom opened this issue Jan 21, 2021 · 22 comments
Assignees

Comments

@durandom
Copy link
Member

durandom commented Jan 21, 2021

I propose to implement a review and merge process, similar to what we have in https://github.com/operate-first/ and discussed in operate-first/apps#81

This would encompass:

I'm not sure though if 2 approvals and bot merge can work - that could be circumvented by granting merge permissions to the @open-infrastructure-labs/operations team

This would be applicable to

@anishasthana
Copy link

That's how we currently do things in a number of other repos -- https://github.com/AICoE/idh-manifests/ as an example. 2 approvals and bot merge can work together without issue.

@larsks
Copy link

larsks commented Jan 25, 2021

Does @sesheta require "Write" or "Maintain" access to the repository?

@goern
Copy link

goern commented Jan 25, 2021

I question the 'two approvals' policy. I could imagine two roles: a reviewer (responsible for looking thru the PR making sure its good) and an582047410458 approver (basically depending on the reviewer and taking the accountability to merge the code)

If you envision a larger group of reviewers taking the majority of work, the approver is the one coordinating feature release, as it might require cross repo dependencies, or even constraints that are not documented as PR...

@goern goern mentioned this issue Jan 25, 2021
6 tasks
@durandom
Copy link
Member Author

I'm also good with one approval and multiple reviewers. Do the bots already support this workflow?
Otherwise we could start with 2 approvals and change later.
One goal is to speed up the merge process

@tumido
Copy link
Member

tumido commented Jan 25, 2021

@goern How does the bots treat a GitHub review though?

For the context, I like to review via the GitHub reviews, because then my review can be re-requested etc/cleared whenever needed and I prefer it over the /approve and /lgtm commands since I want to see who approved what and how many people actually saw it - like our ADRs.

If I "approve" something via a Github review and I'm listed as both Prow "approver" and Prow "reviewer" in that repo, does it mean that I've approved the PR and it will be auto-merged since I'm an approver? Therfore it would act and merge it even though only a single person saw it?

At some (auto-deployed) repos, I want at least 2 people to see a PR. The GitHub approval setting to 2 approves physically blocks people to merge something with a single review. I like that. I rather ping people to get a second pair of eyes on a PR than allow this to be bypassed. I like this to be a hard requirement, so we really have people engaged in the review process, so more than 1 or 2 people really knows what actually is in that particular repo (bus factor > 2).

@anishasthana
Copy link

++ @tumido

@goern
Copy link

goern commented Jan 25, 2021

for https://prow.operate-first.cloud/ a GitHub approving review is equivalent to a /approve comment, see https://github.com/thoth-station/thoth-application/blob/master/prow/overlays/cnv-prod/plugins.yaml#L80-L87 and https://godoc.org/k8s.io/test-infra/prow/plugins#Approve So the difference of a Prow approver and a GitHub reviewer is the power distribution: OR vs AND

Prow (more specifically to LGTM and approve plugins) try to distinguish by role: if reviewers are happy, the approver should be so confident, that he can simply click the button. so the real hard review work will finish with an /lgtm Depending solely on Prow to do all the review/approve/merge work would enable us to have all the srcops configuration in prow's yaml files...

@goern
Copy link

goern commented Jan 25, 2021

.. had a short call with @tumido here is our proposal and goal. We would like to experiment with the proposal on the /support repo tomorrow...

Goal

help the majority fo the team to do good code reviews and take responsibility for high-quality code. GitHub UI and Prow /-commands should enable the same workflows for the same kind of members.

Proposal

  1. create a Devs team on GitHub that is able to do 'triage' on support/, see https://docs.github.com/en/github/setting-up-and-managing-organizations-and-teams/repository-permission-levels-for-an-organization
  2. sort the OWNERS file, so that @tumido and @HumairAK are the approvers, the reviewers are all the members of the Devs team
  3. BTW, approvers are responsible to help reviewers doing a good job, see Goal ;)

@goern
Copy link

goern commented Jan 25, 2021

BTW, operate-first/apps#152 and AICoE/idh-manifests#77 and good examples of non-obvious configurations of GitHub and Prow that look fancy...

@tumido
Copy link
Member

tumido commented Jan 25, 2021

Just to add a bit more meat to it. The proposal should allow us:

  • We can do reviews in Github UI. If the GH review results in selecting the Approve action, it should translate to a lgtm label being applied by Prow
  • If a GH review result in requested changes, Prow is not touching a thing and a review can get re-requested as we are used to from the GH UI.
  • Reviewers can't merge, the GitHub button is disabled for them.
  • Approvers can merge manually, but it should be only a failsafe mechanism, it is preferred for them to merge via /approve command
  • Approvers heavily rely on reviewers reviewing PRs
  • Approvers can review via GitHub - the GitHub approve action should translate to a lgtm label being applied as well.
  • Only when an approver commands Prow to /approve the PR gets merged. No matter how many Github reviews with green tick a PR has, the approver must initiate the action.
  • The number of reviewers is much higher than approvers (only ~2 people can approve, many can review)
  • The OWNERS file is context aware, so we can have a different set of approvers for different paths/folders within repository. Therefore, for example in the operate-first/apps repository, each application can have a different set of approvers.

This should be rewritten as an ADR once we agree on the direction.

@HumairAK
Copy link

HumairAK commented Jan 25, 2021

This definitely seems like the most appropriate way of doing things. I guess my biggest concern is PRs getting bottlenecked by the specific set of approvers (we're still in relatively early stages where we're trying to move a bit rapidly). Separating out approvers by location, should help with this I'd imagine. But let's try it out, and see how it goes.

@HumairAK
Copy link

@tumido
With regards to:

The OWNERS file is context aware, so we can have a different set of approvers for different paths/folders within repository. Therefore, for example in the operate-first/apps repository, each application can have a different set of approvers.

Say if I have this scenario:

  • odh/monitoring has approvers x and y
  • odh/kafka has approvers a and b

If a pr changes odh/monitoring and odh/kafka then do all x,y,a, and b become approvers ?

@tumido
Copy link
Member

tumido commented Jan 25, 2021

No idea and a good question! 😄 @goern do you have any experience on how that would work?

@anishasthana
Copy link

What actually prompted this conversation? Our workflow seems to have been working fairly fine so far 🙂 .

Personally I'm not a fan of the owners + reviewers approach for operations-focused repositories (I think it makes perfect sense for development-focused projects like Kubernetes or CRI-o or w/e). I feel like this would result in knowledge being concentrated on specific folks(in this case @tumido and @HumairAK ), no? Allowing any of the "core" team members to approve PRs would result in knowledge being spread out better. Having specific operate-first members be responsible for approving specific components will result in knowledge silos. Now, specialization isn't a bad thing, but I figured with ops teams we'd want to spread the knowledge to the extent that we aren't reliant on any one person for a given component. With the internal data hub team, we did run into this problem where we had one or two overarching approvers who understood the whole picture, but most team members only focused on their own bits. This meant that PTO and the like are very disruptive.

I might not be understanding things correctly either, but this feels like it also might be over-engineering for a problem we haven't run into yet.

@tumido
Copy link
Member

tumido commented Jan 25, 2021

@anishasthana I don't think this solution/issue implies a knowledge sharing limitations/issues. I think that we need to change our view on the reviewer and approver roles.

The way I see it is that since "everybody" would be able to review, they have to know that the content actually is and does. Or at least this will allow them to obtain such knowledge (good position for newcomers also). The knowledge is being shared and silos are prevented. Approvers can act only upon somebody else's review. Therefore there must be somebody else who's willing to sign that this code is OK.

The approver role in this case to me is more about the responsibility of merging a PR. The approver should be the same person who would be asked to fix things when the merge (and a consecutive auto deploy) would break things. When a PR is merged the person who merged it, should go and really see, in real deployment, if it really did the change the PR was advertising to do.

Currently I don't see each and every person who merges something do that. Heck I don't do it myself. I merge a operate-first website PRs and I don't really monitor if the build succeeded or not and if the change was propagated. You see.. I know how that repo works, how it's set up and many other things about it. But I'm not the one who actually takes care of it.

I don't see this to be an issue about concentrating knowledge but rather concentrating responsibility, which we kinda need...

@HumairAK
Copy link

@tumido I think that's a great point. Especially now that we have automated the actual merges, and deployments, there must be clear indication to whom the onus falls upon to verify the changes are working as intended. We do not currently have this, and I think we've fallen into a bad habit of "Okay I've approved this, sesheta will merge it, let me go do other things now".

We must make clear that if you are approving, you own the responsibility to verifying these changes. So that each PR is always confirmed working in the live system.

@anishasthana
Copy link

Ah that makes a lot of sense, I didn't think of it from a responsibility standpoint at all.

@4n4nd
Copy link

4n4nd commented Jan 25, 2021

The approver should be the same person who would be asked to fix things when the merge (and a consecutive auto deploy) would break things.

I think people who approve PRs rn do know that this is their responsibility to fix things in case the PR breaks something. It just isn't written somewhere. So in a way we have "PR owners" instead of "app owners" we just need to explicitly write that down somewhere.

@tumido as we discussed, we have a small team spread over multiple time zones and sometimes it takes PRs longer to be reviewed because of that. Now when something breaks in our prod environment and we need to get a patch merged in immediately we would still need to wait for the app owner to approve the PR with this new policy and the app owner might be asleep in a different time zone.

@anishasthana
Copy link

Okay so from offline discussion a lot of the confusion has been cleared up. We all seemed to agree on the following:

OWNERS:
Anand, Humair, Tom
Reviewers:
OWNERS + Anish, Hema, Harshad, Martin

PRs need 2 Reviews followed by 1 approval

@tumido @HumairAK @4n4nd please let me know if I'm misrepresenting anything :-)

@HumairAK
Copy link

To add, we will keep reviewers selection based on round robin algorithm (this is by default afaik), to encourage others to review PRs and keep SILOs from forming.

PRs need 2 Reviews followed by 1 approval

The approver can also be one of the 2 reviewers in this case (i.e. approver does /lgtm and /approve)

@larsks
Copy link

larsks commented Jan 29, 2021

Reviewers:
OWNERS + Anish, Hema, Harshad, Martin

Sorry, I may not be following this discussion completely. Shouldn't the open-infrastructure-labs/operations team all be reviewers (rather than individuals)?

@HumairAK
Copy link

I think the conversation started expanding beyond open-infra and in general terms. AFAIK you can't add teams in an OWNERS file. Seems like you can have OWNERS_ALIAS.

But regardless, I think for all repos (whether here, or in operate-first) that contain cluster resources we should be including infra/ops folks.

sesheta pushed a commit to operate-first/apps that referenced this issue Feb 17, 2021
* ✨ rework OWNERS as mentioned in open-infrastructure-labs/ops-issues#16

Signed-off-by: Christoph Görn <[email protected]>

* ⬆️ backportet from thoth-application/ repo

Signed-off-by: Christoph Görn <[email protected]>

* ignore overrides/

Signed-off-by: Christoph Görn <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

7 participants