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

Define when a PR is "ready to merge" #4625

Closed

Conversation

Aneurysm9
Copy link
Member

Signed-off-by: Anthony J Mirabella a9@aneurysm9.com

Description: Copied definition of "ready to merge" from OTel Go.

Signed-off-by: Anthony J Mirabella <a9@aneurysm9.com>
@Aneurysm9 Aneurysm9 requested review from a team and owais January 3, 2022 23:47
@Aneurysm9 Aneurysm9 added the Skip Changelog PRs that do not require a CHANGELOG.md entry label Jan 3, 2022
@codecov
Copy link

codecov bot commented Jan 3, 2022

Codecov Report

Merging #4625 (58ca33d) into main (51fcb65) will not change coverage.
The diff coverage is n/a.

Impacted file tree graph

@@           Coverage Diff           @@
##             main    #4625   +/-   ##
=======================================
  Coverage   90.35%   90.35%           
=======================================
  Files         181      181           
  Lines       10591    10591           
=======================================
  Hits         9570     9570           
  Misses        797      797           
  Partials      224      224           

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 51fcb65...58ca33d. Read the comment docs.

Copy link

@bhs bhs left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

no major objections... mostly just clarifications in this review.

CONTRIBUTING.md Outdated Show resolved Hide resolved
CONTRIBUTING.md Outdated Show resolved Hide resolved
CONTRIBUTING.md Outdated Show resolved Hide resolved
changes it should be assumed that the PR needs their review again. Other
project members (e.g. approvers, maintainers) can help with this if there are
any questions or if you forget to clear reviews.
* It has been open for review for at least one working day. This gives
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

my two cents: 24h is pretty short for substantive changes... I usually specify 48h when I'm waiting for final approval on a large/meaningful change.

@bhs
Copy link

bhs commented Jan 4, 2022

... as for the thread that inspired this PR in #4605: in reading that exchange it's not clear whether we all even agree on the facts of the matter (namely, was this actually a significant set of changes or basically an uncontroversial refactor? was the necessary context to understand the change available when the PR was created? etc).

What does seem to be clear is that the various vendors building a technical strategy around the collector want to be on equal footing as far as design decisions. Is that the thing we're trying to solve for with this (#4625) PR?

Signed-off-by: Anthony J Mirabella <a9@aneurysm9.com>
@Aneurysm9 Aneurysm9 linked an issue Jan 4, 2022 that may be closed by this pull request
Copy link
Member

@jpkrohling jpkrohling left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would be willing to give it a try. I'm a bit worried that we might not have enough approvers interested in reviewing all PRs, but if this turns out to be a problem, we can change the policy again.

Copy link
Member

@bogdandrutu bogdandrutu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not going to approve this, since this behavior encourages large "unreviewable" PRs. If this gets merge as is we encourage PRs authors to send 1000+ lines PRs, see also what is proposed here #4630 which are impossible to carefully review, I would not be a maintainer of this project.

@Aneurysm9
Copy link
Member Author

I'm sorry, @bogdandrutu, but I believe that you are out of step with what the other contributors and users of this project want.

I do not understand how this policy would "encourage PRs authors to send 1000+ lines PRs". It says nothing about PR size, only what procedural steps must be satisfied before a PR is ready to be merged. We have used the same policy on the OTel Go repos for a long time and have not appeared to encourage overly-large PRs.

@tigrannajaryan as the other maintainer on this repository will you please provide your feedback?

@bogdandrutu
Copy link
Member

I do not understand how this policy would "encourage PRs authors to send 1000+ lines PRs". It says nothing about PR size, only what procedural steps must be satisfied before a PR is ready to be merged. We have used the same policy on the OTel Go repos for a long time and have not appeared to encourage overly-large PRs.

Because of the time constraints and artificial requirement of companies review, also because of inactivity of a lot of the approvers, everyone will create a large PR and pray to God to get necessary approvers from different companies.

