2013-04-20 09:33:52 -04:00
|
|
|
'Hacking' directory tools
|
|
|
|
=========================
|
|
|
|
|
|
|
|
Env-setup
|
|
|
|
---------
|
|
|
|
|
|
|
|
The 'env-setup' script modifies your environment to allow you to run
|
|
|
|
ansible from a git checkout using python 2.6+. (You may not use
|
|
|
|
python 3 at this time).
|
|
|
|
|
|
|
|
First, set up your environment to run from the checkout:
|
|
|
|
|
|
|
|
$ source ./hacking/env-setup
|
|
|
|
|
|
|
|
You will need some basic prerequisites installed. If you do not already have them
|
|
|
|
and do not wish to install them from your operating system package manager, you
|
|
|
|
can install them from pip
|
|
|
|
|
|
|
|
$ easy_install pip # if pip is not already available
|
2017-01-11 12:03:26 -08:00
|
|
|
$ pip install pyyaml jinja2 nose pytest passlib pycrypto
|
2013-04-20 09:33:52 -04:00
|
|
|
|
2014-01-28 20:29:24 -05:00
|
|
|
From there, follow ansible instructions on docs.ansible.com as normal.
|
2013-04-20 09:33:52 -04:00
|
|
|
|
|
|
|
Test-module
|
|
|
|
-----------
|
|
|
|
|
|
|
|
'test-module' is a simple program that allows module developers (or testers) to run
|
|
|
|
a module outside of the ansible program, locally, on the current machine.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
2016-12-26 19:24:01 +01:00
|
|
|
$ ./hacking/test-module -m lib/ansible/modules/commands/shell -a "echo hi"
|
2013-04-20 09:33:52 -04:00
|
|
|
|
|
|
|
This is a good way to insert a breakpoint into a module, for instance.
|
|
|
|
|
2015-05-28 14:43:25 -04:00
|
|
|
For more complex arguments such as the following yaml:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
parent:
|
|
|
|
child:
|
|
|
|
- item: first
|
|
|
|
val: foo
|
|
|
|
- item: second
|
|
|
|
val: boo
|
|
|
|
```
|
|
|
|
|
|
|
|
Use:
|
|
|
|
|
|
|
|
$ ./hacking/test-module -m module \
|
|
|
|
-a "{"parent": {"child": [{"item": "first", "val": "foo"}, {"item": "second", "val": "bar"}]}}"
|
|
|
|
|
2013-04-20 09:36:09 -04:00
|
|
|
Module-formatter
|
|
|
|
----------------
|
|
|
|
|
|
|
|
The module formatter is a script used to generate manpages and online
|
|
|
|
module documentation. This is used by the system makefiles and rarely
|
|
|
|
needs to be run directly.
|
|
|
|
|
|
|
|
Authors
|
|
|
|
-------
|
|
|
|
'authors' is a simple script that generates a list of everyone who has
|
|
|
|
contributed code to the ansible repository.
|
|
|
|
|
2013-04-20 09:33:52 -04:00
|
|
|
|