openstack-doc-tools/autogenerate-config-docs
Andreas Jaeger 05f9428303 Rework repository to make it an installable python package
This is an overhaul of the complete content to make it
a separate python package that can be installed on the jenkins
machines as well as on editor's machines.

The goal of this patchset is to package everything
and get the command "openstack-doc-test" running so that
it can be used for gating.

This will need further refinement for the other commands.

Change-Id: Icc2f1807dd5ab5fb2f83c05d1b3895b3a9a0dbaf
2013-12-14 22:53:18 +01:00
..
flagmappings Update nova flagmappings for libvirt group 2013-11-22 06:53:30 -05:00
test Add Autogenerate-config-doc code to tools 2013-08-10 09:43:55 +08:00
.gitignore Add Autogenerate-config-doc code to tools 2013-08-10 09:43:55 +08:00
autohelp.py Add Autogenerate-config-doc code to tools 2013-08-10 09:43:55 +08:00
common.py Rework repository to make it an installable python package 2013-12-14 22:53:18 +01:00
extract_swift_flags.py Update autogenerate tools for new directory struct 2013-09-07 12:29:27 -07:00
flow.dia Add Autogenerate-config-doc code to tools 2013-08-10 09:43:55 +08:00
README.md Adds multiple group support for config options in 2013-12-10 11:01:21 -05:00

autogenerate-config-docs

Automatically generate configuration tables to document OpenStack.

Dependencies: python-git (at least version 0.3.2 RC1), oslo.config

Setting up your environment

Note: This tool is best run in a fresh VM environment, as running it requires installing the dependencies of the particular OpenStack product you are working with. Installing all of that on your normal machine could leave you with a bunch of cruft!

First install git and python-pip,

$ sudo apt-get install git python-pip

next, install oslo.config and GitPython

$ sudo pip install oslo.config "GitPython>=0.3.2.RC1"

then, checkout the repository you are working with:

$ git clone https://github.com/openstack/nova.git

(this guide makes reference to a /repos directory, so you should record the directory you are using and replace as appropriate below)

and the tool itself:

$ git clone https://github.com/openstack/openstack-manuals.git

and finally, the dependencies for the product you are working with:

$ sudo pip install -r nova/requirements.txt

Now you are ready to use the tool.

Using the tool

This tool is divided into three parts:

  1. Extraction of flags names eg

    $ ./autohelp.py --action create -i flagmappings/nova.flagmappings -o names --path /repos/nova

  2. Grouping of flags

This is currently done manually, by using the flag name file and placing one or more categories after a space.

eg

 $ head flagmappings/glance.flagmappings
 admin\_password registry api
 admin\_role api
 admin\_tenant\_name registry api
 admin\_user registry
 ...
  1. Creation of docbook-formatted configuration table files

eg

$ ./autohelp.py --action create -i flagmappings/nova.flagmappings -o docbook --path /repos/nova

A worked example - updating the docs for H2

update automatically generated tables - from scratch

$ sudo apt-get update
$ sudo apt-get install git python-pip python-dev
$ sudo pip install git-review GitPython
$ git clone git://github.com/openstack/openstack-manuals.git
$ cd openstack-manuals/
$ git review -d 35726
$ cd tools/autogenerate-config-docs/

Now, cloning and installing requirements for nova, glance, quantum

$ for i in nova glance quantum; do git clone git://github.com/openstack/$i.git; done
$ for i in nova glance quantum; do sudo pip install -r $i/requirements.txt; done

This missed some requirements for nova, which were fixed by:

$ sudo pip install python-glanceclient websockify pyasn1 python-cinderclient error_util
$ sudo apt-get install python-ldap python-lxml

Making the flag names update

./autohelp.py -vvv --action update -i flagmappings/nova.flagmappings -o names --path ~/nova | more

At this point, seach through flagmappings/nova.flagmappings.new for anything labelled Unknown and fix, once that is done use:

./autohelp.py -vvv --action create -i flagmappings/nova.flagmappings -o docbook --path ~/nova

to generate the XML files and move those into the appropriate part ofthe git repo