diff options
author | OpenShift Bot <eparis+openshiftbot@redhat.com> | 2017-04-19 18:15:31 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-04-19 18:15:31 -0500 |
commit | f7563926873863f9455f24822f2197a36c49df06 (patch) | |
tree | 5d85c0bc126309c969ce629b9d6811506d22938a | |
parent | b0b66e5d8565ec5205e8eda2225b6e2678de3153 (diff) | |
parent | b1898ac36a115763e07f3eaf103f8bb5606d0e82 (diff) | |
download | openshift-f7563926873863f9455f24822f2197a36c49df06.tar.gz openshift-f7563926873863f9455f24822f2197a36c49df06.tar.bz2 openshift-f7563926873863f9455f24822f2197a36c49df06.tar.xz openshift-f7563926873863f9455f24822f2197a36c49df06.zip |
Merge pull request #3938 from mtnbikenc/syntax-check
Merged by openshift-bot
-rw-r--r-- | setup.py | 48 | ||||
-rw-r--r-- | tox.ini | 2 |
2 files changed, 49 insertions, 1 deletions
@@ -7,6 +7,7 @@ import os import fnmatch import re import sys +import subprocess import yaml # Always prefer setuptools over distutils @@ -199,6 +200,52 @@ class OpenShiftAnsibleGenerateValidation(Command): print('\nAll generate scripts passed.\n') +class OpenShiftAnsibleSyntaxCheck(Command): + ''' Command to run Ansible syntax check''' + description = "Run Ansible syntax check" + user_options = [] + + # Colors + FAIL = '\033[91m' # Red + ENDC = '\033[0m' # Reset + + def initialize_options(self): + ''' initialize_options ''' + pass + + def finalize_options(self): + ''' finalize_options ''' + pass + + def run(self): + ''' run command ''' + + has_errors = False + + for yaml_file in find_files( + os.path.join(os.getcwd(), 'playbooks', 'byo'), + None, None, r'\.ya?ml$'): + with open(yaml_file, 'r') as contents: + for line in contents: + # initialize_groups.yml is used to identify entry point playbooks + if re.search(r'initialize_groups\.yml', line): + print('-' * 60) + print('Syntax checking playbook: %s' % yaml_file) + try: + subprocess.check_output( + ['ansible-playbook', '-i localhost,', + '--syntax-check', yaml_file] + ) + except subprocess.CalledProcessError as cpe: + print('{}Execution failed: {}{}'.format( + self.FAIL, cpe, self.ENDC)) + has_errors = True + # Break for loop, no need to continue looping lines + break + if has_errors: + raise SystemExit(1) + + class UnsupportedCommand(Command): ''' Basic Command to override unsupported commands ''' user_options = [] @@ -242,6 +289,7 @@ setup( 'lint': OpenShiftAnsiblePylint, 'yamllint': OpenShiftAnsibleYamlLint, 'generate_validation': OpenShiftAnsibleGenerateValidation, + 'ansible_syntax': OpenShiftAnsibleSyntaxCheck, }, packages=[], ) @@ -21,4 +21,4 @@ commands = yamllint: python setup.py yamllint generate_validation: python setup.py generate_validation # TODO(rhcarvalho): check syntax of other important entrypoint playbooks - ansible_syntax: ansible-playbook --syntax-check playbooks/byo/config.yml + ansible_syntax: python setup.py ansible_syntax |