<div dir="ltr">I tend to agree with Lucas. I think ironic-lib was designed to have common code to be used primarily into ironic and IPA. It was not intended to be used in other projects. We tend to add methods in the ironic-lib with Ironic and IPA in mind and never thought of it could be used by out of tree drivers.<div><br></div><div>But it would be useful, it were to consumed by out of tree drivers.</div><div><br></div><div>Thanks,</div><div>Shiv</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, May 16, 2016 at 8:26 PM, Sam Betts (sambetts) <span dir="ltr"><<a href="mailto:sambetts@cisco.com" target="_blank">sambetts@cisco.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I personally disagree with saying that if we wanted it make it usable by<br>
projects other than ones in the Ironic umbrella it should go into oslo. I<br>
think that non-ironic projects directly related to Ironic such as out of<br>
tree drivers etc, should be able to utilise the code placed into<br>
ironic-lib.<br>
<br>
Neutron are doing a very similar thing for all their drivers/extensions<br>
they have broken out over the last 2 cycles,<br>
<a href="http://specs.openstack.org/openstack/neutron-specs/specs/liberty/neutron-li
b.html" rel="noreferrer" target="_blank">http://specs.openstack.org/openstack/neutron-specs/specs/liberty/neutron-li<br>
b.html</a>.<br>
<br>
Making ironic-lib available to out of tree drivers etc also puts us into a<br>
good position to begin the work to stabilise things like the driver API.<br>
Neutron is making the rule that out of tree drivers shouldn¹t<br>
inherit/import anything from the neutron core code base, only neutron-lib,<br>
they are doing this to provide a stable interface that shouldn¹t be broken<br>
by changes to neutron core. I think we could do the same, with in-tree<br>
drivers dog-fooding the driver api we provide in ironic-lib.<br>
<br>
Sam<br>
<span class=""><br>
On 16/05/2016 15:14, "Lucas Alvares Gomes" <<a href="mailto:lucasagomes@gmail.com">lucasagomes@gmail.com</a>> wrote:<br>
<br>
>Hi,<br>
><br>
>Thanks for starting this discussion Ruby.<br>
><br>
>On Mon, May 16, 2016 at 2:57 PM, Loo, Ruby <<a href="mailto:ruby.loo@intel.com">ruby.loo@intel.com</a>> wrote:<br>
>> Hi,<br>
>><br>
>> A patch to ironic-lib made me wonder about what is our supported usage<br>
>>of<br>
>> ironic-lib. Or even the intent/scope of it. This patch changes a method,<br>
</span>>> Œbootable¹ parameter is removed and Œboot_flag¹ parameter is added [1].<br>
<div class="HOEnZb"><div class="h5">>><br>
>> If this library/method is used by some out-of-tree thing (or even some<br>
>> in-tree but outside of ironic), this will be a breaking change. If this<br>
>> library is meant to be internal to ironic program itself, and to e.g.<br>
>>only<br>
>> be used by ironic and IPA, then that is different. I was under the<br>
>> impression that it was a library and meant to be used by whatever, no<br>
>> restrictions on what that whatever was. It would be WAY easier if we<br>
>>limited<br>
>> this for usage by only a few specified projects.<br>
>><br>
>> What do people think?<br>
>><br>
><br>
>I still believe that the ironic-lib project was designed to share code<br>
>between the Ironic projects _only_. Otherwise, if it the code was<br>
>supposed to be shared across multiple projects we should have put it<br>
>in oslo instead.<br>
><br>
>The governance description is a bit vague [0], it does say: "A python<br>
>library of common ironic utilities.". Does it include out-of-tree<br>
>ironic-related code? I would like to think that it does not. The fact<br>
>that ( IIRC ) we never stated that this is a public library, there's<br>
>no documentation of any methods/modules there, no release notes, no<br>
>sample usages, etc... Makes it a bit unsuitable for 3rd party<br>
>consumption.<br>
><br>
>That said, I'm not totally against make this library suitable for a<br>
>broader usage but this will require more thoughts on it and effort.<br>
><br>
>[0]<br>
><a href="https://github.com/openstack-infra/project-config/blob/920441f2fc02df89624" rel="noreferrer" target="_blank">https://github.com/openstack-infra/project-config/blob/920441f2fc02df89624</a><br>
>5b53e6f18b4ea6a0252a0/gerrit/projects.yaml#L2193<br>
><br>
>Cheers,<br>
>Lucas<br>
><br>
>__________________________________________________________________________<br>
>OpenStack Development Mailing List (not for usage questions)<br>
>Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
><a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br>
<br>
__________________________________________________________________________<br>
OpenStack Development Mailing List (not for usage questions)<br>
Unsubscribe: <a href="http://OpenStack-dev-request@lists.openstack.org?subject:unsubscribe" rel="noreferrer" target="_blank">OpenStack-dev-request@lists.openstack.org?subject:unsubscribe</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" rel="noreferrer" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div>