Contributing to the OpenStack SDK

Contributing to the OpenStack SDK

This section of documentation pertains to those who wish to contribute to the development of this SDK. If you’re looking for documentation on how to use the SDK to build applications, please see the user section.

About the Project

The OpenStack SDK is a OpenStack project aimed at providing a complete software development kit for the programs which make up the OpenStack community. It is a set of Python-based libraries, documentation, examples, and tools released under the Apache 2 license.

Contacting the Developers


The developers of this project are available in the #openstack-sdks channel on Freenode. This channel includes conversation on SDKs and tools within the general OpenStack community, including OpenStackClient as well as occasional talk about SDKs created for languages outside of Python.


The openstack-dev mailing list fields questions of all types on OpenStack. Using the [python-openstacksdk] filter to begin your email subject will ensure that the message gets to SDK developers.

Development Environment

The first step towards contributing code and documentation is to setup your development environment. We use a pretty standard setup, but it is fully documented in our setup section.


The project contains three test packages, one for unit tests, one for functional tests and one for examples tests. The openstack.tests.unit package tests the SDK’s features in isolation. The openstack.tests.functional and openstack.tests.examples packages test the SDK’s features and examples against an OpenStack cloud.

Project Layout

The project contains a top-level openstack package, which houses several modules that form the foundation upon which each service’s API is built on. Under the openstack package are packages for each of those services, such as openstack.compute.

Adding Features

Does this SDK not do what you need it to do? Is it missing a service? Are you a developer on another project who wants to add their service? You’re in the right place. Below are examples of how to add new features to the OpenStack SDK.

Creative Commons Attribution 3.0 License

Except where otherwise noted, this document is licensed under Creative Commons Attribution 3.0 License. See all OpenStack Legal Documents.