A consistent interface to multiple IaaS clouds; in Python http://cloudbridge.cloudve.org

Enis Afgan b42ddb020c Qualify __repr__ returns with CB- 10 éve
cloudbridge b42ddb020c Qualify __repr__ returns with CB- 10 éve
test 2f285b4365 Temporary fix for travis build hang 10 éve
.gitignore bc79e797a9 Add .DS_Store to .gitignore 10 éve
.travis.yml e090981cb5 Simplified tox coverage. Fixed typos 10 éve
LICENSE 1500caecff Initial commit 10 éve
README.md 2574c82589 Add testing docs to README 10 éve
example.py 1cfae21f31 Merge branch 'master' of https://github.com/gvlproject/cloudbridge 10 éve
requirements.txt 4b12ccfb9b Added setup.py 10 éve
setup.py cfaaf0db5d Improved pep8 compliance 10 éve
tox.ini 0eb5f71847 Omit interfaces from coverage 10 éve

README.md

cloudbridge

cloudbridge provides a layer of abstraction over different cloud providers. It's a straightfoward implementation of the bridge pattern.

Code Climate Code Health Coverage Status Build Status Release Status

Usage example

from cloudbridge.providers.interfaces import CloudProviderFactory
from bunch import Bunch

config = Bunch(access_key='a_key',
               secret_key='s_key')

provider = CloudProviderFactory().create_provider(ProviderList.EC2, config)
print(provider.security.list_key_pairs())

Running tests

To run the test suite locally, install tox with pip install tox and run tox command. This will run all the tests for all the environments defined in file tox.ini. In order to properly run the tests, you should have all the environment variables listed in tox.ini file (under passenv) exported.

If you’d like to run the tests on a specific environment only, use a command like this: tox -e py27 (or python setup.py test directly). If you'd like to run the tests for a specific cloud only, you should export env var CB_TEST_PROVIDER and specify the desired provider name (e.g., ec2 or openstack) and then run the tox command.

Note that running the tests will create various cloud resources, for which you may incur costs.