1
0
Fork 0
mirror of https://github.com/hadolint/hadolint-action.git synced 2024-08-16 10:09:53 +02:00

Merge pull request #43 from m-ildefons/config-options

features: config options, saving to file, SARIF
This commit is contained in:
José Lorenzo Rodríguez 2022-03-22 09:41:12 +01:00 committed by GitHub
commit 070f68df71
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 112 additions and 32 deletions

View file

@ -50,7 +50,8 @@ jobs:
uses: ./ uses: ./
with: with:
dockerfile: testdata/warning.Dockerfile dockerfile: testdata/warning.Dockerfile
ignore: DL3014 DL3008 DL3015 ignore: 'DL3014,DL3008'
no-fail: true
- name: Run integration test 3 - set failure threshold - name: Run integration test 3 - set failure threshold
# This step will print out an info level rule violation, but not fail # This step will print out an info level rule violation, but not fail
@ -68,13 +69,21 @@ jobs:
failure-threshold: error failure-threshold: error
format: json format: json
- name: Run integration test 4 - output format - name: Run integration test 5 - output format
# This step will never fail, but will print out rule violations. # This step will never fail, but will print out rule violations.
uses: ./ uses: ./
with: with:
dockerfile: testdata/warning.Dockerfile dockerfile: testdata/warning.Dockerfile
config: testdata/hadolint.yaml config: testdata/hadolint.yaml
- name: Run integration test 6 - output to file
# This step will never fail, but will print out rule violations.
uses: ./
with:
dockerfile: testdata/warning.Dockerfile
format: sarif
output-file: /report.sarif
release: release:
if: github.event_name == 'push' && github.ref == 'refs/heads/master' if: github.event_name == 'push' && github.ref == 'refs/heads/master'
name: Release name: Release

View file

@ -1,4 +1,4 @@
FROM hadolint/hadolint:v2.7.0-debian FROM hadolint/hadolint:v2.8.0-debian
COPY LICENSE README.md problem-matcher.json / COPY LICENSE README.md problem-matcher.json /
COPY hadolint.sh /usr/local/bin/hadolint.sh COPY hadolint.sh /usr/local/bin/hadolint.sh

View file

@ -23,20 +23,34 @@ steps:
## Inputs ## Inputs
| Name | Description | Default | | Name | Description | Default |
|------------------ |------------------------------------------ |----------------- | |------------------- |------------------------------------------ |----------------- |
| dockerfile | The path to the Dockerfile to be tested | ./Dockerfile | | dockerfile | The path to the Dockerfile to be tested | ./Dockerfile |
| recursive | Search for specified dockerfile | false | | recursive | Search for specified dockerfile | false |
| | recursively, from the project root | | | | recursively, from the project root | |
| format | The output format. One of [tty \| json \| | tty | | config | Custom path to a Hadolint config file | ./.hadolint.yaml |
| | checkstyle \| codeclimate \| | | | output-file | A sub-path where to save the | |
| | gitlab_codeclimate] | | | | output as a file to | |
| ignore | Space separated list of Hadolint rules to | <none> | | no-color | Don't create colored output | |
| | ignore. | | | no-fail | Never fail the action | |
| config | Custom path to a Hadolint config file | ./.hadolint.yaml | | verbose | Output more information | |
| failure-threshold | Rule severity threshold for pipeline | info | | format | The output format. One of [tty \| json \| | tty |
| | failure. One of [error \| warning \| | | | | checkstyle \| codeclimate \| | |
| | info \| style \| ignore] | | | | gitlab_codeclimate \| codacy \| sarif] | |
| failure-threshold | Rule severity threshold for pipeline | info |
| | failure. One of [error \| warning \| | |
| | info \| style \| ignore] | |
| override-error | List of rules to treat with 'error' | |
| | severity | |
| override-warning | List of rules to treat with 'warning' | |
| | severity | |
| override-info | List of rules to treat with 'info' | |
| | severity | |
| override-style | List of rules to treat with 'style' | |
| | severity | |
| ignore | Space separated list of Hadolint rules to | <none> |
| | ignore. | |
| trusted-resgitries | List of urls of trusted registries | |
## Hadolint Configuration ## Hadolint Configuration

View file

