<div dir="ltr">While I agree with most of what Thierry said, I need clarifications though, on what a Program is, and what is the key point where an idea should get its own Program instead of being headed by an already existing Program.<div>
<br></div><div>For example, take Barbican which is providing extra features to Keystone, or Docker which will provide its own API for managing VMs. Are they both eligible for new Programs, or should they stick to the existing programs (respectively Identity and Compute) ?</div>
<div><br></div><div>If the answer is "they can be part of the already existing Programs", then how can we leverage the difference in between the projects (ie. Keystone is Openstack, Barbican is Stackforge), and how could at some point the code getting incubated ?</div>
<div><br></div><div>That said, Climate (Reservations as a Service) does have the same concern, while we're not yet planning to ask for incubation until a certain point, which needs to be discussed internally.</div><div>
<br></div><div>Thanks,</div><div>-Sylvain</div><div><br></div><div><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">2013/12/13 Russell Bryant <span dir="ltr"><<a href="mailto:rbryant@redhat.com" target="_blank">rbryant@redhat.com</a>></span><br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On 12/13/2013 10:37 AM, Flavio Percoco wrote:<br>
> On 13/12/13 15:53 +0100, Thierry Carrez wrote:<br>
>> Hi everyone,<br>
>><br>
>> TL;DR: Incubation is getting harder, why not ask efforts to apply<br>
>> for a new program first to get the visibility they need to grow.<br>
>><br>
>> Long version:<br>
>><br>
>> Last cycle we introduced the concept of "Programs" to replace<br>
>> the concept of "Official projects" which was no longer working<br>
>> that well for us. This was recognizing the work of existing<br>
>> teams, organized around a common mission, as an integral part of<br>
>> "delivering OpenStack". Contributors to programs become ATCs, so<br>
>> they get to vote in Technical Committee (TC) elections. In<br>
>> return, those teams place themselves under the authority of the<br>
>> TC.<br>
>><br>
>> This created an interesting corner case. Projects applying for<br>
>> incubation would actually request two concurrent things: be<br>
>> considered a new "Program", and give "incubated" status to a code<br>
>> repository under that program.<br>
>><br>
>> Over the last months we significantly raised the bar for<br>
>> accepting new projects in incubation, learning from past<br>
>> integration and QA mistakes. The end result is that a number of<br>
>> promising projects applied for incubation but got rejected on<br>
>> maturity, team size, team diversity, or current integration level<br>
>> grounds.<br>
>><br>
>> At that point I called for some specific label, like "Emerging<br>
>> Technology" that the TC could grant to promising projects that<br>
>> just need more visibility, more collaboration, more<br>
>> crystallization before they can make good candidates to be made<br>
>> part of our integrated releases.<br>
>><br>
>> However, at the last TC meeting it became apparent we could<br>
>> leverage "Programs" to achieve the same result. Promising efforts<br>
>> would first get their mission, scope and existing results blessed<br>
>> and recognized as something we'd really like to see in OpenStack<br>
>> one day. Then when they are ready, they could have one of their<br>
>> deliveries apply for incubation if that makes sense.<br>
>><br>
>> The consequences would be that the effort would place itself<br>
>> under the authority of the TC. Their contributors would be ATCs<br>
>> and would vote in TC elections, even if their deliveries never<br>
>> make it to incubation. They would get (some) space at Design<br>
>> Summits. So it's not "free", we still need to be pretty<br>
>> conservative about accepting them, but it's probably manageable.<br>
>><br>
>> I'm still weighing the consequences, but I think it's globally<br>
>> nicer than introducing another status. As long as the TC feels<br>
>> free to revoke Programs that do not deliver the expected results<br>
>> (or that no longer make sense in the new world order) I think<br>
>> this approach would be fine.<br>
>><br>
>> Comments, thoughts ?<br>
>><br>
><br>
><br>
> My first thought while reading this email was:<br>
><br>
> What happens if that "Emerging Technology" doesn't move forward?<br>
<br>
</div></div>Thierry addressed that at the very end of his message:<br>
<div class="im"><br>
  As long as the TC feels free to revoke  Programs that do not deliver<br>
  the expected results (or that no longer make sense in the new world<br>
  order) I think this approach would be fine.<br>
<br>
</div><div class="im">> Will a Program with actual projects exist? (I personally think<br>
> this will create some confusion).<br>
><br>
> I guess the same thing would happen with incubated projects that<br>
> never graduate to integrated. However, the probability this would<br>
> happen are way lower. You also make a good point w.r.t ATCs and the<br>
> rights to vote.<br>
><br>
> -1 from me. I'd be even in favor to not calling any Program<br>
> official until there's an integrated *team* - not project - working<br>
> on it. Notice that I'm using the term 'team' and not projects.<br>
> Programs like 'Documentation' have an integrated team working on it<br>
> and are part of every release cycle, the same thing applies for the<br>
> "Release Cycle Management" program, etc.<br>
<br>
</div>We wouldn't create a program without an existing team doing some work<br>
already.  We even have rules around now programs along side the rules<br>
for incubating/graduating projects:<br>
<br>
<a href="http://git.openstack.org/cgit/openstack/governance/tree/reference/new-programs-requirements" target="_blank">http://git.openstack.org/cgit/openstack/governance/tree/reference/new-programs-requirements</a><br>
<div class="im HOEnZb"><br>
> With the above, I'm basically saying that a Queuing ;) program<br>
> shouldn't exist until there's an integrated team of folks working<br>
> on queuing. Incubation doesn't guarantees integration and<br>
> "emerging technology" doesn't guarantees incubation. Both stages<br>
> mean there's interest about that technology and that we're looking<br>
> forward to see it being part of OpenStack, period. Each stage<br>
> probably means a bit more than that but, IMHO, that's the<br>
> 'community' point of view of those stages.<br>
><br>
> What if we have a TC-managed* Program incubation period? The<br>
> Program won't be managed by the team working on the emerging<br>
> technology, nor the team working on the incubated project. Until<br>
> those projects don't graduate, the program won't be official nor<br>
> will have the 'rights' of other programs. And if the project fits<br>
> into another program, then it won't be officially part of it until<br>
> it graduates.<br>
><br>
> Unless I'm completely wrong about what a program is / should be,<br>
> I'm leaning towards -1.<br>
><br>
> * I'm sorry, I couldn't come up with a better term for this. :)<br>
><br>
> Cheers, FF<br>
><br>
><br>
><br>
><br>
</div><div class="im HOEnZb">> _______________________________________________ OpenStack-dev<br>
> mailing list <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
><br>
<br>
<br>
</div><span class="HOEnZb"><font color="#888888">--<br>
Russell Bryant<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div>