[openstack-dev] [Neutron] Plugin and Driver Inclusion Requirements

Mark McClain mark.mcclain at dreamhost.com
Thu Nov 14 20:20:30 UTC 2013


tl;dr
-----
The Neutron team has experienced tremendous growth in vendor plugins and drivers over the last few cycles.  As a result of the growth, the Neutron team is implementing new requirements for plugin and driver code for Icehouse cycle to ensure continued code quality and stability.

- Each third party plugin/driver shall designate a point of contact for the coordinated release cycle.
- To be designated as compatible, a third-party plugin and/or driver code must implement external third party integration testing.
- Policy is in effect immediately for new plugin/drivers.
- Existing plugin/drivers have until Icehouse-2 to become compliant.

Introduction
-----------
Ensuring release quality through proper testing is an important tenant of the OpenStack community and Neutron team wants to do our part. We are introducing changes below provide more visibility into the quality and stability of vendor plugin and driver code.  The policies described here are in effect immediately.

Rationale
--------
Code proposals for third party plugins have always presented a review challenge for the Neutron core team.  In the early days, code was often proposed by core project contributors and our review process only validated whether the requirements were met for community coding style and unit testing.  As Neutron has added new resources via extensions, it has become more difficult for Neutron reviewers to ensure the proposed code is functional.  Many of the plugins and/or drivers require proprietary hardware and/or software to conduct such testing.

In addition to testing changes, the Neutron team is revising the requirements for the point of contact for third party code.  The changes bring the written expectations for contacts in line with current practice.

Point of Contact Requirements
-----------------------------
Each third party plugin and/or driver shall designate a point of contact for each coordinated release cycle.  The contact will serve as a liaison between the Neutron core team and the vendor or community supporting the plugin or driver.  The contact shall:
	- Attend weekly Neutron team IRC meetings
	- Be an active reviewer and contributor 
	- Be an active participant on openstack-dev mailing list
	- Assist the core team with triaging bugs specific to the plugin and/or driver
	- Ensure OpenStack development deadlines are properly communicated back to their company and/or community

NOTE: The this information can be maintained here: https://wiki.openstack.org/wiki/Neutron_Plugins_and_Drivers

Testing Requirements
-----------------
To be designated as compatible, a third-party plugin and/or driver code must implement external third party testing.  The testing should be Tempest executed against a Devstack build with the proposed code changes.  The environment managed by the vendor should be configured to incorporate the plugin and/or driver solution.  The OpenStack Infrastructure team has provided details on how to integrate 3rd party testing at:

http://ci.openstack.org/third_party.html

and Tempest can be found at:

https://github.com/openstack/tempest

The Neutron team expects that the third party testing will provide a +/-1 verify vote for all changes to a plugin or driver’s code.  In addition, the Neutron team expects that the third party test will also vote on all code submissions by the jenkins user.  The jenkins user regularly submits requirements changes and the Neutron team hopes to catch any possible regressions as early as possible.

Existing Plugin and Drivers
-------------------------
Plugins and drivers currently in the Neutron project repository will be given a grace period until the Icehouse-2 milestone to implement external third party testing.  At that time, the Neutron team will release a list of the compatible plugins and drivers (i.e. those that meet the testing requirements).  Plugins and drivers that do not have external testing will be deprecated at the Icehouse release and will be candidates for removal when the J-release cycle opens.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.openstack.org/pipermail/openstack-dev/attachments/20131114/3bc6c934/attachment.html>


More information about the OpenStack-dev mailing list