@ -6,15 +6,38 @@ inputs:
required: false required: false
description: 'The path to the Dockerfile to lint' description: 'The path to the Dockerfile to lint'
default: 'Dockerfile' default: 'Dockerfile'
config:
required: false
description: 'Path to a config file'
default:
recursive: recursive:
required: false required: false
description: 'Search for specified dockerfile recursively, from the project root' description:
'Search for specified dockerfile recursively, from the project root'
default: 'false'
output-file:
required: false
description: 'The path where to save the linting results to'
default:
# standart hadolint options:
no-color:
required: false
description: Don't create colored output.
default: 'false'
no-fail:
required: false
description: Never exit with a failure status code
default: 'false'
verbose:
required: false
description: Print more information about the running config
default: 'false' default: 'false'
format: format:
required: false required: false
description: | description: |
The output format, one of [tty (default) | json | checkstyle | The output format, one of [tty (default) | json | checkstyle |
codeclimate | gitlab_codeclimate ] codeclimate | gitlab_codeclimate | codacy | sarif]
default: 'tty' default: 'tty'
failure-threshold: failure-threshold:
required: false required: false
@ -22,28 +45,56 @@ inputs:
Fail the pipeline only if rules with severity above this threshold are Fail the pipeline only if rules with severity above this threshold are
violated. One of [error | warning | info (default) | style | ignore] violated. One of [error | warning | info (default) | style | ignore]
default: 'info' default: 'info'
override-error:
required: false
description:
'A comma separated list of rules whose severity will be `error`'
default:
override-warning:
required: false
description:
'A comma separated list of rules whose severity will be `warning`'
default:
override-info:
required: false
description:
'A comma separated list of rules whose severity will be `info`'
default:
override-style:
required: false
description:
'A comma separated list of rules whose severity will be `style`'
default:
ignore: ignore:
required: false required: false
description: 'A space separated string of rules to ignore' description: 'A comma separated string of rules to ignore'
default: default:
config: trusted-registries:
required: false required: false
description: 'Path to a config file' description: 'A comma separated list of trusted registry urls'
default: default:
runs: runs:
using: 'docker' using: 'docker'
image: 'Dockerfile' image: 'Dockerfile'
args: args:
- -f
- ${{ inputs.format }}
- -t
- ${{ inputs.failure-threshold }}
- ${{ inputs.dockerfile }} - ${{ inputs.dockerfile }}
env: env:
HADOLINT_CONFIG: ${{ inputs.config }} NO_COLOR: ${{ inputs.no-color }}
HADOLINT_NOFAIL: ${{ inputs.no-fail }}
HADOLINT_VERBOSE: ${{ inputs.verbose }}
HADOLINT_FORMAT: ${{ inputs.format }}
HADOLINT_FAILURE_THRESHOLD: ${{ inputs.failure-threshold }}
HADOLINT_OVERRIDE_ERROR: ${{ inputs.override-error }}
HADOLINT_OVERRIDE_WARNING: ${{ inputs.override-warning }}
HADOLINT_OVERRIDE_INFO: ${{ inputs.override-info }}
HADOLINT_OVERRIDE_STYLE: ${{ inputs.override-style }}
HADOLINT_IGNORE: ${{ inputs.ignore }} HADOLINT_IGNORE: ${{ inputs.ignore }}
HADOLINT_TRUSTED_REGISTRIES: ${{ inputs.trusted-registries }}
HADOLINT_CONFIG: ${{ inputs.config }}
HADOLINT_RECURSIVE: ${{ inputs.recursive }} HADOLINT_RECURSIVE: ${{ inputs.recursive }}
HADOLINT_OUTPUT: ${{ inputs.output-file }}
branding: branding:
icon: 'layers' icon: 'layers'
color: 'purple' color: 'purple'

View file

@ -19,9 +19,13 @@ if [ -n "$HADOLINT_CONFIG" ]; then
HADOLINT_CONFIG="-c ${HADOLINT_CONFIG}" HADOLINT_CONFIG="-c ${HADOLINT_CONFIG}"
fi fi
for i in $HADOLINT_IGNORE; do OUTPUT=
HADOLINT_IGNORE_CMDLINE="${HADOLINT_IGNORE_CMDLINE} --ignore=${i}" if [ -n "$HADOLINT_OUTPUT" ]; then
done if [ -f "$HADOLINT_OUTPUT" ]; then
HADOLINT_OUTPUT="$TMP_FOLDER/$HADOLINT_OUTPUT"
fi
OUTPUT=" | tee $HADOLINT_OUTPUT"
fi
if [ "$HADOLINT_RECURSIVE" = "true" ]; then if [ "$HADOLINT_RECURSIVE" = "true" ]; then
shopt -s globstar shopt -s globstar
@ -29,8 +33,10 @@ if [ "$HADOLINT_RECURSIVE" = "true" ]; then
filename="${!#}" filename="${!#}"
flags="${@:1:$#-1}" flags="${@:1:$#-1}"
hadolint $HADOLINT_IGNORE_CMDLINE $HADOLINT_CONFIG $flags **/$filename hadolint $HADOLINT_CONFIG $flags **/$filename $OUTPUT
else else
# shellcheck disable=SC2086 # shellcheck disable=SC2086
hadolint $HADOLINT_IGNORE_CMDLINE $HADOLINT_CONFIG "$@" hadolint $HADOLINT_CONFIG "$@" $OUTPUT
fi fi
[ -z "$HADOLINT_OUTPUT" ] || echo "Hadolint output saved to: $HADOLINT_OUTPUT"