This is a python module for ceph configuration and deployment.
This python module is intended to be reused by any tool that automates the install of ceph.
All methods in this module are intended to be atomic and idempotent. Some state changes are in practice made up of many steps, but will verify that all stages have succeeded before presenting the result to the caller. Most functions are fully idempotent in operation so can be repeated or retried as often as necessary without causing unintended effects. This is so clients of this module do not need to keep track of whether the operation was already performed or not. Some methods do depend upon the successful completion of other methods. While not strictly idempotent, this is considered acceptable modules having dependencies on other methods operation should present clear error messages.
This python module was originally part of a salt execution module for configuring ceph on large clusters but it became clear that the code was reusable without salt.
For the original use case of salt configuration of ceph a making this module a stand alone library helps reuse of code for the execution and state functions without excessive state rediscovery.
Prerequisite packages from a normal ubuntu install:
- python3-stdeb
- python3-setuptools
- debhelper
- python3-all
- python-all
This library makes use of standard setuptools functionality.
python3 setup.py --command-packages=stdeb.command sdist_dsc --with-python2=True --with-python3=True --no-python2-scripts=True bdist_deb
The code is structured with basic methods calling 3 main class types.
- Models
This stores all the gathered configuration on the node to apply the function.
- Loaders
These objects are used to update the Model.
- Presenters
These objects are used to present the data in the model to the API users.
This code base is tested with the tox framework. All tests are in the directory:
ceph_cfg/tests/
To run all tests please run:
tox
Each test can be indevidually run an example is shown here:
py.test ceph_cfg/tests/test_utils_is_valid_base64.py
For packaging purposes we are currently turning off tox