<div dir="ltr"><br><div class="gmail_quote"><div dir="ltr">On Mon, Jul 25, 2016 at 10:36 PM Hayes, Graham <<a href="mailto:graham.hayes@hpe.com">graham.hayes@hpe.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Top posting - this is a recap of what has been said, and some<br>
clarifications<br>
<br>
I realise that I was not very clear at the beginning of this process, so<br>
here is my effort to clarify things, from the ML thread, and the review.<br>
<br>
> ... does this also include plugins within projects, like storage<br>
> backends in cinder and hypervisor drivers in nova?<br>
<br>
No - this was not clear enough. This change is aimed at projects that are<br>
points of significant cross project interaction. While, in the future<br>
there may<br>
come a point where Nova Compute Drivers are developed out of tree (though<br>
I doubt it), that is not happening today. As a result, there is no<br>
projects in<br>
the list of projects that would need to integrate with Nova.<br>
<br>
> Could you please clarify: do you advocate for a generic plugin<br>
interface for<br>
> every project, or that each project should expose a plugin<br>
interface that<br>
> allows plugin to behave as in-tree components? Because the latter<br>
is what<br>
> happens with Tempest, and I see the former a bit complicated.<br>
<br>
For every project that has cross project interaction - tempest is a good<br>
example.<br>
<br>
For these projects, they should allow all projects in tree (like Nova,<br>
Neutron, Cinder etc are today), or they should have a plugin interface<br>
(like they currently do), but all projects *must* use it, and not use<br>
parts of tempest that are not exposed in that interface.<br></blockquote><div><br></div><div>Defining a policy that *all* projects must use the plugin interface would not help.</div><div>You could define plugins in tree in Tempest but that would not change much.</div><div>The plugin interface is quite complete as it is today, I don't expect it will be extended much after [0] is merged.<br></div><div><br></div><div>What still requires work in Tempest is the stable interface. Because plugins are not in the Tempest tree, the QA team recommend that they use only tempest stable interfaces. Increasing the surface of stable interfaces is what keeps a lot of the QA folks busy.</div><div><br></div><div>There's a lot of code in tempest that was written under the assumption that all tests would always live in the tempest tree; evolving that code into a stable publicly consumable interface is simply a lot of work, which the QA team is prioritising based on the input from plugins.<br></div><div><br></div><div>Tempest plugins are for all right now. Keystone, Cinder and Neutron already have a plugin today. We don't want tests which are not relevant for integration or defcore to be added to Tempest, and that is true for *all* services.</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
This would mean that tempest would move the nova, neutron, etc tests to<br>
use the plugin interface. </blockquote><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Now, that plugin could be kept in the tempest repo, and still maintained<br>
by the QA team, but should use the same interface as the other plugins<br>
that are not in that repository.<br></blockquote><div><br></div><div>All tests in tempest consume the stable interfaces in tempest.lib.</div><div>The QA team is working continuously to stabilise and migrate more parts of tempest into the tempest.lib namespace. </div><div><br></div><div>Since a lot of plugins are using tempest unstable interfaces, we're also trying as much as possible to maintain backward compatibility on unstable interfaces, until the stable version is available, but that is not always an option.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Of course, it is not just tempest - an incomplete list looks like:<br>
<br>
* Tempest<br>
* Devstack<br>
* Grende<br>
* Horizon<br>
* OpenStack Client<br>
* OpenStack SDK<br>
* Searchlight<br>
* Heat<br>
* Mistral<br>
* Celiometer<br>
* Rally<br>
* Documentation<br>
<br>
And I am sure I have missed some obvious ones. (if you see a project missing<br>
let me know on the review)<br>
<br>
<br>
> I think I disagree here. The root cause is being addressed:<br>
external tests can<br>
> use the Tempest plugin interface, and use the API, which is being<br>
stabilized.<br>
> The fact that the Tempest API is partially unstable is a temporary<br>
things, due<br>
> to the origin of the project and the way the scope was redefined,<br>
but again<br>
> it's temporary.<br>
<br>
This seems to be the core of a lot of the disagreement - this is only<br>
temporary,<br>
it will all be fixed in the future, and it should stay this way.<br>
<br>
Unfortunately the discrepancy between projects is not temporary. The<br>
specific<br>
problems I have highlighted in the thread for one of the projects is<br>
temporary,<br>
but I beleive the only long-term solution is to remove the difference<br>
between<br>
projects.<br>
<br>
> Before we start making lots of specific rules about how teams<br>
> coordinate, I would like to understand the problem those rules are<br>
meant<br>
> to solve, so thank you for providing that example.<br>
> ...<br>
> It's not clear yet whether there needs to be a new policy to change the<br>
> existing intent, or if a discussion just hasn't happened, or if someone<br>
> simply needs to edit some code.<br>
<br>
Unfortunately there is a big push back on editing code to help plugins from<br>
some of the projects. Again, having the differing access between<br>
projects will<br>
continue to exacerbate the problem.<br>
<br>
<br>
> "Change the name of the resolution"<br>
<br>
That was done in the last patchset. I think the Level Playing Field title<br>
bounced around my head from the other resolution that was titled Level<br>
Playing<br>
Field. It may have been confusing alright.<br>
<br>
I feel like I have been using tempest as an example a little too much,<br>
as it captures<br>
the current issues perfectly, and a large number of the community have some<br>
knowledge of it, and how it works.<br>
<br>
There is other areas across OpenStack where plugins need attention as well:<br>
<br>
Horizon<br>
-------<br>
<br>
Horizon privileged projects have access to much more panels than<br>
plugins (service status, quotas, overviews etc).<br>
Plugins have to rely on tarballs of horizon<br>
<br>
OpenStack Client<br>
----------------<br>
<br>
OpenStack CLI privileged projects have access to more commands, as<br>
plugins cannot hook in to them (e.g. quotas)<br>
<br>
Grenade<br>
-------<br>
<br>
Plugins may or may not have tempest tests ran (I think that patch<br>
merged), they have to use parts of tempest I was told explicitly<br>
plugins should not use to get the tests to run at that point.<br>
<br>
Docs<br>
----<br>
<br>
We can now add install guides and hook into the API Reference, and API<br>
guides. This is great - and I am really happy about it. We still have<br>
issues trying to integrate with other areas in docs, and most non docs<br>
privileged projects end up with massive amounts of users docs in<br>
<a href="http://docs.openstack.org/developer/" rel="noreferrer" target="_blank">docs.openstack.org/developer/</a><project> , which is not ideal.<br>
<br>
<br>
Thanks,<br>
<br>
Graham<br>
<br>
On 14/07/2016 20:25, Hayes, Graham wrote:<br>
> I just proposed a review to openstack/governance repo [0] that aims<br>
> to have everything across OpenStack be plugin based for all cross<br>
> project interaction, or allow all projects access to the same internal<br>
> APIs and I wanted to give a bit of background on my motivation, and how<br>
> it came about.<br>
><br>
> Coming from a smaller project, I can see issues for new projects,<br>
> smaller projects, and projects that may not be seen as "important".<br>
><br>
> As a smaller project trying to fit into cross project initiatives,<br>
> (and yes, make sure our software looks at least OK in the<br>
> Project Navigator) the process can be difficult.<br>
><br>
> A lot of projects / repositories have plugin interfaces, but also<br>
> have project integrations in tree, that do not follow the plugin<br>
> interface. This makes it difficult to see what a plugin can, and<br>
> should do.<br>
><br>
> When we moved to the big tent, we wanted as a community to move to<br>
> a flatter model, removing the old integrated status.<br>
><br>
> Unfortunately we still have areas when some projects are more equal -<br>
> there is a lingering set of projects who were integrated at the point<br>
> in time that we moved, and have preferential status.<br>
><br>
> A lot of the effects are hard to see, and are not insurmountable, but<br>
> do cause projects to re-invent the wheel.<br>
><br>
> For example, quotas - there is no way for a project that is not nova,<br>
> neutron, cinder to hook into the standard CLI, or UI for setting<br>
> quotas. They can be done as either extra commands<br>
> (openstack dns quota set --foo bar) or as custom panels, but not<br>
> the way other quotas get set.<br>
><br>
> Tempest plugins are another example. Approximately 30 of the 36<br>
> current plugins are using resources that are not supposed to be<br>
> used, and are an unstable interface. Projects in tree in tempest<br>
> are at a much better position, as any change to the internal<br>
> API will have to be fixed before the gate merges, but other<br>
> out of tree plugins are in a place where they can be broken at any<br>
> point.<br>
><br>
> None of this is meant to single out projects, or teams. A lot<br>
> of the projects that are in this situation have inordinate amounts of<br>
> work placed on them by the big-tent, and I can emphasize with why things<br>
> are this way. These were the examples that currently stick out<br>
> in my mind, and I think we have come to a point where we need to make<br>
> a change as a community.<br>
><br>
> By moving to a "plugins for all" model, these issues are reduced.<br>
> It undoubtedly will cause more, but it is closer to our goal<br>
> of Recognizing all our community is part of OpenStack, and<br>
> differentiate projects by tags.<br>
><br>
> This won't be a change that happens tomorrow, next week, or even next<br>
> cycle, but think as a goal, we should start moving in this direction<br>
> as soon as we can, and start building momentum.<br>
><br>
> Thanks,<br>
><br>
> Graham<br>
><br>
> 0 - <a href="https://review.openstack.org/342366" rel="noreferrer" target="_blank">https://review.openstack.org/342366</a><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>
__________________________________________________________________________<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></blockquote><div><br></div><div>andrea </div><div><br></div><div>[0] <a href="https://review.openstack.org/#/c/333513">https://review.openstack.org/#/c/333513</a></div></div></div>