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

nuwan_ag 07d873eda2 Made ec2 refresh methods more resilient to missing/deleted objects. 10 rokov pred
cloudbridge 07d873eda2 Made ec2 refresh methods more resilient to missing/deleted objects. 10 rokov pred
test 4ac4c0cfb0 Improved tests to make sure that deleted objects are actually deleted. 10 rokov pred
.gitignore bc79e797a9 Add .DS_Store to .gitignore 10 rokov pred
.travis.yml 718e5fdd05 Removed osx from travis build. 10 rokov pred
LICENSE 1500caecff Initial commit 10 rokov pred
README.md 6fd60d9370 Rename EC2 into AWS to be consistent with the naming principles used with OpenStack 10 rokov pred
example.py 1cfae21f31 Merge branch 'master' of https://github.com/gvlproject/cloudbridge 10 rokov pred
requirements.txt 4b12ccfb9b Added setup.py 10 rokov pred
setup.py 6a602f4380 Added openstack object store implementation 10 rokov pred
tox.ini 629e1ed12a Renamed aws environment variables 10 rokov pred

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.AWS, 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., aws or openstack) and then run the tox command.

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