feat: add format input and a single-line problem matcher (#40)

Co-authored-by: Joakim Sørensen <ludeeus@gmail.com>
This commit is contained in:
Alexey Alekhin 2021-03-31 21:03:27 +02:00 committed by GitHub
parent 184a772465
commit 94e0aab03c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 45 additions and 5 deletions

18
.github/problem-matcher-gcc.json vendored Normal file
View File

@ -0,0 +1,18 @@
{
"problemMatcher": [
{
"owner": "shellcheck-gcc",
"pattern": [
{
"regexp": "^(.+):(\\d+):(\\d+):\\s(note|warning|error):\\s(.*)\\s\\[(SC\\d+)\\]$",
"file": 1,
"line": 2,
"column": 3,
"severity": 4,
"message": 5,
"code": 6
}
]
}
]
}

View File

@ -1,7 +1,7 @@
{ {
"problemMatcher": [ "problemMatcher": [
{ {
"owner": "shellcheck", "owner": "shellcheck-tty",
"pattern": [ "pattern": [
{ {
"regexp": "^In\\s(.+)\\sline\\s(\\d+):$", "regexp": "^In\\s(.+)\\sline\\s(\\d+):$",

View File

@ -131,3 +131,19 @@ by setting `disable_matcher` to `true`.
with: with:
disable_matcher: true disable_matcher: true
``` ```
## Change output format
Shellcheck can print output in these formats: `checkstyle`, `diff`, `gcc`, `json`, `json1`, `quiet`, `tty`. See some examples [here](https://github.com/koalaman/shellcheck/wiki/Integration#pick-the-output-format-that-makes-your-life-easier).
Only `tty` and `gcc` produce file annotations via problem matcher, default is `gcc`.
- `tty` has multi-line log messages, but all annotations are reported as errors
- `gcc` has single-line log messages, so it's easier to parse with a problem matcher (including correct severity annotation)
```yaml
...
- name: Run ShellCheck
uses: ludeeus/action-shellcheck@master
with:
format: tty
```

View File

@ -26,6 +26,10 @@ inputs:
description: "Set to true to skip using problem-matcher" description: "Set to true to skip using problem-matcher"
required: false required: false
default: "false" default: "false"
format:
description: "Output format (checkstyle, diff, gcc, json, json1, quiet, tty)"
required: false
default: "gcc"
outputs: outputs:
files: files:
description: A list of files with issues description: A list of files with issues
@ -38,12 +42,13 @@ branding:
color: "gray-dark" color: "gray-dark"
runs: runs:
using: "composite" using: "composite"
steps: steps:
- name: Enable problem-matcher - name: Enable problem-matcher
shell: bash shell: bash
run: | run: |
if [[ ${{ inputs.disable_matcher }} != "true" ]]; then problem_matcher_file="${{ github.action_path }}/.github/problem-matcher-${{ inputs.format }}.json"
echo "::add-matcher::${{ github.action_path }}/.github/problem-matcher.json" if [[ ${{ inputs.disable_matcher }} != "true" && -f "$problem_matcher_file" ]]; then
echo "::add-matcher::$problem_matcher_file"
fi fi
- name: Download shellcheck - name: Download shellcheck
@ -78,6 +83,7 @@ runs:
if [[ -n "${{ inputs.severity }}" ]]; then if [[ -n "${{ inputs.severity }}" ]]; then
options+=("-S ${{ inputs.severity }}") options+=("-S ${{ inputs.severity }}")
fi fi
options+=("--format=${{ inputs.format }}")
echo "::set-output name=options::${options[@]}" echo "::set-output name=options::${options[@]}"
- name: Gather excluded paths - name: Gather excluded paths
@ -190,7 +196,7 @@ runs:
"$file" || statuscode=$?; "$file" || statuscode=$?;
done done
fi fi
echo "::set-output name=statuscode::$statuscode" echo "::set-output name=statuscode::$statuscode"
- name: Print information - name: Print information