2020-12-06 09:46:26 +00:00
# Hadolint Action
2019-10-02 21:50:00 +01:00
2020-12-06 09:46:26 +00:00
> GitHub Action that runs [Hadolint](https://github.com/hadolint/hadolint) Dockerfile linting tool.
2019-10-02 21:50:00 +01:00
[![GitHub Action ](https://img.shields.io/badge/GitHub-Action-blue?style=for-the-badge )](https://github.com/features/actions)
[![License ](https://img.shields.io/badge/License-MIT-yellow.svg?style=for-the-badge )](LICENSE)
[![Commitizen friendly ](https://img.shields.io/badge/commitizen-friendly-brightgreen.svg?style=for-the-badge )](http://commitizen.github.io/cz-cli/)
[![semantic-release ](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg?style=for-the-badge )](https://github.com/semantic-release/semantic-release?style=for-the-badge)
2023-01-17 15:05:26 +01:00
[![GitHub Workflow Status ](https://img.shields.io/github/actions/workflow/status/hadolint/hadolint-action/ci.yml?branch=master&style=for-the-badge )](https://github.com/hadolint/hadolint-action/action)
2019-10-02 21:50:00 +01:00
## Usage
2020-12-06 09:46:26 +00:00
Add the following step to your workflow configuration:
2019-10-02 21:50:00 +01:00
```yml
steps:
2023-01-14 14:59:41 -06:00
- uses: actions/checkout@v3
- uses: hadolint/hadolint-action@v3 .0.0
2021-05-08 13:08:16 +02:00
with:
dockerfile: Dockerfile
2019-10-02 21:50:00 +01:00
```
## Inputs
2022-11-15 20:14:37 +01:00
| Name | Description | Default |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------------|
| `dockerfile` | The path to the Dockerfile to be tested | `./Dockerfile` |
| `recursive` | Search for specified dockerfile </ br > recursively, from the project root | `false` |
| `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 | |
| `results-to-console` | The flag to print Hadolint results to console | `false` |
| `no-color` | Don't create colored output (`true` /`false` ) | |
| `no-fail` | Never fail the action (`true` /`false` ) | |
| `verbose` | Output more information (`true` /`false` ) | |
| `format` | The output format. One of [`tty` \ | `json` \| </ br > `checkstyle` \| `codeclimate` \| </ br > `gitlab_codeclimate` \| `codacy` \| `sarif` ] | `tty` |
| `failure-threshold` | Rule severity threshold for pipeline </ br > failure. One of [`error` \ | `warning` \| </ br > `info` \| `style` \| `ignore` ] | `info` |
| `override-error` | Comma separated list of rules to treat with `error` severity | |
| `override-warning` | Comma separated list of rules to treat with `warning` severity | |
| `override-info` | Comma separated list of rules to treat with `info` severity | |
| `override-style` | Comma separated list of rules to treat with `style` severity | |
| `ignore` | Comma separated list of Hadolint rules to ignore. | < none > |
| `trusted-registries` | Comma separated list of urls of trusted registries | |
2020-12-06 09:46:26 +00:00
2022-03-31 14:56:53 +02:00
## Output
The Action will store results in an environment variable that can be used in other steps in a workflow.
Example to create a comment in a PR:
```
- name: Update Pull Request
uses: actions/github-script@v6
if: github.event_name == 'pull_request'
with:
script: |
const output = `
2022-03-31 15:31:54 +02:00
#### Hadolint: \`${{ steps.hadolint.outcome }}\`
2022-03-31 14:56:53 +02:00
\`\`\`
${process.env.HADOLINT_RESULTS}
\`\`\`
`;
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: output
})
```
2020-12-06 09:46:26 +00:00
## Hadolint Configuration
To configure Hadolint (for example ignore rules), you can create an `.hadolint.yaml` file in the root of your repository. Please check the Hadolint [documentation ](https://github.com/hadolint/hadolint#configure ).
2019-10-02 21:50:00 +01:00
## 🤝 Contributing
Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated** .
1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature` )
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'` )
4. Push to the Branch (`git push origin feature/AmazingFeature` )
5. Open a Pull Request
2022-03-22 11:44:03 +01:00
2020-12-06 09:46:26 +00:00
## 💛 Support the project
2021-05-17 19:06:18 +01:00
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.
2020-12-06 09:46:26 +00:00
The sinplest form of support is to give a ⭐️ to this repo.
2021-05-17 19:06:18 +01:00
This project was originally created by [Bruno Paz ](https://github.com/sponsors/brpaz ) and incorporated into the Hadolint organization. If you appreciate the work done on this action, Bruno would be happy with your [sponsorship ](https://github.com/sponsors/brpaz ).
2020-12-06 09:46:26 +00:00
2019-10-02 21:50:00 +01:00
## Author
👤 **Bruno Paz**
* Website: [https://github.com/brpaz ](https://github.com/brpaz )
* Github: [@brpaz ](https://github.com/brpaz )
## 📝 License
2021-05-17 19:06:18 +01:00
[MIT ](LICENSE )