Dockerfile linter, validate inline bash, written in Haskell https://github.com/hadolint/hadolint
Find a file
2023-01-17 17:36:09 +01:00
.github Merge branch 'master' into master 2023-01-17 17:36:09 +01:00
testdata hadolint: version bump to 2.4.0 2021-05-08 14:54:03 +02:00
.editorconfig feat: first commit 2019-10-02 21:50:00 +01:00
.gitignore Some shellcheck fixes and new input (#1) 2022-11-15 20:14:37 +01:00
.hadolint.yml feat: first commit 2019-10-02 21:50:00 +01:00
.pre-commit-config.yaml feat: first commit 2019-10-02 21:50:00 +01:00
.releaserc fix: add missing releaserc file 2019-10-02 22:03:48 +01:00
.yamllint feat: first commit 2019-10-02 21:50:00 +01:00
action.yml Merge branch 'master' into master 2023-01-17 17:36:09 +01:00
Dockerfile upgrade hadolint to 2.12 2022-11-11 05:52:50 -05:00
hadolint.sh Some shellcheck fixes and new input (#1) 2022-11-15 20:14:37 +01:00
LICENSE feat: first commit 2019-10-02 21:50:00 +01:00
Makefile chore: fix typos 2022-03-31 09:56:25 +02:00
problem-matcher.json fix: Remove problem matcher after run (#16) 2020-12-06 19:10:45 +00:00
README.md Some shellcheck fixes and new input (#1) 2022-11-15 20:14:37 +01:00
structure-tests.yaml feat: first commit 2019-10-02 21:50:00 +01:00

Hadolint Action

GitHub Action that runs Hadolint Dockerfile linting tool.

GitHub Action License Commitizen friendly semantic-release GitHub Workflow Status

Usage

Add the following step to your workflow configuration:

steps:
  - uses: actions/checkout@v2 
  - uses: hadolint/hadolint-action@v2.1.0
    with:
      dockerfile: Dockerfile

Inputs

Name Description Default
dockerfile The path to the Dockerfile to be tested ./Dockerfile
recursive Search for specified dockerfile
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
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 |
checkstyle | codeclimate |
gitlab_codeclimate | codacy | sarif]
failure-threshold Rule severity threshold for pipeline
failure. One of [error \
warning |
info | style | ignore]
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.
trusted-registries Comma separated list of urls of trusted registries

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 = `
      #### 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

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.

🤝 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

💛 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.

The sinplest form of support is to give a to this repo.

This project was originally created by Bruno Paz and incorporated into the Hadolint organization. If you appreciate the work done on this action, Bruno would be happy with your sponsorship.

Author

👤 Bruno Paz

📝 License

MIT