mirror of
https://github.com/hadolint/hadolint-action.git
synced 2026-05-15 14:45:53 +00:00
Compare commits
71 commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2332a7b74a | ||
|
|
2bfd2b95f8 | ||
|
|
0931ae0972 | ||
|
|
3fc49fb50d | ||
|
|
45eb072a0b | ||
|
|
97f3e4f6be | ||
|
|
3e9a095cc7 | ||
|
|
3285327e7a | ||
|
|
8bde06f9ce | ||
|
|
24598f413e | ||
|
|
cc71e1bfd1 | ||
|
|
2f0331e821 | ||
|
|
715c307046 | ||
|
|
d292784f8f | ||
|
|
5d0317e9d0 | ||
|
|
7857e0b9ce | ||
|
|
218bc411d7 | ||
|
|
726b0bb298 | ||
|
|
a17195f03e | ||
|
|
88c79a349b | ||
|
|
a4d0f06c93 | ||
|
|
c8298ca3ec | ||
|
|
8b07a99429 | ||
|
|
87a23faa1f | ||
|
|
79c12b5608 | ||
|
|
54c9adbab1 | ||
|
|
0ef98d9a5c | ||
|
|
1a139ce6cc | ||
|
|
e88bddc55d | ||
|
|
676012c475 | ||
|
|
77e79bb879 | ||
|
|
4b5806eb9c | ||
|
|
e977686583 | ||
|
|
67d715bb13 | ||
|
|
48c4120377 | ||
|
|
e81a8de9db | ||
|
|
68a2276a3c | ||
|
|
eeab5ede16 | ||
|
|
169ddcf265 | ||
|
|
d51839a6b5 | ||
|
|
f988afea3d | ||
|
|
55991004e8 | ||
|
|
d73282b64c | ||
|
|
2faf5c6ef4 | ||
|
|
724e05f46b | ||
|
|
a78be8d386 | ||
|
|
652bc66203 | ||
|
|
1dd44fc493 | ||
|
|
5fc1b0e2fb | ||
|
|
a8bbf351c0 | ||
|
|
e3462c378d | ||
|
|
0c7fcaa67b | ||
|
|
8ea032569b | ||
|
|
262f403978 | ||
|
|
1878581f63 | ||
|
|
bc289f2eaa | ||
|
|
83b3de1e17 | ||
|
|
289302ad8f | ||
|
|
89e60e4868 | ||
|
|
8a428b4815 | ||
|
|
0a6d062e78 | ||
|
|
0b08ca228d | ||
|
|
9a555bc2d4 | ||
|
|
e8cde77aa0 | ||
|
|
bc86787e19 | ||
|
|
d2b4ab26ff | ||
|
|
2bcb99c6e2 | ||
|
|
63666e594d | ||
|
|
96339c1113 | ||
|
|
37f399667b | ||
|
|
aa70df94a2 |
6 changed files with 153 additions and 69 deletions
82
.github/workflows/ci.yml
vendored
82
.github/workflows/ci.yml
vendored
|
|
@ -3,27 +3,49 @@ on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
|
|
||||||
pull_request:
|
pull_request:
|
||||||
|
|
||||||
env:
|
env:
|
||||||
TEST_IMAGE_NAME: hadolint-action:${{github.sha}}
|
TEST_IMAGE_NAME: hadolint-action:${{github.sha}}
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
issues: write # Used by Release step to update "The automated release is failing" issue
|
||||||
|
pull-requests: write # Used by ShellCheck Action to add comments on PR
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
lint:
|
lint:
|
||||||
name: Lint
|
name: Lint
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-24.04
|
||||||
container: pipelinecomponents/hadolint:0.10.1
|
container: pipelinecomponents/hadolint:0.27.2
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: Run hadolint
|
- name: Run hadolint
|
||||||
run: hadolint Dockerfile
|
run: hadolint Dockerfile
|
||||||
|
|
||||||
|
shellcheck:
|
||||||
|
name: ShellCheck
|
||||||
|
runs-on: ubuntu-24.04
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
|
- name: Run ShellCheck
|
||||||
|
uses: reviewdog/action-shellcheck@v1.31.0
|
||||||
|
with:
|
||||||
|
reporter: github-pr-review
|
||||||
|
fail_on_error: true
|
||||||
|
|
||||||
build-test:
|
build-test:
|
||||||
name: Build and Test
|
name: Build and Test
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-24.04
|
||||||
needs: ["lint"]
|
needs:
|
||||||
|
- lint
|
||||||
|
- shellcheck
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: Build Docker image
|
- name: Build Docker image
|
||||||
run: docker build -t $TEST_IMAGE_NAME .
|
run: docker build -t $TEST_IMAGE_NAME .
|
||||||
|
|
||||||
|
|
@ -34,10 +56,11 @@ jobs:
|
||||||
|
|
||||||
integration-tests:
|
integration-tests:
|
||||||
name: Integration Tests
|
name: Integration Tests
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-24.04
|
||||||
needs: build-test
|
needs:
|
||||||
|
- build-test
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: Run integration test 1
|
- name: Run integration test 1
|
||||||
uses: ./
|
uses: ./
|
||||||
|
|
@ -69,29 +92,48 @@ jobs:
|
||||||
failure-threshold: error
|
failure-threshold: error
|
||||||
format: json
|
format: json
|
||||||
|
|
||||||
- name: Run integration test 5 - output format
|
- name: Run integration test 5 - config file
|
||||||
# This step will never fail, but will print out rule violations.
|
# This step will never fail, but will print out rule violations
|
||||||
|
# because in config is set the error failure threshold.
|
||||||
|
id: hadolint5
|
||||||
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
|
- name: Run integration test 6 - verify results output parameter
|
||||||
# This step will never fail, but will print out rule violations.
|
# This step will never fail, but will print out the results from step5
|
||||||
|
env:
|
||||||
|
results: ${{ steps.hadolint5.outputs.results }}
|
||||||
|
run: echo "$results"
|
||||||
|
|
||||||
|
- name: Run integration test 7 - set recursive
|
||||||
|
# This step will never fail, but will print out rule violations
|
||||||
|
# for all the Dockerfiles in repository.
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
dockerfile: testdata/warning.Dockerfile
|
dockerfile: "*Dockerfile"
|
||||||
format: sarif
|
failure-threshold: error
|
||||||
output-file: /report.sarif
|
recursive: true
|
||||||
|
|
||||||
|
#- name: Run integration test 8 - 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
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-24.04
|
||||||
needs: integration-tests
|
needs:
|
||||||
|
- integration-tests
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v5
|
||||||
- uses: cycjimmy/semantic-release-action@v2
|
|
||||||
|
- uses: cycjimmy/semantic-release-action@v5
|
||||||
with:
|
with:
|
||||||
extra_plugins: |
|
extra_plugins: |
|
||||||
@semantic-release/git
|
@semantic-release/git
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
FROM hadolint/hadolint:v2.9.2-debian
|
FROM ghcr.io/hadolint/hadolint:v2.14.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
|
||||||
|
|
|
||||||
2
Makefile
2
Makefile
|
|
@ -1,7 +1,7 @@
|
||||||
|
|
||||||
IMAGE_NAME:=hadolint-action
|
IMAGE_NAME:=hadolint-action
|
||||||
|
|
||||||
lint-dockerfile: ## Runs hadoint against application dockerfile
|
lint-dockerfile: ## Runs hadolint against application dockerfile
|
||||||
@docker run --rm -v "$(PWD):/data" -w "/data" hadolint/hadolint hadolint Dockerfile
|
@docker run --rm -v "$(PWD):/data" -w "/data" hadolint/hadolint hadolint Dockerfile
|
||||||
|
|
||||||
lint-yaml: ## Lints yaml configurations
|
lint-yaml: ## Lints yaml configurations
|
||||||
|
|
|
||||||
77
README.md
77
README.md
|
|
@ -6,8 +6,8 @@
|
||||||
[](LICENSE)
|
[](LICENSE)
|
||||||
[](http://commitizen.github.io/cz-cli/)
|
[](http://commitizen.github.io/cz-cli/)
|
||||||
[](https://github.com/semantic-release/semantic-release?style=for-the-badge)
|
[](https://github.com/semantic-release/semantic-release?style=for-the-badge)
|
||||||
|
[](https://github.com/hadolint/hadolint-action/action)
|
||||||
|
|
||||||
[](https://github.com/hadolint/hadolint-action/action)
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
|
|
@ -15,8 +15,8 @@ Add the following step to your workflow configuration:
|
||||||
|
|
||||||
```yml
|
```yml
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v3
|
||||||
- uses: hadolint/hadolint-action@v1.6.0
|
- uses: hadolint/hadolint-action@v3.1.0
|
||||||
with:
|
with:
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
```
|
```
|
||||||
|
|
@ -24,33 +24,49 @@ 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 </br> recursively, from the project root | `false` |
|
||||||
| | recursively, from the project root | |
|
| `config` | Custom path to a Hadolint config file | `./.hadolint.yaml` |
|
||||||
| config | Custom path to a Hadolint config file | ./.hadolint.yaml |
|
| `output-file` | A sub-path where to save the </br> output as a file to | `/dev/stdout` |
|
||||||
| output-file | A sub-path where to save the | |
|
| `no-color` | Don't create colored output (`true`/`false`) | `false` |
|
||||||
| | output as a file to | |
|
| `no-fail` | Never fail the action (`true`/`false`) | `false` |
|
||||||
| no-color | Don't create colored output | |
|
| `verbose` | Output more information (`true`/`false`) | `false` |
|
||||||
| no-fail | Never fail the action | |
|
| `format` | The output format. One of [`tty` \| `json` \| </br> `checkstyle` \| `codeclimate` \| </br> `gitlab_codeclimate` \| `codacy` \| `sarif`] | `tty` |
|
||||||
| verbose | Output more information | |
|
| `failure-threshold` | Rule severity threshold for pipeline </br> failure. One of [`error` \| `warning` \| </br> `info` \| `style` \| `ignore`] | `info` |
|
||||||
| format | The output format. One of [tty \| json \| | tty |
|
| `override-error` | Comma separated list of rules to treat with `error` severity | |
|
||||||
| | checkstyle \| codeclimate \| | |
|
| `override-warning` | Comma separated list of rules to treat with `warning` severity | |
|
||||||
| | gitlab_codeclimate \| codacy \| sarif] | |
|
| `override-info` | Comma separated list of rules to treat with `info` severity | |
|
||||||
| failure-threshold | Rule severity threshold for pipeline | info |
|
| `override-style` | Comma separated list of rules to treat with `style` severity | |
|
||||||
| | failure. One of [error \| warning \| | |
|
| `ignore` | Comma separated list of Hadolint rules to ignore. | <none> |
|
||||||
| | info \| style \| ignore] | |
|
| `trusted-registries` | Comma separated list of urls of trusted registries | |
|
||||||
| override-error | List of rules to treat with 'error' | |
|
|
||||||
| | severity | |
|
## Output
|
||||||
| override-warning | List of rules to treat with 'warning' | |
|
|
||||||
| | severity | |
|
The Action will store results in an environment variable that can be used in other steps in a workflow.
|
||||||
| override-info | List of rules to treat with 'info' | |
|
|
||||||
| | severity | |
|
Example to create a comment in a PR:
|
||||||
| override-style | List of rules to treat with 'style' | |
|
|
||||||
| | severity | |
|
```
|
||||||
| ignore | Space separated list of Hadolint rules to | <none> |
|
- name: Update Pull Request
|
||||||
| | ignore. | |
|
uses: actions/github-script@v6
|
||||||
| trusted-resgitries | List of urls of trusted registries | |
|
if: github.event_name == 'pull_request'
|
||||||
|
with:
|
||||||
|
script: |
|
||||||
|
const output = `
|
||||||
|
#### Hadolint: \`${{ steps.hadolint.outcome }}\`
|
||||||
|
\`\`\`
|
||||||
|
${process.env.HADOLINT_RESULTS}
|
||||||
|
\`\`\`
|
||||||
|
`;
|
||||||
|
|
||||||
|
github.rest.issues.createComment({
|
||||||
|
issue_number: context.issue.number,
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
body: output
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
## Hadolint Configuration
|
## Hadolint Configuration
|
||||||
|
|
||||||
|
|
@ -65,6 +81,7 @@ Contributions are what make the open source community such an amazing place to b
|
||||||
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
|
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
|
||||||
4. Push to the Branch (`git push origin feature/AmazingFeature`)
|
4. Push to the Branch (`git push origin feature/AmazingFeature`)
|
||||||
5. Open a Pull Request
|
5. Open a Pull Request
|
||||||
|
|
||||||
## 💛 Support the project
|
## 💛 Support the project
|
||||||
|
|
||||||
If this project was useful to you in some form, We would be glad to have your support. It will help keeping the project alive.
|
If this project was useful to you in some form, We would be glad to have your support. It will help keeping the project alive.
|
||||||
|
|
|
||||||
|
|
@ -18,7 +18,7 @@ inputs:
|
||||||
output-file:
|
output-file:
|
||||||
required: false
|
required: false
|
||||||
description: 'The path where to save the linting results to'
|
description: 'The path where to save the linting results to'
|
||||||
default:
|
default: "/dev/stdout"
|
||||||
|
|
||||||
# standart hadolint options:
|
# standart hadolint options:
|
||||||
no-color:
|
no-color:
|
||||||
|
|
|
||||||
49
hadolint.sh
49
hadolint.sh
|
|
@ -1,13 +1,16 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# The problem-matcher definition must be present in the repository
|
# The problem-matcher definition must be present in the repository
|
||||||
# checkout (outside the Docker container running hadolint). We copy
|
# checkout (outside the Docker container running hadolint). We copy
|
||||||
# problem-matcher.json to the home folder.
|
# problem-matcher.json to the home folder.
|
||||||
cp /problem-matcher.json "$HOME/"
|
|
||||||
|
|
||||||
|
PROBLEM_MATCHER_FILE="/problem-matcher.json"
|
||||||
|
if [ -f "$PROBLEM_MATCHER_FILE" ]; then
|
||||||
|
cp "$PROBLEM_MATCHER_FILE" "$HOME/"
|
||||||
|
fi
|
||||||
# After the run has finished we remove the problem-matcher.json from
|
# After the run has finished we remove the problem-matcher.json from
|
||||||
# the repository so we don't leave the checkout dirty. We also remove
|
# the repository so we don't leave the checkout dirty. We also remove
|
||||||
# the matcher so it won't take effect in later steps.
|
# the matcher so it won't take effect in later steps.
|
||||||
|
# shellcheck disable=SC2317
|
||||||
cleanup() {
|
cleanup() {
|
||||||
echo "::remove-matcher owner=brpaz/hadolint-action::"
|
echo "::remove-matcher owner=brpaz/hadolint-action::"
|
||||||
}
|
}
|
||||||
|
|
@ -19,24 +22,46 @@ if [ -n "$HADOLINT_CONFIG" ]; then
|
||||||
HADOLINT_CONFIG="-c ${HADOLINT_CONFIG}"
|
HADOLINT_CONFIG="-c ${HADOLINT_CONFIG}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
OUTPUT=
|
if [ -z "$HADOLINT_TRUSTED_REGISTRIES" ]; then
|
||||||
if [ -n "$HADOLINT_OUTPUT" ]; then
|
unset HADOLINT_TRUSTED_REGISTRIES
|
||||||
if [ -f "$HADOLINT_OUTPUT" ]; then
|
|
||||||
HADOLINT_OUTPUT="$TMP_FOLDER/$HADOLINT_OUTPUT"
|
|
||||||
fi
|
|
||||||
OUTPUT=" | tee $HADOLINT_OUTPUT"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
COMMAND="hadolint $HADOLINT_CONFIG"
|
||||||
|
|
||||||
if [ "$HADOLINT_RECURSIVE" = "true" ]; then
|
if [ "$HADOLINT_RECURSIVE" = "true" ]; then
|
||||||
shopt -s globstar
|
shopt -s globstar
|
||||||
|
|
||||||
filename="${!#}"
|
filename="${!#}"
|
||||||
flags="${@:1:$#-1}"
|
flags="${*:1:$#-1}"
|
||||||
|
|
||||||
hadolint $HADOLINT_CONFIG $flags **/$filename $OUTPUT
|
RESULTS=$(eval "$COMMAND $flags" -- **/"$filename")
|
||||||
else
|
else
|
||||||
# shellcheck disable=SC2086
|
flags=$*
|
||||||
hadolint $HADOLINT_CONFIG "$@" $OUTPUT
|
RESULTS=$(eval "$COMMAND" "$flags")
|
||||||
|
fi
|
||||||
|
FAILED=$?
|
||||||
|
|
||||||
|
if [ -n "$HADOLINT_OUTPUT" ]; then
|
||||||
|
if [ -f "$HADOLINT_OUTPUT" ]; then
|
||||||
|
HADOLINT_OUTPUT="$TMP_FOLDER/$HADOLINT_OUTPUT"
|
||||||
|
fi
|
||||||
|
echo "$RESULTS" >"$HADOLINT_OUTPUT"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
RESULTS="${RESULTS//$'\\n'/''}"
|
||||||
|
|
||||||
|
{
|
||||||
|
echo "results<<EOF"
|
||||||
|
echo "$RESULTS"
|
||||||
|
echo "EOF"
|
||||||
|
} >>"$GITHUB_OUTPUT"
|
||||||
|
|
||||||
|
{
|
||||||
|
echo "HADOLINT_RESULTS<<EOF"
|
||||||
|
echo "$RESULTS"
|
||||||
|
echo "EOF"
|
||||||
|
} >>"$GITHUB_ENV"
|
||||||
|
|
||||||
[ -z "$HADOLINT_OUTPUT" ] || echo "Hadolint output saved to: $HADOLINT_OUTPUT"
|
[ -z "$HADOLINT_OUTPUT" ] || echo "Hadolint output saved to: $HADOLINT_OUTPUT"
|
||||||
|
|
||||||
|
exit $FAILED
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue