-
Notifications
You must be signed in to change notification settings - Fork 0
45 lines (39 loc) · 1.74 KB
/
shellcheck.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
# Workflow definition for ShellCheck linter on shell scripts
name: ShellCheck
# Define the events that will trigger the workflow
"on":
# Trigger the workflow when code is pushed to any branch
push:
branches:
- "*" # Trigger on any push to any branch
paths:
- "**/*.sh" # Only trigger if any .sh file is modified in the push event
# Trigger the workflow when a pull request is made to any branch
pull_request:
branches:
- "*" # Trigger on pull request to any branch
paths:
- "**/*.sh" # Only trigger if .sh files are modified in the pull request
# Allow manual triggering of the workflow from the GitHub UI
workflow_dispatch: {}
# Define the jobs that will run in this workflow
jobs:
# Job definition for running ShellCheck linter
shellcheck:
# Name of the job as it will appear in the GitHub Actions UI
name: Run ShellCheck Linter
# Specify the environment (runner) to run the job on
runs-on: ubuntu-latest # Use the latest version of Ubuntu as the runner
steps:
# Step 1: Checkout the repository code so we can access the shell scripts
- name: Checkout Code
uses: actions/checkout@v3 # Use GitHub's checkout action to pull the latest code from the repository
# Step 2: Run ShellCheck to lint all shell scripts (.sh files) in the repository
- name: Run ShellCheck
uses: ludeeus/action-shellcheck@master # Use the ShellCheck action from the 'ludeeus' GitHub user to run ShellCheck
with:
# Arguments for ShellCheck
args:
"--check-sourced --enable=all" # Run ShellCheck with options:
# --check-sourced: Checks files that are sourced in the script.
# --enable=all: Enables all checks and warnings