<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Apr 16, 2015 at 7:50 AM, Emilien Macchi <span dir="ltr"><<a href="mailto:emilien@redhat.com" target="_blank">emilien@redhat.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><span class=""><br>
<br>
On 04/16/2015 12:26 AM, Matt Fischer wrote:<br>
> Recently a mass of changes was proposed and some merged to move the<br>
> rabbit/kombu settings to avoid a Kilo deprecation. As far as I can tell<br>
> this will break rabbit connectivity for all modules still using Juno. I<br>
> did an experiment with Heat and it certainly can't talk to rabbit<br>
> anymore. (Hopefully you guys can just tell me I'm wrong here and<br>
> everything will still work)<br>
><br>
> So why did we do this? We seem to have traded a slightly annoying<br>
> deprecation warning for breaking every single module. It does not seem<br>
> like a good trade-off to me. At a minimum, I would have liked to wait<br>
> until we had forked Kilo off and we're working towards Liberty. Why?<br>
> Because there was simply no pressing reason to do this right now when<br>
> most everyone is still using Juno.</span></blockquote><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><span class="">
><br>
> Since we as a community are pretty terrible at backports, this means<br>
> that I now need to switch to stable and sit on old and non-updated code<br>
> until I can upgrade to Kilo, which is likely a minimum of 45 days away<br>
> for many components for us.<br>
<br>
</span>We do our best now to backport what is backportable to stable/juno.<br>
<span class=""><br>
> This has implications for my team beyond breaking everything:<br>
><br>
> * It means that we need to stop importing puppet code changes with our<br>
> git-upstream jobs. This makes the process of moving back to master when<br>
> we finally can quite painful. I had to do it for Icehouse and I don't<br>
> relish doing it again.<br>
><br>
> * It means that any fixes we want will require a two step process to get<br>
> into backports. This delays things obviously.<br>
><br>
> * It means that the number of contributions you will get from us will<br>
> probably fall, not being on master makes it way more likely for us just<br>
> to hold patches.<br>
><br>
> * It means that we will have to write a shim layer in our module to deal<br>
> with these settings and whatever else gets broken like this.<br>
><br>
> So I'd like to discuss the philosophy of why this was done. I'd also<br>
> again like to put in my vote for master supporting current-1 for at<br>
> least some period of time. There's a reason that the upstream code that<br>
> we configure just did this with a deprecation rather than a "if you set<br>
> it like this you are broken". We should do the same.<br></span></blockquote><div>Since I started working on this project I was under the impression that master tracks the next unreleased version of OpenStack. I don't recall where I got this impression and I don't believe it is documented, but I think it makes sense. If we didn't do this, we would have to wait for months after a release to make breaking changes. Master is not supposed to be stable, that is what stable branches are for.</div><div><br></div><div>However, I am sympathetic to the problem, as I don't have access to pre-release upstream packages and I have to check out old commits in order to do development. I would be in favor of adding conditionals for deprecated parameters, even though it would probably end up being messy. Deprecated is deprecated, not invalid, so I agree that we should probably allow them for a release cycle.</div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><span class="">
<br>
</span>FWIW, even without rabbit/kombu topic, master won't work on Juno, there<br>
is plenty of things that are brought in Kilo.<br>
<br>
My opinion is we should follow other projects that use stable branches<br>
with doing deprecation for one (or more?) release (currently our master)<br>
and then drop the deprecations after some time.<br>
<br>
So I would propose this policy:<br>
* for new features, patch master with backward compatibility<br>
* backports relevant patches from master to stable branches (mainly bugs)<br>
* in the case of rabbit or any update in OpenStack upstream, update<br>
master without backward compatibility, except if we accept to have a lot<br>
of if/else in our code, and a lot of backwards to support; I'm not in<br>
favor of that.<br></blockquote><div>I would like to additionally propose that we assign responsibility for backports so that these changes don't just get left behind and forgotten about. The author of the patch should add some sort of tag to indicate that something is a bugfix, a backwards compatible feature, or a backwards-incompatible change. The approver of the patch must take responsibility for cherry-picking the patch to the stable branch if it is backwards compatible. </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<span class=""><br>
> For now I've -1'd all the outstanding reviews until we can have a<br>
> discussion about it. I know one was merged despite my -1, but I didn't<br>
> think a -2 was warranted.<br>
><br>
<br>
</span>It's on the agenda for Tuesday's meeting (thanks Matt for this).<br>
In the meantime, any feedback is welcome,<br>
<br>
> __________________________________________________________________________<br>
> OpenStack Development Mailing List (not for usage questions)<br>
> Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</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>
<span class=""><font color="#888888"><br>
--<br>
Emilien Macchi<br>
<br>
</font></span><br>__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</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></blockquote><div>Thanks for bringing this up.</div><div> </div></div>Colleen (crinkle)</div></div>