<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Jun 21, 2016, at 4:51 PM, Van Lindberg <<a href="mailto:van.lindberg@rackspace.com" class="">van.lindberg@RACKSPACE.COM</a>> wrote:</div><br class="Apple-interchange-newline"><div class="">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" class="">
<div class=""><p dir="ltr" class=""><br class="">
On Jun 21, 2016 6:30 PM, Chris Hoge <<a href="mailto:chris@openstack.org" class="">chris@openstack.org</a>> wrote:<br class="">
><br class="">
> * Should there be a short-term exception for additional properties?</p><p dir="ltr" class="">Yes, absolutely.<br class="">
</p><p dir="ltr" class="">> This change has been harmful to vendors, users, and the OpenStack<br class="">
> Powered program, and there should be a facility in DefCore to handle<br class="">
> this. Existing companies, that passed early in the year last year, no<br class="">
> longer pass. </p><p dir="ltr" class="">This is the crux of the issue; a cloud that passed in December stopped passing in January, not due to any change on the part of the product offered for sale.</p><p dir="ltr" class="">Making this change even more egregious, this change is not part of any required capability - this was an extraneous change. Even if we want to make "does not return extra properties" a tested capability in the defcorish sense, we would need to
put it through the standard process (widely deployed? Aligned with future direction? etc.) and then put in via the standard advisory/approved process.</p><p dir="ltr" class="">> While there has been warning, product decisions move more<br class="">
> slowly. </p><p dir="ltr" class="">There has been lots of warnings on lots of things. That doesn't mean that whatever makes it into upstream automatically is part of Openstack(TM). The things that are part of the Openstack trademark are solely decided according to the defcore process
- a process that was negotiated out for literally years.<br class=""></p></div></div></blockquote><div>Yes, and microversions and strict API checking is a change that</div><div>we would be giving vendors more than two years to adopt.</div><blockquote type="cite" class=""><div class=""><div class=""><p dir="ltr" class="">
</p><p dir="ltr" class="">> * Should there a permanent exception for additional properties?</p><p dir="ltr" class="">Yes, until such time as "Does not return additional properties" is an accepted defcore capability.</p></div></div></blockquote><div>I disagree that it’s a capability. It’s the API definition, and</div><div>part of testing that definition is checking for a well-formed</div><div>response on every call. By definition you’re not part of the</div><div>Nova 2.1+ API if you add extra properties, and 2.0 is</div><div>deprecated (and removed upstream).</div><blockquote type="cite" class=""><div class=""><div class=""><p dir="ltr" class="">> However, upstream is moving in this<br class="">
> direction, and it's only a matter of time before more projects and tools<br class="">
> adopt strict response checking, making it a long-term interoperability<br class="">
> issue regardless of the position DefCore takes. </p><p dir="ltr" class="">I would add that I oppose any restriction on the ability to provide extensions until such point as there is a workable alternative to migrate to, plus an appropriate time to migrate.</p><p dir="ltr" class="">I believe that this whole issue is an inappropriate technical fix for what is really social problem.<br class=""></p></div></div></blockquote><div>This is addressing a social and technical problem. It</div><div>forces vendors to make their additions discoverable and</div><div>interoperable. Every cloud sending extra data back</div><div>on what are well-defined responses harms interoperability.</div><blockquote type="cite" class=""><div class=""><div class=""><p dir="ltr" class="">
</p><p dir="ltr" class="">> * What is our guidance for vendors going forward?<br class="">
><br class="">
> My suggestion to vendors is to use the next year to adjust their product<br class="">
> strategy and releases. The ideal solution is to work with upstream to<br class="">
> have additional properties rolled into a new micro-version [2], which<br class="">
> would force those properties to be adopted upstream into the Tempest<br class="">
> library.</p><p dir="ltr" class="">I am generally supportive of this, but that presupposes that microversions actually provide a realistic alternative mechanism. This has not been shown yet.</p></div></div></blockquote><div>How has it not been shown? We’ve had 30 micro version</div><div>revisions to the API[1], much of it to add information that is similar</div><div>to what the RAX public cloud is returning.</div><div><br class=""></div><div>I don’t like that this is painful, but at some point the painful step</div><div>has to be taken. That only two clouds are being significantly</div><div>impacted by this problem is an indication that micro-versions</div><div>and the API restrictions have been widely adopted. I’m </div><div>looking for a solution that gives deployed products time to</div><div>align with the direction the community has clearly and loudly</div><div>said they want the Nova APIs to go in.</div><div><br class=""></div><div>-Chris</div><div><br class=""></div><div>[1] <a href="http://docs.openstack.org/developer/nova/api_microversion_history.html#id3" class="">http://docs.openstack.org/developer/nova/api_microversion_history.html#id3</a></div><br class=""><blockquote type="cite" class=""><div class=""><div class=""><p dir="ltr" class="">Thanks,<br class="">
Van <br class="">
</p>
</div>
</div></blockquote></div><br class=""></body></html>