Thanks Matt and Jason.

I'll update the proposals to remove the PMC requirement from Relaxed RTC.

I'm also going to update to make clear that the focus of this vote is trunk development. Initially, it would apply to branches, also. If we feel that branches need special controls, we should handle by refining our general process. I don't wan't to get hung up fixing *everything*...

Any other comments?

More inline...

On Sep 6, 2006, at 7:27 PM, Jason Dillon wrote:

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.

Totally agree. I almost made that change, but was consciously trying *not* to edit the proposals as I pulled them out of the various discussion threads.



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.

It's not bad and I think we can operate quite reasonably using this. However, I don't think it's necessary. I'd prefer to see the benefits of this approach handled by more up-front communication using CTR. By the time something is committed, it's not much of a surprise...



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.

I think RTC w/ lazy consensus is always available under a CTR model. However, I'd prefer it be self-imposed rather than expected. I wouldn't be upset if someone didn't follow RTC for a significant change. I would be upset if they failed to adequately communicate and discuss with the community...


 * * *

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

Jason, Perhaps it's time for a little holiday...  ;-)

--kevan

Reply via email to