Jump to: navigation, search

Neutron Plugins and Drivers

Revision as of 18:45, 19 May 2014 by Mestery (talk | contribs) (Existing Plugin and Drivers)

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.

Plugin/Driver Name Contact Name IRC Nick
ML2 Neutron Team rkukura, mestery
Big Switch/Floodlight Kevin Benton kevinbenton
Arista Networks Sukhdev Kapur Sukhdev
Embrane Ivar Lazzaro ivar-lazzaro
PLUMgrid Fawad Khaliq fawadkhaliq
Mellanox Irena Berezovsky irenab
Cisco Edgar Magana emagana
Brocade Shiv Haris shivh
Tail-f NCS Luke Gorrie lukego
A10 Networks Micheal Thompson layer427expert
Nicira/VMware Armando Migliaccio armax
Ryu Nachi Ueno nati_ueno
Metaplugin NTT Team nati_ueno, hichihara
NEC Akihiro Motoki amotoki
vArmour Gary Duan garyduan
Midokura Lucas Eznarriaga luqas
Nuage Networks Ronak Shah rms_13
Place Holder Person 1 Name irc_nick