dce445f956
Print out the data that fails to validate when doing schema checking on modules This allows easier interpretation of error messages. From: ``` ERROR: DOCUMENTATION.notes.2: expected basestring ``` To: ``` ERROR: DOCUMENTATION.notes.2: expected basestring @ data['notes'][2]. Got {"As with C(include) this task can be static or dynamic, If static it implies that it won't need templating nor loops nor conditionals and will show included tasks in the --list options. Ansible will try to autodetect what is needed, but you can set `static": 'yes|no` at task level to control this.'} ``` |
||
---|---|---|
.. | ||
__init__.py | ||
module_args.py | ||
README.rst | ||
schema.py | ||
skip.txt | ||
test_validate_modules_regex.py | ||
utils.py | ||
validate-modules |
validate-modules
Python program to help test or validate Ansible modules.
Originally developed by Matt Martz (@sivel)
Usage
cd /path/to/ansible/source
source hacking/env-setup
test/sanity/validate-modules/validate-modules /path/to/modules
Help
usage: validate-modules [-h] [-w] [--exclude EXCLUDE] modules
positional arguments:
modules Path to module or module directory
optional arguments:
-h, --help show this help message and exit
-w, --warnings Show warnings
--exclude EXCLUDE RegEx exclusion pattern
Current Validations
Modules
Errors
- Interpreter line is not
#!/usr/bin/python
main()
not at the bottom of the file- Module does not import
ansible.module_utils.basic
- Missing
DOCUMENTATION
- Documentation is invalid YAML
- Invalid schema for
DOCUMENTATION
- Missing
EXAMPLES
- Invalid Python Syntax
- Tabbed indentation
- Use of
sys.exit()
instead ofexit_json
orfail_json
- Missing GPLv3 license header in module
- PowerShell module missing
WANT_JSON
- PowerShell module missing
POWERSHELL_COMMON
- New modules have the correct
version_added
- New arguments have the correct
version_added
- Modules should not import requests, instead use
ansible.module_utils.urls
- Missing
RETURN
for new modules - Use of
type()
for type comparison instead ofisinstance()
Warnings
- Try/Except
HAS_
expression missing - Missing
RETURN
for existing modules import json
found- Module contains duplicate globals from basic.py
Module Directories (Python Packages)
- Missing
__init__.py