Gordon is no longer developed publicly. This code will remain available, but will not change.
Service to consume hostname-related events from a pub/sub and add, update, & delete records for a 3rd party DNS provider.
NOTICE: This is still in the planning phase and under active development. Gordon should not be used in production, yet.
For the initial release, the following will be supported:
- Python 3.6
- Google Cloud Platform
Support for other Python versions and cloud providers may be added.
For development and running tests, your system must have all supported versions of Python installed. We suggest using pyenv.
$ git clone git@github.com:spotify/gordon.git && cd gordon
# make a virtualenv
(env) $ pip install -r dev-requirements.txt
To run the entire test suite:
# outside of the virtualenv
# if tox is not yet installed
$ pip install tox
$ tox
If you want to run the test suite for a specific version of Python:
# outside of the virtualenv
$ tox -e py36
To run an individual test, call pytest
directly:
# inside virtualenv
(env) $ pytest tests/test_foo.py
To generate documentation:
(env) $ pip install -r docs-requirements.txt
(env) $ cd docs && make html # builds HTML files into _build/html/
(env) $ cd _build/html
(env) $ python -m http.server $PORT
Then navigate to localhost:$PORT
!
To watch for changes and automatically reload in the browser:
(env) $ cd docs
(env) $ make livehtml # default port 8888
# to change port
(env) $ make livehtml PORT=8080
This project adheres to the Open Code of Conduct. By participating, you are expected to honor this code.