<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:p="urn:schemas-microsoft-com:office:powerpoint" xmlns:a="urn:schemas-microsoft-com:office:access" xmlns:dt="uuid:C2F41010-65B3-11d1-A29F-00AA00C14882" xmlns:s="uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882" xmlns:rs="urn:schemas-microsoft-com:rowset" xmlns:z="#RowsetSchema" xmlns:b="urn:schemas-microsoft-com:office:publisher" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:c="urn:schemas-microsoft-com:office:component:spreadsheet" xmlns:odc="urn:schemas-microsoft-com:office:odc" xmlns:oa="urn:schemas-microsoft-com:office:activation" xmlns:html="http://www.w3.org/TR/REC-html40" xmlns:q="http://schemas.xmlsoap.org/soap/envelope/" xmlns:rtc="http://microsoft.com/officenet/conferencing" xmlns:D="DAV:" xmlns:Repl="http://schemas.microsoft.com/repl/" xmlns:mt="http://schemas.microsoft.com/sharepoint/soap/meetings/" xmlns:x2="http://schemas.microsoft.com/office/excel/2003/xml" xmlns:ppda="http://www.passport.com/NameSpace.xsd" xmlns:ois="http://schemas.microsoft.com/sharepoint/soap/ois/" xmlns:dir="http://schemas.microsoft.com/sharepoint/soap/directory/" xmlns:ds="http://www.w3.org/2000/09/xmldsig#" xmlns:dsp="http://schemas.microsoft.com/sharepoint/dsp" xmlns:udc="http://schemas.microsoft.com/data/udc" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:sub="http://schemas.microsoft.com/sharepoint/soap/2002/1/alerts/" xmlns:ec="http://www.w3.org/2001/04/xmlenc#" xmlns:sp="http://schemas.microsoft.com/sharepoint/" xmlns:sps="http://schemas.microsoft.com/sharepoint/soap/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:udcs="http://schemas.microsoft.com/data/udc/soap" xmlns:udcxf="http://schemas.microsoft.com/data/udc/xmlfile" xmlns:udcp2p="http://schemas.microsoft.com/data/udc/parttopart" xmlns:wf="http://schemas.microsoft.com/sharepoint/soap/workflow/" xmlns:dsss="http://schemas.microsoft.com/office/2006/digsig-setup" xmlns:dssi="http://schemas.microsoft.com/office/2006/digsig" xmlns:mdssi="http://schemas.openxmlformats.org/package/2006/digital-signature" xmlns:mver="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns:mrels="http://schemas.openxmlformats.org/package/2006/relationships" xmlns:spwp="http://microsoft.com/sharepoint/webpartpages" xmlns:ex12t="http://schemas.microsoft.com/exchange/services/2006/types" xmlns:ex12m="http://schemas.microsoft.com/exchange/services/2006/messages" xmlns:pptsl="http://schemas.microsoft.com/sharepoint/soap/SlideLibrary/" xmlns:spsl="http://microsoft.com/webservices/SharePointPortalServer/PublishedLinksService" xmlns:Z="urn:schemas-microsoft-com:" xmlns:st="" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<meta name="Generator" content="Microsoft Word 12 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Consolas;
        panose-1:2 11 6 9 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
p.MsoPlainText, li.MsoPlainText, div.MsoPlainText
        {mso-style-priority:99;
        mso-style-link:"Plain Text Char";
        margin:0in;
        margin-bottom:.0001pt;
        font-size:10.5pt;
        font-family:Consolas;}
span.PlainTextChar
        {mso-style-name:"Plain Text Char";
        mso-style-priority:99;
        mso-style-link:"Plain Text";
        font-family:Consolas;}
