-
Notifications
You must be signed in to change notification settings - Fork 74
Developers Guide
This document contains some quick notes that are needed to get started with developing in Adagios. It's a work in progress an anyone is welcome to make changes to the guide.
We use github pull requests to receive patches. If you are not familiar with them, read on for a short explanation of the process.
If you are only commiting trivial patches you can browse to the files here on github and click edit.
You will be asked to fork the repo (do that!) and after you have saved your changes you will have a copy of our code on your repository.
When you have saved, click the "pull request" button in your repository and it will open up an issue on our and and ask for merging the patch.
Adagios python code should more or less conform with PEP8, although line length up to 120 chars is common and no plans to change that.
Make sure you have all the dependencies installed on your machine and optimally have gotten adagios to work. You will need a set of nagios configuraiton under /etc/nagios but if you are not working on the status views it should be optional to have nagios installed and running.
# Clone our repo
git clone http://github.com/opinkerfi/adagios.git
# Start the django web server
cd adagios/adagios
python manage.py runserver
Most of the complex code logic lies in underlying libraries like pynag.
We use Django's unit tests for smoke-testing views. Please do not commit your code if you break any of the unit tests.
Unit tests themselves live within every django app so for examples tests for the status module live in /status/tests.py. You can run the unit tests from the command line with:
python manage.py test
Creating test database for alias 'default'...
.................
----------------------------------------------------------------------
Ran 17 tests in 2.906s
OK
Destroying test database for alias 'default'...
If you create any new views, you are also responsible for creating unit tests for them.