Thanks Kevan for the summary, I think this really helps.

More comments below inline...

On Sep 6, 2006, at 1:34 PM, Kevan Miller wrote:
1. Relaxed RTC

...

* 3 +1 votes from committers on the project (1 of these committers needs to be a member of the PMC) with no outstanding -1 votes.

I don't think that we need a requirement of a PMC vote here. The PMC can provide enough oversight w/o a required vote. IMO, a vote is a vote is a vote... I don't put any weight over a committers vote to a PMC members vote. I value them both equally. Forcing a PMC vote here is artificial and promotes separatism rather than unity.


2. RTC with Lazy Consensus

Geronimo follows a Review-Then-Commit model with Lazy consensus. Patches for new function are provided by developers for review and comment by their peers. Feedback is conducted through JIRA comments. The goal of this interaction is to solicit suggestions from the community and incorporate their feedback as appropriate. A patch is accepted if:

* 3 +1 votes from committers on the project with no outstanding -1 votes and no significant, ongoing discussion

* 72 hours pass with no outstanding -1 votes and no significant, ongoing discussion. A 24 hour warning should be sent to the dev list.

For the most part I like this model... but only for non-trivial changes, see below.


3. CTR with documentation guidelines

Geronimo follows a Commit-Then-Review model. There should be an emphasis of community communication. Community-based policing and persuasion will be used to remedy any problem areas. Guidelines are not strict dogma -- common sense should prevail. Community communication is the key, not a process. General guidelines are:

* Non-trivial changes (and certainly potentially controversial changes) should be announced on the dev list. This announcement should be well in advance of the change being committed. The community should be given the opportunity to understand and discuss the proposal.

* Concurrent with the commit of a significant change, the committer should document the change on the dev list. You should describe what you are doing, describe why you are doing it, and provide an overview of how you implemented it.

This feels a whole lot like common-sense for how to participate on an open-source project. In most cases, I think this is also the best model to run under... though I do believe that RTC has some merit as well.

If it was up to me (which it isn't, but here is my opinion anyways), I would use a hybrid model, which would default to CTR (with emphasis on common sense and communication) and for non-trivial or potentially controversial changes follow the RTC with Lazy Consensus as described in #2 (with the addition of inclusion of development branches or patches, depending on the complexity). I actually think that this is common-sense too.

IMO... this is the best of both worlds, without being too overbearing on policy and process, leveraging the trust of the developers and fostering our community with sufficient oversight and freedom to allow real progress to be achieved.

 * * *

But Jason... how do I know what is non-trivial or controversial?

Well, if you have to ask this... either common sense has failed you ( :-P ) or you should consider your changes to be non-trivial/ controversial and propose the change under RTC w/LC.

But Jason... what if someone commits something that I think should have been RTC w/LC?

Well, you communicate that to the group, explaining why you think the change was non-trivial/controversial and then we work together as a community to resolve the issue, potentially educating the developer if the change should have been RTC w/LC or educating why it was not and if needed backing out the change and re-proposing it via RTC w/ LC. This too feels like common sense.

But Jason... I think you are on crack... and I want to smoke some too!

Okay, you are on your own there... just make sure you clean your pipe, cause their ain't nuthing worse than a dirty ole crack pipe. :-P

--jason

Reply via email to