Yaml Lint action
Find a file
Ilir Bekteshi c2e8eccd22
Change default output format to parsable (#17)
* Change default output format to parsable

`github` format is barely usable in the logs where it only shows that errors/warnings occurred but not which file:line.

* Update README.md
2021-04-23 12:03:45 +02:00
.github/workflows Convert to composite action #10 (#11) 2020-11-08 18:54:33 +01:00
test Use yamllint github format to set file annotations on errors & warnings (#12) 2020-10-22 12:23:39 +02:00
.gitattributes Autotag releases, use Dockerfile (for now) #5 2020-02-28 10:14:09 +01:00
.gitignore Initial commit 2019-10-16 10:26:48 +02:00
.yamllint Use yamllint github format to set file annotations on errors & warnings (#12) 2020-10-22 12:23:39 +02:00
action.yml Change default output format to parsable (#17) 2021-04-23 12:03:45 +02:00
Dockerfile Installs build tools for installing pyyaml (#15) 2021-04-15 08:44:05 +02:00
entrypoint.sh Convert to composite action #10 (#11) 2020-11-08 18:54:33 +01:00
LICENSE Initial commit 2019-10-16 10:26:48 +02:00
README.md Change default output format to parsable (#17) 2021-04-23 12:03:45 +02:00

GitHub YAMLlint

This action executes yamllint (https://github.com/adrienverge/yamllint) against file(s) or folder

Usage

Simple as:

- uses: ibiqlik/action-yamllint@v3

Optional parameters

  • config_file - Path to custom configuration
  • config_data - Custom configuration (as YAML source)
  • file_or_dir - Enter file/folder (space separated), wildcards accepted. Examples:
    • . - run against all yaml files in a directory recursively (default)
    • file1.yaml
    • file1.yaml file2.yaml
    • kustomize/**/*.yaml mychart/*values.yaml
  • format - Format for parsing output [parsable,standard,colored,github,auto] (default: parsable)
  • strict - Return non-zero exit code on warnings as well as errors [true,false] (default: false)

Note: If .yamllint configuration file exists in your root folder, yamllint will automatically use it.

Example usage in workflow

name: Yaml Lint
on: [push]
jobs:
  lintAllTheThings:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v1
    - name: yaml-lint
      uses: ibiqlik/action-yamllint@v3
      with:
        file_or_dir: myfolder/*values*.yaml
        config_file: .yamllint.yml

Or just simply check all yaml files in the repository:

name: Yaml Lint
on: [push]
jobs:
  lintAllTheThings:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v1
    - name: yaml-lint
      uses: ibiqlik/action-yamllint@v3

Config data examples:

# Single line
config_data: "{extends: default, rules: {new-line-at-end-of-file: disable}}"
# Multi line
config_data: |
  extends: default
  rules:
    new-line-at-end-of-file:
      level: warning
    trailing-spaces:
      level: warning