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:
commit
070f68df71
5 changed files with 112 additions and 32 deletions
13
.github/workflows/ci.yml
vendored
13
.github/workflows/ci.yml
vendored
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
42
README.md
42
README.md
|
@ -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
|
||||||
|
|
||||||
|
|
71
action.yml
71
action.yml
|
@ -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'
|
||||||
|
|
16
hadolint.sh
16
hadolint.sh
|
@ -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"
|
||||||
|
|
Loading…
Add table
Reference in a new issue