Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
terminal

GitHub Action

sh-checker

v0.2.2

sh-checker

terminal

sh-checker

Run shellcheck and/or shfmt on all shell script files and include commentaries, there is a exclude parameter

Installation

Copy and paste the following snippet into your .yml file.

              

- name: sh-checker

uses: luizm/[email protected]

Learn more about this action in luizm/action-sh-checker

Choose a version

sh-checker

A GitHub action that performs static analysis of shell scripts using shellcheck and shfmt.

Screen Shot 2020-04-01 at 12 18 59

Usage

Job example to check all sh files but ignore the directory .terraform and file dir/example.sh

name: example
on:
  - pull_request
jobs:
  sh-checker:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v1
      - name: Run the sh-checker
        uses: luizm/[email protected]
        env:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
          SHELLCHECK_OPTS: -e SC1004 # exclude some shellcheck warnings.
          SHFMT_OPTS: -s # arguments to shfmt.
        with:
          sh_checker_comment: true
          sh_checker_exclude: ".terraform ^dir/example.sh"

Environment Variables

SHELLCHECK_OPTS: Used to specify shellcheck arguments.

SHFMT_OPTS: Used to specify shfmt arguments.

Inputs

sh_checker_exclude: (optional) Directory or file name that doesn't need to be checked.

sh_checker_comment: (optional) If true, it will show the errors as commentaries in the pull requests. Default is false.

sh_checker_shfmt_disable: (optional) If true, it will skip shfmt. Default is false.

sh_checker_shellcheck_disable: (optional) If true, it will skip shellcheck. Default is false.

sh_checker_checkbashisms_enable: (optional) If true, run checkbashisms tool against scripts. Default is false.

Secrets

GITHUB_TOKEN: (optional) The GitHub API token used to post comments to pull requests. Not required if sh_checker_comment is set to false.