Also this artificially increases the "power" of less represented companies, by the artificial requirement to have approvers from different companies.

I do understand why this is important for a project like specification, but does not make any sense here.

@Aneurysm9
Copy link
Member Author

Because of the time constraints and artificial requirement of companies review, also because of inactivity of a lot of the approvers, everyone will create a large PR and pray to God to get necessary approvers from different companies.

For the vast majority of PRs this would change nothing. Any PR that is approved by anyone not from Splunk and merged would satisfy this policy as the merging maintainer would provide the second approval. In contrib it becomes even less of an issue as there are non-Splunk maintainers.

Also this artificially increases the "power" of less represented companies, by the artificial requirement to have approvers from different companies.

I don't understand this perspective. Adding this requirement wouldn't increase the "power" of any company except to the extent that it would decrease the "power" of Splunk and put all participants on a level playing field. Any "less represented compan[y]" with an approver can already put a block on a PR.

I do understand why this is important for a project like specification, but does not make any sense here.

It makes perfect sense here, but I believe that you are blinded to its necessity as you benefit from the status quo.

@bogdandrutu
Copy link
Member

For the vast majority of PRs this would change nothing. Any PR that is approved by anyone not from Splunk and merged would satisfy this policy as the merging maintainer would provide the second approval. In contrib it becomes even less of an issue as there are non-Splunk maintainers.

@Aneurysm9 from your comments it is clearly that you have a problem with "Splunk" maintainers, since you refer only for Splunk people.

I don't understand this perspective. Adding this requirement wouldn't increase the "power" of any company except to the extent that it would decrease the "power" of Splunk and put all participants on a level playing field. Any "less represented compan[y]" with an approver can already put a block on a PR.

This is yet one more time when you have a problem with Splunk not want the best for the project, or you will argue that the best for the project is to remove Splunk :))

It makes perfect sense here, but I believe that you are blinded to its necessity as you benefit from the status quo.

I may be ... I definitely benefit, especially when I look at this https://all.devstats.cncf.io/d/66/developer-activity-counts-by-companies?orgId=1&var-period_name=Last%202%20years&var-metric=contributions&var-repogroup_name=All&var-country_name=All&var-companies=All

@bogdandrutu
Copy link
Member

This to me sound like the real motivation is not to make the project more successful, but instead to reduce Splunk's influence and contribution to a project.

@Aneurysm9
Copy link
Member Author

I have no problem with Splunk or maintainers who represent Splunk. I have a problem with a single company having the ability to unilaterally execute changes to a community project and exercising that ability in non-transparent ways that appear to be related to their internal strategy. Splunk is the only company in that position in this repository, so of course I have mentioned Splunk and not other companies.

I am in no way advocating for the removal of Splunk. I am advocating for the removal of Splunk's privileged position with respect to this project. I think that is in the best interest of the project.

@open-telemetry/governance-committee I believe that we are unlikely to have further productive discussions on this matter in this forum and would ask for your intervention.

@yurishkuro
Copy link
Member

Added to next GC meeting agenda

@bhs
Copy link

bhs commented Jan 4, 2022

Two things...

Tactical question about what the GC is meant to discuss

I believe that we are unlikely to have further productive discussions on this matter in this forum and would ask for your intervention.

What is the GC meant to decide/discuss here? And do we want to either include @Aneurysm9 in our Thurs meeting? (Or should @bogdandrutu recuse himself?? Otherwise it seems like an asymmetric debate since in a "normal" GC meeting Bogdan would be part of the discussion, but Anthony would not)

About the larger issues here...

I really do see both points of view in this thread. I trust that Splunk has no bad intentions regarding the collector, and yet I recognize that there is opacity and an imbalanced playing field for non-Splunk community members when it comes to influencing the technical strategy for the collector.

