hadolint/README.md

102 lines
6 KiB
Markdown
Raw Permalink Normal View History

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)
2021-04-14 19:25:02 +01:00
[![GitHub Workflow Status](https://img.shields.io/github/workflow/status/hadolint/hadolint-action/CI?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:
- uses: actions/checkout@v2
- uses: hadolint/hadolint-action@v2.1.0
with:
dockerfile: Dockerfile
2019-10-02 21:50:00 +01:00
```
## Inputs
2022-03-25 13:07:15 +08: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 | |
2022-03-25 13:09:48 +08:00
| `no-color` | Don't create colored output (`true`/`false`) | |
| `no-fail` | Never fail the action (`true`/`false`) | |
| `verbose` | Output more information (`true`/`false`) | |
2022-03-25 13:07:15 +08:00
| `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` |
2022-03-25 13:09:48 +08:00
| `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 | |
2022-03-25 13:07:15 +08:00
| `ignore` | Comma separated list of Hadolint rules to ignore. | <none> |
2022-03-25 13:09:48 +08:00
| `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
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.
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
[MIT](LICENSE)