<div dir="ltr">I definitely agree that reviewer time is wasted reviewing changes. However, I don't think moving them to a different repo with different cores is going to make them less brittle without some very strict guidelines about what a driver/plugin is allowed to do.<div>
<br></div><div>For example, without neutron core reviewer oversight, what prevents a plugin author from monkey patching parts of the neutron API? If nothing, that will immediately break on any kind of API refactoring, module renaming, etc. </div>
<div><br></div><div>That scenario also brings up another concern. Will changes to neutron that break a vendor plugin even be blocked on the neutron side? If so, the neutron repo will be held hostage by third-party code that isn't in Neutron and lacks the quality control it would have in Neutron. If not, this will immediately break the gate on the driver repo, forcing maintainers to disable the gating job for that vendor plugin. Neither of these scenarios seem less brittle to me.</div>
<div><br></div><div>What the PLUMgrid folks did works; however, IIUC it was at the sacrifice of unit tests verifying any calls into the plumlib. There is just a fake driver that accepts anything for the unit tests. [1] They could implement a lot of mock logic to simulate the real driver, but then we are back to square one and they might as well put the actual driver there.</div>
<div><br></div><div>I'm all for moving drivers/plugins out of Neutron, but we need to be really careful here because we are going to lose a lot of quality control that Neutron could end up taking the blame for since these drivers/plugins are still in a public repo.</div>
<div><br></div><div>1. <a href="https://github.com/openstack/neutron/blob/08529376f16837083c28b009411cc52e0e2a8d33/neutron/plugins/plumgrid/drivers/fake_plumlib.py">https://github.com/openstack/neutron/blob/08529376f16837083c28b009411cc52e0e2a8d33/neutron/plugins/plumgrid/drivers/fake_plumlib.py</a></div>
</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Aug 15, 2014 at 8:50 AM, Kyle Mestery <span dir="ltr"><<a href="mailto:mestery@mestery.com" target="_blank">mestery@mestery.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I think the review time alone is a huge issue. Even worse, for the<br>
most part, core reviewers are reviewing code for which they themselves<br>
can't test because it requires proprietary hardware or software,<br>
making the situation brittle at best. Having a separate git repository<br>
which is gated by stringent third-party CI requirements, with separate<br>
(and possibly overlapping) core reviewers would help to alleviate this<br>
problem. Another alternative is to move most intelligence out of the<br>
plugins/drivers and into vendor owned packages which can live on pypi.<br>
This is similar to what the PLUMgrid folks did for their plugin. This<br>
allows vendor control over most of their bits, removes the constant<br>
churn for simple bug fixes in the neutron tree, and adds the benefit<br>
of being a part of the simultaneous release, which is the only thing<br>
most vendors care about.<br>
<div class="HOEnZb"><div class="h5"><br>
On Thu, Aug 14, 2014 at 10:34 PM, Kevin Benton <<a href="mailto:blak111@gmail.com">blak111@gmail.com</a>> wrote:<br>
>>I also feel like the drivers/plugins are currently BEYOND a tipping<br>
> point, and are in fact dragging down velocity of the core project in<br>
> many ways.<br>
><br>
> Can you elaborate on the ways that they are slowing down the velocity? I<br>
> know they take up reviewer time, but are there other ways that you think<br>
> they slow down the project?<br>
><br>
><br>
> On Thu, Aug 14, 2014 at 6:07 AM, Kyle Mestery <<a href="mailto:mestery@mestery.com">mestery@mestery.com</a>> wrote:<br>
>><br>
>> I also feel like the drivers/plugins are currently BEYOND a tipping<br>
>> point, and are in fact dragging down velocity of the core project in<br>
>> many ways. I'm working on a proposal for Kilo where we move all<br>
>> drivers/plugins out of the main Neutron tree and into a separate git<br>
>> repository under the networking program. We have way too many drivers,<br>
>> requiring way too man review cycles, for this to be a sustainable<br>
>> model going forward. Since the main reason plugin/driver authors want<br>
>> their code upstream is to be a part of the simultaneous release, and<br>
>> thus be packaged by distributions, having a separate repository for<br>
>> these will satisfy this requirement. I'm still working through the<br>
>> details around reviews of this repository, etc.<br>
>><br>
>> Also, I feel as if the level of passion on the mailing list has died<br>
>> down a bit, so I thought I'd send something out to try and liven<br>
>> things up a bit. It's been somewhat non-emotional here for a day or<br>
>> so. :)<br>
>><br>
>> Thanks,<br>
>> Kyle<br>
>><br>
>> On Thu, Aug 14, 2014 at 5:09 AM, Salvatore Orlando <<a href="mailto:sorlando@nicira.com">sorlando@nicira.com</a>><br>
>> wrote:<br>
>> > I think there will soon be a discussion regarding what the appropriate<br>
>> > location for plugin and drivers should be.<br>
>> > My personal feeling is that Neutron has simply reached the tipping point<br>
>> > where the high number of drivers and plugins is causing unnecessary load<br>
>> > for<br>
>> > the core team and frustration for the community.<br>
>> ><br>
>> > There I would totally support Luke's initiative about maintaining an<br>
>> > out-of-tree ML2 driver. On the other hand, a plugin/driver "diaspora"<br>
>> > might<br>
>> > also have negative consequences such as frequent breakages such as those<br>
>> > Bob<br>
>> > was mentioning or confusion for users which might need to end up<br>
>> > fetching<br>
>> > drivers from disparate sources.<br>
>> ><br>
>> > As mentioned during the last Neutron IRC meeting this is another<br>
>> > "process"<br>
>> > aspect which will be discussed soon, with the aim of defining a plan<br>
>> > for:<br>
>> > - drastically reduce the number of plugins and drivers which must be<br>
>> > maintained in the main source tree<br>
>> > - enhance control of plugin/driver maintainers over their own code<br>
>> > - preserve the ability of doing CI checks on gerrit as we do today<br>
>> > - raise the CI bar (maybe finally set the smoketest as a minimum<br>
>> > requirement?)<br>
>> ><br>
>> > Regards,<br>
>> > Salvatore<br>
>> ><br>
>> ><br>
>> ><br>
>> > On 14 August 2014 11:47, loy wolfe <<a href="mailto:loywolfe@gmail.com">loywolfe@gmail.com</a>> wrote:<br>
>> >><br>
>> >><br>
>> >><br>
>> >><br>
>> >> On Thu, Aug 14, 2014 at 4:22 PM, Mathieu Rohon<br>
>> >> <<a href="mailto:mathieu.rohon@gmail.com">mathieu.rohon@gmail.com</a>><br>
>> >> wrote:<br>
>> >>><br>
>> >>> Hi,<br>
>> >>><br>
>> >>> I would like to add that it would be harder for the community to help<br>
>> >>> maintaining drivers.<br>
>> >>> such a work [1] wouldn't have occured with an out of tree ODL driver.<br>
>> >><br>
>> >><br>
>> >> +1.<br>
>> >> It's better to move all MD for none built-in backend out of tree,<br>
>> >> maintaining these drivers shouldn't be the responsibility of community.<br>
>> >> Not<br>
>> >> only MD, but also plugin, agent should all obey this rule<br>
>> >><br>
>> >>><br>
>> >>><br>
>> >>> [1] <a href="https://review.openstack.org/#/c/96459/" target="_blank">https://review.openstack.org/#/c/96459/</a><br>
>> >>><br>
>> >>> On Wed, Aug 13, 2014 at 1:09 PM, Robert Kukura<br>
>> >>> <<a href="mailto:kukura@noironetworks.com">kukura@noironetworks.com</a>><br>
>> >>> wrote:<br>
>> >>> > One thing to keep in mind is that the ML2 driver API does sometimes<br>
>> >>> > change,<br>
>> >>> > requiring updates to drivers. Drivers that are in-tree get updated<br>
>> >>> > along<br>
>> >>> > with the driver API change. Drivers that are out-of-tree must be<br>
>> >>> > updated by<br>
>> >>> > the owner.<br>
>> >>> ><br>
>> >>> > -Bob<br>
>> >>> ><br>
>> >>> ><br>
>> >>> > On 8/13/14, 6:59 AM, ZZelle wrote:<br>
>> >>> ><br>
>> >>> > Hi,<br>
>> >>> ><br>
>> >>> ><br>
>> >>> > The important thing to understand is how to integrate with neutron<br>
>> >>> > through<br>
>> >>> > stevedore/entrypoints:<br>
>> >>> ><br>
>> >>> ><br>
>> >>> ><br>
>> >>> > <a href="https://github.com/dave-tucker/odl-neutron-drivers/blob/master/setup.cfg#L32-L34" target="_blank">https://github.com/dave-tucker/odl-neutron-drivers/blob/master/setup.cfg#L32-L34</a><br>
>> >>> ><br>
>> >>> ><br>
>> >>> > Cedric<br>
>> >>> ><br>
>> >>> ><br>
>> >>> > On Wed, Aug 13, 2014 at 12:17 PM, Dave Tucker <<a href="mailto:dave@dtucker.co.uk">dave@dtucker.co.uk</a>><br>
>> >>> > wrote:<br>
>> >>> >><br>
>> >>> >> I've been working on this for OpenDaylight<br>
>> >>> >> <a href="https://github.com/dave-tucker/odl-neutron-drivers" target="_blank">https://github.com/dave-tucker/odl-neutron-drivers</a><br>
>> >>> >><br>
>> >>> >> This seems to work for me (tested Devstack w/ML2) but YMMV.<br>
>> >>> >><br>
>> >>> >> -- Dave<br>
>> >>> >><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>
>> >>> ><br>
>> >>> ><br>
>> >>> ><br>
>> >>> ><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>
>> >>> ><br>
>> >>> ><br>
>> >>> ><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>
>> >>> ><br>
>> >>><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>
>> >><br>
>> >><br>
>> >><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>
>> >><br>
>> ><br>
>> ><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>
>> ><br>
>><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>
><br>
><br>
><br>
><br>
> --<br>
> Kevin Benton<br>
><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>
><br>
<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><br clear="all"><div><br></div>-- <br><div>Kevin Benton</div>
</div>