.MsoChpDefault
        {mso-style-type:export-only;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Monty Taylor wrote:</p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">On 10/15/2013 08:36 PM, Sean Dague wrote:<o:p></o:p></p>
<p class="MsoPlainText">> On 10/15/2013 04:54 PM, Vishvananda Ishaya wrote:<o:p></o:p></p>
<p class="MsoPlainText">>> Hi Everyone,<o:p></o:p></p>
<p class="MsoPlainText">>><o:p> </o:p></p>
<p class="MsoPlainText">>> I've been following this conversation and weighing the different<o:p></o:p></p>
<p class="MsoPlainText">>> sides. This is a tricky issue but I think it is important to decouple<o:p></o:p></p>
<p class="MsoPlainText">>> further and extend our circle of trust.<o:p></o:p></p>
<p class="MsoPlainText">>><o:p> </o:p></p>
<p class="MsoPlainText">>> When nova started it was very easy to do feature development. As it<o:p></o:p></p>
<p class="MsoPlainText">>> has matured the pace has slowed. This is expected and necessary, but<o:p></o:p></p>
<p class="MsoPlainText">>> we periodically must make decoupling decisions or we will become mired<o:p></o:p></p>
<p class="MsoPlainText">>> in overhead. We did this already with cinder and neutron, and we have<o:p></o:p></p>
<p class="MsoPlainText">>> discussed doing this with virt drivers in the past.<o:p></o:p></p>
<p class="MsoPlainText">>><o:p> </o:p></p>
<p class="MsoPlainText">>> We have a large number of people attempting to contribute to small<o:p></o:p></p>
<p class="MsoPlainText">>> sections of nova and getting frustrated with the process.  The<o:p></o:p></p>
<p class="MsoPlainText">>> perception of developers is much more important than the actual<o:p></o:p></p>
<p class="MsoPlainText">>> numbers here. If people are frustrated they are disincentivized to<o:p></o:p></p>
<p class="MsoPlainText">>> help and it hurts everyone. Suggesting that these contributors need to<o:p></o:p></p>
<p class="MsoPlainText">>> learn all of nova and help with the review queue is silly and makes us<o:p></o:p></p>
<p class="MsoPlainText">>> seem elitist. We should make it as easy as possible for new<o:p></o:p></p>
<p class="MsoPlainText">>> contributors to help.<o:p></o:p></p>
<p class="MsoPlainText">>><o:p> </o:p></p>
<p class="MsoPlainText">>> I think our current model is breaking down at our current size and we<o:p></o:p></p>
<p class="MsoPlainText">>> need to adopt something more similar to the linux model when dealing<o:p></o:p></p>
<p class="MsoPlainText">>> with subsystems. The hyper-v team is the only one suggesting changes,<o:p></o:p></p>
<p class="MsoPlainText">>> but there have been similar concerns from the vmware team. I have no<o:p></o:p></p>
<p class="MsoPlainText">>> doubt that there are similar issues with the PowerVM, Xen, Docker, lxc<o:p></o:p></p>
<p class="MsoPlainText">>> and even kvm driver contributors.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> The Linux kernel process works for a couple of reasons...<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> 1) the subsystem maintainers have known each other for a solid decade<o:p></o:p></p>
<p class="MsoPlainText">> (i.e. 3x the lifespan of the OpenStack project), over a history of 10<o:p></o:p></p>
<p class="MsoPlainText">> years, of people doing the right things, you build trust in their judgment.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> *no one* in the Linux tree was given trust first, under the hope that it<o:p></o:p></p>
<p class="MsoPlainText">> would work out. They had to earn it, hard, by doing community work, and<o:p></o:p></p>
<p class="MsoPlainText">> not just playing in their corner of the world.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> 2) This<o:p></o:p></p>
<p class="MsoPlainText">> http://www.wired.com/wiredenterprise/2012/06/torvalds-nvidia-linux/ is<o:p></o:p></p>
<p class="MsoPlainText">> completely acceptable behavior. So when someone has bad code, they are<o:p></o:p></p>
<p class="MsoPlainText">> flamed to within an inch of their life, repeatedly, until they never<o:p></o:p></p>
<p class="MsoPlainText">> ever do that again. This is actually a time saving measure in code<o:p></o:p></p>
<p class="MsoPlainText">> review. It's a lot faster to just call people idiots then to help them<o:p></o:p></p>
<p class="MsoPlainText">> with line by line improvements in their code, 10, 20, 30, or 40<o:p></o:p></p>
<p class="MsoPlainText">> iterations in gerrit.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> We, as a community have decided, I think rightly, that #2 really isn't<o:p></o:p></p>
<p class="MsoPlainText">> in our culture. But you can't start cherry picking parts of the Linux<o:p></o:p></p>
<p class="MsoPlainText">> kernel community without considering how all the parts work together.<o:p></o:p></p>
<p class="MsoPlainText">> The good and the bad are part of why the whole system works.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">>> In my opinion, nova-core needs to be willing to trust the subsystem<o:p></o:p></p>
<p class="MsoPlainText">>> developers and let go of a little bit of control. I frankly don't see<o:p></o:p></p>
<p class="MsoPlainText">>> the drawbacks.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> I actually see huge draw backs. Culture matters. Having people active<o:p></o:p></p>
<p class="MsoPlainText">> and willing to work on real core issues matter. The long term health of<o:p></o:p></p>
<p class="MsoPlainText">> Nova matters.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> As the QA PTL I can tell you that when you look at Nova vs. Cinder vs.<o:p></o:p></p>
<p class="MsoPlainText">> Neutron, you'll see some very clear lines about how long it takes to get<o:p></o:p></p>
<p class="MsoPlainText">> to the bottom of a race condition, and how many deep races are in each<o:p></o:p></p>
<p class="MsoPlainText">> of them. I find this directly related to the stance each project has<o:p></o:p></p>
<p class="MsoPlainText">> taken on whether it's socially acceptable to only work on your own<o:p></o:p></p>
<p class="MsoPlainText">> vendor code. Nova's insistence up until this point that if you only play<o:p></o:p></p>
<p class="MsoPlainText">> in your corner, you don't get the same attention is important incentive<o:p></o:p></p>
<p class="MsoPlainText">> for people to integrate and work beyond just their boundaries. I think<o:p></o:p></p>
<p class="MsoPlainText">> diluting this part of the culture would be hugely detrimental to Nova.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> Let's take an example that came up today, the compute_diagnostics API.<o:p></o:p></p>
<p class="MsoPlainText">> This is an area where we've left it completely to the virt drivers to<o:p></o:p></p>
<p class="MsoPlainText">> vomit up a random dictionary of the day for debugging reasons, and<o:p></o:p></p>
<p class="MsoPlainText">> stamped it as an API. With a model where we let virt driver authors go<o:p></o:p></p>
<p class="MsoPlainText">> hide in a corner, that's never going to become an API with any kind of<o:p></o:p></p>
<p class="MsoPlainText">> contract, and given how much effort we've spent on ensuring RPC<o:p></o:p></p>
<p class="MsoPlainText">> versioning and message formats, the idea that we are exposing a public<o:p></o:p></p>
<p class="MsoPlainText">> rest endpoint that's randomly fluctuating data based on date and<o:p></o:p></p>
<p class="MsoPlainText">> underlying implementation, is a bit saddening.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">>> I'm leaning towards giving control of the subtree to the team as the<o:p></o:p></p>
<p class="MsoPlainText">>> best option because it is simple and works with our current QA system.<o:p></o:p></p>
<p class="MsoPlainText">>> Alternatively, we could split out the driver into a nova subproject (2<o:p></o:p></p>
<p class="MsoPlainText">>> below) or we could allow them to have a separate branch and do a<o:p></o:p></p>
<p class="MsoPlainText">>> trusted merge of all changes at the end of the cycle (similar to the<o:p></o:p></p>
<p class="MsoPlainText">>> linux model).<o:p></o:p></p>
<p class="MsoPlainText">>><o:p> </o:p></p>
<p class="MsoPlainText">>> I hope we can come to a solution to the summit that makes all of our<o:p></o:p></p>
<p class="MsoPlainText">>> contributors want to participate more. I believe that giving people<o:p></o:p></p>
<p class="MsoPlainText">>> more responsibility inspires them to participate more fully.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> I would like nothing more than all our contributors to participate more.<o:p></o:p></p>
<p class="MsoPlainText">> But more has to mean caring about not only your stuff.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> I was called out today in the hyper-v meeting because I had the audacity<o:p></o:p></p>
<p class="MsoPlainText">> to -1 a hyper-v patch because I wanted some reference in the code<o:p></o:p></p>
<p class="MsoPlainText">> somewhere to format references so why we had some new random seek call<o:p></o:p></p>
<p class="MsoPlainText">> would be understood by people down the road -<o:p></o:p></p>
<p class="MsoPlainText">> http://eavesdrop.openstack.org/meetings/hyper_v/2013/hyper_v.2013-10-15-16.03.log.html<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> As OpenStack grows, the single biggest factor in it's success isn't<o:p></o:p></p>
<p class="MsoPlainText">> going to be a feature in a driver, it's going to be if this crazy<o:p></o:p></p>
<p class="MsoPlainText">> complicated system holds together. Whether or not we've got a handle on<o:p></o:p></p>
<p class="MsoPlainText">> the emergent behavior that happens in an asynchronous message based<o:p></o:p></p>
<p class="MsoPlainText">> system, with 10s of integrated projects, and many dozens of daemons<o:p></o:p></p>
<p class="MsoPlainText">> cross talking with each other.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> I mean seriously, one of the only reasons we made it through to Havana<o:p></o:p></p>
<p class="MsoPlainText">> RC phase is because we built a search engine based system to build<o:p></o:p></p>
<p class="MsoPlainText">> statistical frequency analysis of unique failures on our gate resets to<o:p></o:p></p>
<p class="MsoPlainText">> fully expose the top race conditions that had gotten so bad the gate<o:p></o:p></p>
<p class="MsoPlainText">> basically locked up. And a bunch of people went all hands on deck to<o:p></o:p></p>
<p class="MsoPlainText">> drive these out. People jumped across normal project lines to help on<o:p></o:p></p>
<p class="MsoPlainText">> some of these top bugs, because that's what makes OpenStack a whole system.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> Things actually looked *really* bleak for release for a while. All the<o:p></o:p></p>
<p class="MsoPlainText">> people that helped out and got us through this deserve a huge pat on the<o:p></o:p></p>
<p class="MsoPlainText">> back. That's what OpenStack is about.<o:p></o:p></p>
<p class="MsoPlainText">> <o:p></o:p></p>
<p class="MsoPlainText">> So I feel pretty strongly that optimizing the contribution process for<o:p></o:p></p>
<p class="MsoPlainText">> people that aren't helping with that larger problem, is the tragedy of<o:p></o:p></p>
<p class="MsoPlainText">> the commons, and I think entirely the wrong optimization to be made.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">I agree strongly with Sean, although I can sympathize with the other<o:p></o:p></p>
<p class="MsoPlainText">POV. So far in OpenStack, we've consistently valued an attempt at<o:p></o:p></p>
<p class="MsoPlainText">growing the whole over the perceived velocity (or other) needs of a<o:p></o:p></p>
<p class="MsoPlainText">subset. I think this has served us well so far, and I'm not sure I see<o:p></o:p></p>
<p class="MsoPlainText">that we're having such a bad time that we need to ditch it. The last<o:p></o:p></p>
<p class="MsoPlainText">thing that OpenStack needs ANY more help with is velocity. I mean, let's<o:p></o:p></p>
<p class="MsoPlainText">be serious - we land WAY more patches in a day than is even close to sane.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Individual developer latency? Yeah. Sometimes that's going to happen.<o:p></o:p></p>
<p class="MsoPlainText">I'm one of the 4 core infra team members and I've got patches that have<o:p></o:p></p>
<p class="MsoPlainText">been waiting for 2 other core reviewers for a couple of weeks now. Ok.<o:p></o:p></p>
<p class="MsoPlainText">so I work on something else - there's plenty to do. I'm in core.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">The system isn't broken - it's working as designed. When something moves<o:p></o:p></p>
<p class="MsoPlainText">faster (recently, we rolled out nodepool, and for a week or two jim was<o:p></o:p></p>
<p class="MsoPlainText">just rolling it out directly into production because we had to to keep<o:p></o:p></p>
<p class="MsoPlainText">up with feature freeze) you get into a bad spot afterwards (I can only<o:p></o:p></p>
<p class="MsoPlainText">just now be useful in code review for nodepool, because it got away from<o:p></o:p></p>
<p class="MsoPlainText">me and I wasn't involved)<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">That's a 4 person team, and a 2 weeks of letting up had a noticible<o:p></o:p></p>
<p class="MsoPlainText">impact. How about a 20 person core team with hundreds of regular<o:p></o:p></p>
<p class="MsoPlainText">contributors?<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">We MUST continue to be vigilent in getting people to care about more<o:p></o:p></p>
<p class="MsoPlainText">than their specific part, or else this big complex mess is going to come<o:p></o:p></p>
<p class="MsoPlainText">crashing down around us. Tragedy of the Commons is right - it's really<o:p></o:p></p>
<p class="MsoPlainText">hard to get your product managers to allow you to spend time working on<o:p></o:p></p>
<p class="MsoPlainText">something other than your vendor feature, right?<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">So maybe, just maybe, if we keep working with the system we've built, we<o:p></o:p></p>
<p class="MsoPlainText">can go back to them and say "if you want the features in quicker, you<o:p></o:p></p>
<p class="MsoPlainText">should give me 10% or 20% of my time to work on Nova overall. It'll make<o:p></o:p></p>
<p class="MsoPlainText">Nova healthier, and it'll give us more of a basis on which to push our<o:p></o:p></p>
<p class="MsoPlainText">specifics." Then it's a simple cost/benefit, and unless your product<o:p></o:p></p>
<p class="MsoPlainText">manager is nuts, it should be ok.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">We're also working on other things to make this better, that still<o:p></o:p></p>
<p class="MsoPlainText">haven't fully hit yet - so before we go making additional changes, how<o:p></o:p></p>
<p class="MsoPlainText">about we see if those help? Russell drew a line in the sane about 3rd<o:p></o:p></p>
<p class="MsoPlainText">party testing for vendor drivers. Since then, a bunch of folks have been<o:p></o:p></p>
<p class="MsoPlainText">doing a LOT of work in getting those systems up and going and reporting.<o:p></o:p></p>
<p class="MsoPlainText">The current nova devs have said they'll be much more comfortable<o:p></o:p></p>
<p class="MsoPlainText">reviewing vendor-specific code because they can see that it's being<o:p></o:p></p>
<p class="MsoPlainText">tested. I'd like to see the fruits of that happen before we make other<o:p></o:p></p>
<p class="MsoPlainText">systemic changes.<o:p></o:p></p>
<p class="MsoPlainText"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black">OK, Monty.  You’ve convinced me that this really does need more thought and work if we want this to have a snowball’s chance in hell of keeping the quality high.  I am a team player,
 so I can be naïve about changing cultures.  The reality is that the driver guys would need to have at least as high a design-, quality-, test- and documentation-centric culture as the Nova and Infra teams for a spin-off to work.  I’m not saying they don’t,
 just saying what Sean said, they haven’t had the time or chance to demonstrate it.  It also sounds like you might have some more thoughts on how to evolve the system to keep it moving forward without getting away from the core principles.  I’ll wait for the
 summit discussions.  I’d love to be there, but won’t.<o:p></o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black">As to Sean’s comment about the diags, this is an area the driver developers could build their reputation with other teams as well as the Nova team, by sitting down together and designing
 a system and API that is a single system that will work for all the virt drivers.  This is the kind of project and design needed to scale OpenStack, and keep bring the driver developers into the culture.  Show us you can work together and stretch at least
 outside of your own code to bring consistency, scalability and traceability to the driver *interfaces* so those developers interfacing with the drivers don’t have to do the same work over for every driver.<o:p></o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black">Enough soap box.  Let’s see a plan that keeps the quality and cooperative culture thriving without bringing progress to a standstill.<o:p></o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black"><o:p> </o:p></span></p>
<p class="MsoPlainText" style="margin-left:.5in"><span style="color:black">--Rocky<o:p></o:p></span></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Anywhoo - I get it. I really do. It drives me CRAZY when it takes 2<o:p></o:p></p>
<p class="MsoPlainText">weeks for a patch to land. It drove me REALLY crazy when it was 2 days<o:p></o:p></p>
<p class="MsoPlainText">between approve and land when the gate was all borked. But just as I<o:p></o:p></p>
<p class="MsoPlainText">think we all felt it was not the right choice to relax the gate during<o:p></o:p></p>
<p class="MsoPlainText">the insanity, but to buckle down, jump in and engage and fix the actual<o:p></o:p></p>
<p class="MsoPlainText">problems, I also don't think it's right to relax our current review<o:p></o:p></p>
<p class="MsoPlainText">criteria to mitigate the developer latency issue.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">BTW - remember landing patches on giant open source projects before this<o:p></o:p></p>
<p class="MsoPlainText">one? Anybody ever try to land a patch against MySQL? Google spent 2<o:p></o:p></p>
<p class="MsoPlainText">years getting one landed. I think we're doing un-terrible- we can<o:p></o:p></p>
<p class="MsoPlainText">improve, but the sky is definitely not falling.<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">Monty<o:p></o:p></p>
<p class="MsoPlainText"><o:p> </o:p></p>
<p class="MsoPlainText">_______________________________________________<o:p></o:p></p>
<p class="MsoPlainText">OpenStack-dev mailing list<o:p></o:p></p>
<p class="MsoPlainText">OpenStack-dev@lists.openstack.org<o:p></o:p></p>
<p class="MsoPlainText">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev<o:p></o:p></p>
</div>
</body>
</html>