<div dir="ltr">In general, I think this is fantastic and I know that Glance would benefit from something similar.<div><br></div><div>I have a few opinions I want to share:</div><div><br></div><div>- I'd love to use this as a way to OpenStack-validate plugins that live outside of the project--and then kick most plugins out of the project to some other semi-canonical area.</div>
<div>- I don't think the test infrastructure should depend wholly on devstack--while that makes a ton of sense for plugins that depend on other OpenStack services working, I think its pretty crufty that we have plugins that depend on other openstack services. I'd rather not to weigh the good down with the bad.</div>
<div><br></div><div>Thanks for creating this discussion!</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Jul 30, 2013 at 12:04 PM, John Griffith <span dir="ltr"><<a href="mailto:john.griffith@solidfire.com" target="_blank">john.griffith@solidfire.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_default" style="font-family:courier new,monospace"><br></div><div class="gmail_extra">
<br><br><div class="gmail_quote"><div class="im">On Tue, Jul 30, 2013 at 11:47 AM, Walter A. Boring IV <span dir="ltr"><<a href="mailto:walter.boring@hp.com" target="_blank">walter.boring@hp.com</a>></span> wrote:<br>


<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  
    
  
  <div bgcolor="#FFFFFF" text="#000000">
    <div>So how frequently would this be
      required and when do the results need to be provided?<br></div></div></blockquote><div><br></div></div><div class="gmail_default" style="font-family:'courier new',monospace">To start I'd like to propose any new driver, and then each driver upon milestone release, or at the very least each cycle.</div>
<div class="im">

<div class="gmail_default" style="font-family:'courier new',monospace"></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div bgcolor="#FFFFFF" text="#000000">


<div>
         I generally think this is a good idea, but as well all know
      that the project seems to be in flux at times around the
      milestones.  Especially around G3 when we changed the way the CONF
      object was accessed, almost all drivers failed to work right after
      G3 when cinder.conf was configured with a multi-backend setup.  It
      took a week or so after G3 before everyone</div></div></blockquote><div><br></div></div><div class="gmail_default" style="font-family:'courier new',monospace">IMO this is exactly why something like this would actually be more beneficial.</div>
<div class="im">

<div class="gmail_default" style="font-family:'courier new',monospace"></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div bgcolor="#FFFFFF" text="#000000">


<div> was able to go through
      drivers and clean them up and get them to work in this scenario.  
      I'm not trying to be a wet blanket on this idea, but I think we
      just have to be careful.   I have no problem running my drivers
      through this and providing the results.  What happens when
      something changes in cinder that causes drivers to fail and the
      test runs fail?   How long</div></div></blockquote><div><br></div></div><div class="gmail_default" style="font-family:'courier new',monospace">We should be extra careful to keep this sort of thing from happening, but again without doing any sort of public testing/results here we run the risk of nobody knowing it's broken until a customer encounters it.  I'm also not quite sure I see the issue here, I mean if something in the cinder base code breaks a driver it's still going to be broken, the only difference is that we'll actually know that it's broken.</div>
<div class="im">

<div class="gmail_default" style="font-family:'courier new',monospace"></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div bgcolor="#FFFFFF" text="#000000">


<div> does a maintainer get to fix the issue
      before X happens as a result?  Does this happen every milestone
      I-1, I-2, I-3?  What happens if a maintainer can't do it for every
      milestone for whatever reason?<br></div></div></blockquote><div><br></div></div><div class="gmail_default" style="font-family:'courier new',monospace">I don't think we've arrived at a point where we say X happens yet.  To start I'd view this as logging a bug if it doesn't pass.  Ultimately it would probably be interesting to consider things like removing a driver but there would have to be some process setup regarding how we try and address the issue before doing something drastic.</div>
<div class="im">

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div bgcolor="#FFFFFF" text="#000000"><div>
      <br>
      Just playing a bit of devil's advocate here.   I do like the idea
      though, just depends on the "rules" setup and how it all applies
      when things don't go well for a particular driver.<br></div></div></blockquote><div><br></div></div><div class="gmail_default" style="font-family:'courier new',monospace">Sure, that's fine and I think you bring up a good point.  The idea here is NOT to make things difficult or to try and keep drivers out etc, the idea is to release a better product.  There are a number of folks that have drivers that are "believed" to work but since there's no formal testing/integration it's just an assumption in the community.  This proposal would at least make it public information regarding whether a driver actually works or not.  I mean really, I don't think this is asking too much considering we require any patch to the projects in OpenStack to run these tests against the LVM driver to make sure things work.  This really isn't any different, except we don't *require* it for every check in.  We just do checks to make sure drivers are actually doing what we expect and end-users aren't surprised to find their driver doesn't actually work.</div>
<div><div class="h5">

<div class="gmail_default" style="font-family:'courier new',monospace"></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div bgcolor="#FFFFFF" text="#000000">


<div>
      <br>
      Cheers,<br>
      Walt<br>
      <br>
      <br>
    </div>
    <blockquote type="cite"><div><div>
      
      <div dir="ltr">
        <div style="font-family:courier new,monospace">Hey Everyone,</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">
          Something I've been kicking around for quite a while now but
          never really been able to get around to is the idea of
          requiring that drivers in Cinder run a qualification test and
          submit results prior to introduction in to Cinder.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">To elaborate a bit, the idea could start as
          something really simple like the following:</div>
        <div style="font-family:courier new,monospace">1. We'd add a functional_qual option/script to
          devstack</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">
          2. Driver maintainer runs this script to setup devstack and
          configure it to use their backend device on their own system.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">
          3. Script does the usual devstack install/configure and runs
          the volume pieces of the Tempest gate tests.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">
          4. Grabs output and checksums of the directories in the
          devstack and /opt/stack directories, bundles up the results
          for submission</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">
          5. Maintainer submits results</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">So why would we do this you ask?  Cinder is
          pretty heavy on the third party driver plugin model which is
          fantastic.  On the other hand while there are a lot of folks
          who do great reviews that catch things like syntax or logic
          errors in the code, and unit tests do a reasonable job of
          exercising the code it's difficult for folks to truly verify
          these devices all work.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">I think it would be a very useful tool for
          initial introduction of a new driver and even perhaps some
          sort of check that's run and submitted again prior to
          milestone releases.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">This would also drive some more activity and
          contribution in to Tempest with respect to getting folks like
          myself motivated to contribute more tests (particularly in
          terms of new functionality) in to Tempest.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">I'd be interested to hear if folks have any
          interest or strong opinions on this (positive or otherwise).
           I know that some vendors like RedHat have this sort of thing
          in place for certifications, and to be honest that observation
          is something that caused me to start thinking about this
          again.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">There are a lot of gaps here regarding how the
          submission process would look, but we could start relatively
          simple and grow from there if it's valuable or just abandon
          the idea if it proves to be unpopular and a waste of time.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">Anyway, I'd love to get feed-back from folks
          and see what they think.</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
        <div style="font-family:courier new,monospace">Thanks,</div>
        <div style="font-family:courier new,monospace">
          John</div>
        <div style="font-family:courier new,monospace"><br>
        </div>
      </div>
      <br>
      <fieldset></fieldset>
      <br>
      </div></div><div><pre>_______________________________________________
OpenStack-dev mailing list
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">OpenStack-dev@lists.openstack.org</a>
<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>
</pre>
    </div></blockquote>
    <br>
  </div>

<br>_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org" target="_blank">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></blockquote></div></div></div><br></div></div>
<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></blockquote></div><br></div>