Simple tool for generating ansible role documentation
Project description
# Ansible-DocGen
A python utility for generating Ansible README.md files for roles
[![Build Status](https://travis-ci.org/toast38coza/Ansible-DocGen.svg?branch=master)](https://travis-ci.org/toast38coza/Ansible-DocGen)
* Ansible-DocGen is tested in `python3`
## Installation
### PIP
pip install ansible-docgeneration
**Note if you installed it from pip, you will need to use it like so from the command line:**
python -m docgen
### From Source
```
git clone git@github.com:toast38coza/Ansible-DocGen.git
cd Ansible-DocGen
virtualenv-3.4 env -p python3
source env/bin/activate
pip install -r requirements.txt
```
## Usage
```
Usage: docgen.py [OPTIONS]
# Basic usage:
python docgen.py
#Specify a path to a role:
python docgen.py --path=/path/to/ansible/role
#Specify a path to a role, and output the result to a file:
python docgen.py --path=/path/to/ansible/role > /path/to/ansible/role/README.md
```
**Options:**
* `--path` Path to your role (defaults to current directory)
* `--help` Show this message and exit.
## Test
.. coming soon
## Example output:
A role for settings up a django application
* **Required ansible version:** >= 1.2
## Required variables:
| Parameter | Example | Comment |
|--------------|----------|----------|
|`django_app_name`|`polls`|The name of your application. Typcially this will be the name of the folder containing your settings.py file|
## Optional variables:
| Parameter | Default |
|--------------|----------|
|`django_settings_directory_path`|`{{django_app_path}}/{{django_project_name}}`|
|`django_gunicorn_workers`|`2`|
|`django_venv_path`|`/srv/venvs/{{django_app_name}}`|
|`django_media_path`|`/srv/{{django_app_name}}/media`|
|`django_http_port`|`8000`|
|`manage_commands`|`['collectstatic', 'syncdb', 'migrate']`|
|`django_settings_vars`|`[]`|
|`django_static_path`|`/srv/{{django_app_name}}/static`|
|`django_log_path`|`/var/log/{{django_app_name}}`|
|`django_requirements_location`|`{{django_app_path}}/requirements.txt`|
|`django_env_vars`|`[]`|
|`django_version`|`1.8`|
|`django_app_path`|`/var/www/{{django_app_name}}`|
|`django_github_version`|`master`|
### Basic usage
```
- hosts: all
vars:
- django_app_name: polls
roles:
- { role: django, tags: django }
```
### TODO
* TODO: use pex to package virtualenv
* Unit testing
* Travis CI
* Better error handling
A python utility for generating Ansible README.md files for roles
[![Build Status](https://travis-ci.org/toast38coza/Ansible-DocGen.svg?branch=master)](https://travis-ci.org/toast38coza/Ansible-DocGen)
* Ansible-DocGen is tested in `python3`
## Installation
### PIP
pip install ansible-docgeneration
**Note if you installed it from pip, you will need to use it like so from the command line:**
python -m docgen
### From Source
```
git clone git@github.com:toast38coza/Ansible-DocGen.git
cd Ansible-DocGen
virtualenv-3.4 env -p python3
source env/bin/activate
pip install -r requirements.txt
```
## Usage
```
Usage: docgen.py [OPTIONS]
# Basic usage:
python docgen.py
#Specify a path to a role:
python docgen.py --path=/path/to/ansible/role
#Specify a path to a role, and output the result to a file:
python docgen.py --path=/path/to/ansible/role > /path/to/ansible/role/README.md
```
**Options:**
* `--path` Path to your role (defaults to current directory)
* `--help` Show this message and exit.
## Test
.. coming soon
## Example output:
A role for settings up a django application
* **Required ansible version:** >= 1.2
## Required variables:
| Parameter | Example | Comment |
|--------------|----------|----------|
|`django_app_name`|`polls`|The name of your application. Typcially this will be the name of the folder containing your settings.py file|
## Optional variables:
| Parameter | Default |
|--------------|----------|
|`django_settings_directory_path`|`{{django_app_path}}/{{django_project_name}}`|
|`django_gunicorn_workers`|`2`|
|`django_venv_path`|`/srv/venvs/{{django_app_name}}`|
|`django_media_path`|`/srv/{{django_app_name}}/media`|
|`django_http_port`|`8000`|
|`manage_commands`|`['collectstatic', 'syncdb', 'migrate']`|
|`django_settings_vars`|`[]`|
|`django_static_path`|`/srv/{{django_app_name}}/static`|
|`django_log_path`|`/var/log/{{django_app_name}}`|
|`django_requirements_location`|`{{django_app_path}}/requirements.txt`|
|`django_env_vars`|`[]`|
|`django_version`|`1.8`|
|`django_app_path`|`/var/www/{{django_app_name}}`|
|`django_github_version`|`master`|
### Basic usage
```
- hosts: all
vars:
- django_app_name: polls
roles:
- { role: django, tags: django }
```
### TODO
* TODO: use pex to package virtualenv
* Unit testing
* Travis CI
* Better error handling
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file ansible-docgenerator-0.1.0.tar.gz
.
File metadata
- Download URL: ansible-docgenerator-0.1.0.tar.gz
- Upload date:
- Size: 3.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d547245718238f4ead9b2a276069b55f7e47b3290e1258b43c657c73baf51cf5 |
|
MD5 | 942e05b03fbafb17eda6a8486d0b69ce |
|
BLAKE2b-256 | ee64e2d192c3c10479e0ca2687c04dd69273562c7b486c2b7d707c8daf74436d |