--- repos: - repo: local hooks: - id: build-fs-matrix name: build-fs-matrix entry: python fs-matrix.py > doc/source/feature-configuration-generated.rst files: config/general_config language: python language_version: python3 always_run: true additional_dependencies: - texttable - pyyaml - repo: https://github.com/pre-commit/pre-commit-hooks rev: v2.4.0 hooks: - id: end-of-file-fixer - id: trailing-whitespace - id: mixed-line-ending - id: check-byte-order-marker - id: check-executables-have-shebangs - id: check-merge-conflict - id: check-symlinks - id: debug-statements - id: flake8 - id: check-yaml files: .*\.(yaml|yml)$ - repo: https://github.com/adrienverge/yamllint.git rev: v1.20.0 hooks: - id: yamllint files: \.(yaml|yml)$ types: [file, yaml] entry: yamllint --strict -f parsable - repo: https://github.com/ansible/ansible-lint.git rev: v4.2.0 hooks: - id: ansible-lint always_run: true pass_filenames: false # do not add file filters here as ansible-lint does not give reliable # results when called with individual files. # https://github.com/ansible/ansible-lint/issues/611 verbose: true entry: env ANSIBLE_LIBRARY=library ansible-lint --force-color -p -v - repo: https://github.com/openstack-dev/bashate.git rev: 0.6.0 hooks: - id: bashate entry: bashate --error . --ignore=E006,E040 # Run bashate check for all bash scripts # Ignores the following rules: # E006: Line longer than 79 columns (as many scripts use jinja # templating, this is very difficult) # E040: Syntax error determined using `bash -n` (as many scripts # use jinja templating, this will often fail and the syntax # error will be discovered in execution anyway)