-
Notifications
You must be signed in to change notification settings - Fork 10
153 lines (138 loc) · 5.54 KB
/
linter.yml
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
name: Linting
# Trigger each time HEAD branch is updated in a pull request
# see https://github.com/orgs/community/discussions/26366
on:
pull_request:
types: [synchronize]
jobs:
changedfiles:
name: Get changed files in PR
runs-on: ubuntu-latest
outputs:
changedFiles: ${{ steps.changes.outputs.files}}
steps:
- name: Checkout repo
uses: actions/checkout@v4
- name: Get changed files
id: changes
run: |
echo "files=$(git diff --name-only --diff-filter=ACMRT ${{ github.event.pull_request.base.sha }} ${{ github.sha }} | grep '\.rb$' || test $? = 1;)" >> $GITHUB_OUTPUT
# (!!!) https://github.com/actions/checkout/issues/520#issuecomment-1167205721
rubocop:
name: RuboCop
runs-on: ubuntu-latest
needs: changedfiles
if: ${{needs.changedfiles.outputs.changedFiles}}
steps:
- name: Echo changed files
run: echo ${{needs.changedfiles.outputs.changedFiles}}
# - name: Determine target branch
# run: |
# target_branch=${{ github.base_ref || 'mampf-next' }}
# echo "Target branch is: $target_branch"
# echo "TARGET_BRANCH=$target_branch" >> $GITHUB_ENV
# # for the " + 1", see:
# # https://github.com/actions/checkout/issues/552#issuecomment-1167086216
# - name: Calculate fetch depth
# run: |
# depth=$(( ${{ github.pull_request.commits }} + 1 ))
# echo "Fetch depth is: $depth"
# echo "PR_FETCH_DEPTH=$depth" >> $GITHUB_ENV
# - name: 'Checkout PR branch and all PR commits'
# uses: actions/checkout@v3
# with:
# ref: ${{ github.pull_request.head.ref }}
# fetch-depth: ${{ env.PR_FETCH_DEPTH }}
# - name: Fetch target branch with enough history for a common merge-base commit
# run: |
# git fetch origin ${{ github.pull_request.base.ref }}
# - name: Set up Ruby 3
# uses: ruby/setup-ruby@v1
# with:
# ruby-version: 3.1.4
# bundler-cache: true
# If this action is not triggered from a PR, we use 'mampf-next' as default
# target branch to compare against. This might not cover all use cases.
# But in the end, one has to open a PR anyways and then the correct target
# branch is identified.
# TODO: rename to 'dev' when 'mampf-next' branch is renamed.
# - name: Fetch target branch
# run: |
# targetBranch=${{ github.base_ref || 'mampf-next' }}
# echo "Target branch is: $targetBranch"
# git fetch origin $targetBranch:$targetBranch --depth=1
# adapted from https://github.com/actions/checkout/issues/520#issuecomment-1167205721
# and: https://robertfaldo.medium.com/commands-to-run-rubocop-and-specs-you-changed-in-your-branch-e6d2f2e4110b
# --diff-filter=d excludes deleted files
# "|| test $? = 1;" is used to ignore the exit code of grep when no files
# are found matching the pattern
# For the "three dots" ... syntax, see
# https://community.atlassian.com/t5/Bitbucket-questions/Git-diff-show-different-files-than-PR-Pull-Request/qaq-p/2331786
# - name: Get changed ruby files (git diff)
# run: |
# changedFiles=$(git diff --name-only --diff-filter=d -r $targetBranch...HEAD | grep '\.rb$' || test $? = 1;)
# printf "Changed ruby files: \n$changedFiles"
# echo "CHANGED_FILES=\"$changedFiles\"" >> $GITHUB_ENV
# See RuboCop command line flags here:
# https://docs.rubocop.org/rubocop/usage/basic_usage.html#command-line-flags
# - name: Run RuboCop
# if: env.CHANGED_FILES != ''
# run: $CHANGED_FILES | xargs bundle exec rubocop
# eslint:
# runs-on: ubuntu-latest
# name: A job to check eslint linter errors
# steps:
# - uses: actions/checkout@v2
# - name: Linter count
# id: hello
# uses: henrixapp/[email protected]
# with:
# name: EsLint
# command: npx eslint
# total_regexp: \d+ problems
# errors_regexp: \d+ errors
# warnings_regexp: \d+ warnings
# compare_branch: mampf-next
# mode: changed
# include: .js
# coffee:
# runs-on: ubuntu-latest
# name: A job to check coffee linter errors
# steps:
# - uses: actions/checkout@v2
# - name: Linter count
# id: hello
# uses: henrixapp/[email protected]
# with:
# name: Coffee
# command: npx coffeelint
# total_regexp: \d+ errors
# errors_regexp: \d+ errors
# warnings_regexp: \d+ warnings
# compare_branch: mampf-next
# mode: changed
# include: .coffee
# erblint:
# runs-on: ubuntu-latest
# name: A job to check erblint linter errors
# steps:
# - uses: actions/checkout@v2
# - name: Set up Ruby 2.7
# uses: ruby/setup-ruby@v1
# with:
# ruby-version: 2.7
# - name: Install gems # usual step to install the gems.
# run: |
# bin/bundle config path vendor/bundle
# bin/bundle config set without 'default doc job cable storage ujs test db'
# bin/bundle install --jobs 4 --retry 3
# - name: Linter count
# id: hello
# uses: henrixapp/[email protected]
# with:
# name: Erblint
# command: bin/bundle exec erblint .
# total_regexp: \d+ error(s)
# errors_regexp: \d+ error(s)
# warnings_regexp: \d+ error(s)
# compare_branch: mampf-next