We all want a trusting group of contributors here – not just because it feels good, but because groups of engineers who trust each other are frankly far more efficient. Thinking out loud: is there benefit to requiring that the Collector SIG have a multi-vendor and well-documented strategy and technical roadmap, and then allowing maintainers more latitude to move fast (even if it's a single vendor approving+merging) as long as the movement is consistent with the aforementioned strategy and technical roadmap. If changes get merged quickly (i.e., with only a single employer approving+merging) that are deemed, retroactively, to be misaligned to the strategy+roadmap, then there could be a policy to roll those changes back and discuss before rolling forward again.

If it's not obvious, my goal above is to address the strategic alignment and trust problems directly, rather than creating additional per-PR friction which might – ironically – erode trust further, contentious PR by contentious PR. All of this being said, if we can't find a way to create true strategic+technical alignment for the Collector SIG, requiring multiple employers to approve changes seems like a viable check-and-balance.

@bogdandrutu
Copy link
Member

What is the GC meant to decide/discuss here? And do we want to either include @Aneurysm9 in our Thurs meeting? (Or should @bogdandrutu recuse himself?? Otherwise it seems like an asymmetric debate since in a "normal" GC meeting Bogdan would be part of the discussion, but Anthony would not)

I think again if it is a matter of applying the rules then @Aneurysm9 should ask TC to decide on this PR. If this is about creating rules then GC should create org rules about how to merge PRs.

If the discussion is just about this PR (and not making the rule for the entire org) then @Aneurysm9 should be included correct. Not sure what GC can discuss about an individual PR, but if that is the case definitely include @Aneurysm9.

@carlosalberto
Copy link
Contributor

I think again if it is a matter of applying the rules then @Aneurysm9 should ask TC to decide on this PR. If this is about creating rules then GC should create org rules about how to merge PRs.

Let's discuss this in the TC too, as this seems a 'hot' topic.

@Aneurysm9
Copy link
Member Author

Aneurysm9 commented Jan 4, 2022

I view this as a project governance policy as it applies regardless of the technical impact of proposed changes. To that extent I think it is within the scope of the GC and the GC should resolve the issue if agreement cannot be reached within the SIG. It could certainly be argued that this relates to "[d]evelopment process and ... coding standards", which would be within the purview of the TC, but I do not expect everyone to be satisfied with any result there and thus it will ultimately come to the GC as the "final escalation path for any contested OpenTelemetry related decision". Given that the joint GC and TC have discussed this issue recently it is probably best that it be handled jointly and that a policy be established for the OpenTelemetry project as a whole and not just for this repository.

@tigrannajaryan
Copy link
Member

(All right, I am back to work after the winter break, sorry for delayed response).

[Meta] Quick reminder to everyone: in Otel we managed to create an environment of positive collaboration in the industry, often between competitors, which to me is extremely valuable. Let's keep it this way and work on improving what needs to be improved.

@Aneurysm9 can you please clarify, I am not sure I understand which of the following this change attempts to solve:

  • Make it easier for non-maintainers to merge their PRs.
  • Make it more difficult for maintainers from one company to merge PRs without sufficient oversight from the community?
  • Something else?

I want to make sure I clearly understand your point of view and what you see as a problem (which, you are right, we as maintainers may not necessarily experience as a problem).

@Aneurysm9
Copy link
Member Author

can you please clarify, I am not sure I understand which of the following this change attempts to solve:

* Make it easier for non-maintainers to merge their PRs.
* Make it more difficult for maintainers from one company to merge PRs without sufficient oversight from the community?

My initial frustration, and the proximal cause of this PR is the latter, though I think that my concern is more with the lack of sufficient oversight and less with the fact that both maintainers of this project represent the same company. A requirement of approval from members representing multiple companies is, in some sense, a proxy for consensus within the community. It is an imperfect proxy, but to my mind better than the current situation, which seems to me to be corrosive to that environment of positive collaboration that you rightly mention is an extremely valuable attribute of this project.

That said, it is my understanding that there has been a proposal circulated among the TC and GC that shares many of the same attributes of this proposal but that would also seek to reduce the friction for non-maintainer approvers seeking to merge PRs that have achieved consensus. I would be happy to have that proposal supplant this one, but doing nothing is not an option from my perspective.

I want to make sure I clearly understand your point of view and what you see as a problem (which, you are right, we as maintainers may not necessarily experience as a problem).

I have tried to lay out my concerns in a way that refrains from directing blame or culpability at any one person, and I don't think that any one person is entirely at fault, but perhaps I have not been clear enough and so I will stop speaking around what I see as the heart of the matter. It appears to me that Bogdan views the collector as his fiefdom to do with as he will without input from, or accountability to, anyone. He seems to make changes with little or no description of their intent or rationale, has them reviewed by someone from Splunk, and merges them before anyone can notice that a change has been proposed. He appears to hold others to a higher standard than he holds himself. I do not feel that he has the judgment or temperament to be the de facto sole maintainer of this project. As a community-run project we cannot afford to allow any individual to act as if they were BDFL.

The policy I have proposed here is one of a series of steps that I believe need to be taken to ensure that the community of collector developers and users can participate in this project on an equal footing and without fear or favor. I also think that the collector and collector-contrib repos need more approvers and maintainers (perhaps as much as four times the current roster) and that effort needs to be put in by the current maintainers to develop that pipeline. I don't believe that any one company should be represented by more than 49% of maintainers of a repository that has more that one maintainer, and I don't think any repository should have a sole maintainer, though that may be a challenge that is not amenable to policy-based solutions in some cases.

@anuraaga
Copy link
Contributor

anuraaga commented Jan 6, 2022

I agree with @bhs's point about a trusting group - the topic of requiring reviews from multiple employers came up in the past in opentelemetry-java-instrumentation but we decided we don't need it, we trust all the maintainers, even if two Splunk maintainers merge in a PR. In practice, we notice this rarely happens for core concepts and more for instrumentation libraries - everyone seems to be on the same page.

I don't believe that requiring two employers to merge can actually help with the issue of visibility to community members - it's easy for two members from different employers with a strong trust relationship to merge each others PRs quickly in the same way as it is for same employers, there just doesn't seem to be anything specific to the aspect of employer here.

Policies, which apply to everyone including maintainers, for better review before code is written could perhaps help. For example, requiring simple design docs for changes affecting core APIs in a significant way or discussion on an issue, could help. I think the key point is that not every PR should have to be slowed down, for example with a one-two day buffer for reviews, but that initial time spent could be spent before a large effort to get a diverse set of community members on the same page in a worthwhile way. FWIW, I don't know the details here and whether this happened or not, but based on the discussions assuming it didn't.

Another issue may have been too much discussion of collector direction in internal company forums / meetings. I think as maintainers in OTel, it is our responsibility to ensure this doesn't happen too much, at least in a way that can make other members feel affected. I try my best for AWS, and myself strongly avoid Quip for discussions about upstream topics. But it's hard and I don't feel so successful at this, my team still writes lots of Quip docs where I wish the discussion was more open. I can understand the tendency to have internal discussions within a company since people are used to it, but hopefully we can at least strive to reduce that where possible. Note that admittedly, this would be helped a bit with a 2-employer merge policy, but I don't feel this to be the brunt of the issue vs just trusting members having a tendency to merge fast.

@github-actions
Copy link
Contributor

This PR was marked stale due to lack of activity. It will be closed in 14 days.

@github-actions github-actions bot added the Stale label Jan 21, 2022
@Aneurysm9 Aneurysm9 removed the Stale label Jan 28, 2022
@github-actions
Copy link
Contributor

This PR was marked stale due to lack of activity. It will be closed in 14 days.

@github-actions github-actions bot added the Stale label Feb 12, 2022
@github-actions
Copy link
Contributor

Closed as inactive. Feel free to reopen if this PR is still being worked on.

@github-actions github-actions bot closed this Feb 26, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Skip Changelog PRs that do not require a CHANGELOG.md entry Stale
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Define when a PR is "ready to merge"
9 participants