extend linter to enforce exception tracking is turned on (#5909)

Status Nim style mandates `{.push raises: []}.` at start of modules.
Add a CI task to ensure exceptions keep getting properly tracked.

- https://status-im.github.io/nim-style-guide/errors.exceptions.html
- https://github.com/status-im/nim-eth/pull/614#discussion_r1220906149
This commit is contained in:
Etan Kissling 2024-02-19 11:02:36 +01:00 committed by GitHub
parent 92197ce690
commit 698a802168
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 23 additions and 4 deletions

View File

@ -241,21 +241,40 @@ jobs:
excluded_extensions="ans|cfg|json|json\\.template|md|png|service|ssz|txt" excluded_extensions="ans|cfg|json|json\\.template|md|png|service|ssz|txt"
current_year=$(date +"%Y") current_year=$(date +"%Y")
outdated_files=() problematic_files=()
while read -r file; do while read -r file; do
if ! grep -qE 'Copyright \(c\) .*'$current_year' Status Research & Development GmbH' "$file"; then if ! grep -qE 'Copyright \(c\) .*'$current_year' Status Research & Development GmbH' "$file"; then
outdated_files+=("$file") problematic_files+=("$file")
fi fi
done < <(git diff --name-only --diff-filter=AM --ignore-submodules HEAD^ HEAD | grep -vE '(\.('$excluded_extensions')|'$excluded_files')$' || true) done < <(git diff --name-only --diff-filter=AM --ignore-submodules HEAD^ HEAD | grep -vE '(\.('$excluded_extensions')|'$excluded_files')$' || true)
if (( ${#outdated_files[@]} )); then if (( ${#problematic_files[@]} )); then
echo "The following files do not have an up-to-date copyright year:" echo "The following files do not have an up-to-date copyright year:"
for file in "${outdated_files[@]}"; do for file in "${problematic_files[@]}"; do
echo "- $file" echo "- $file"
done done
exit 2 exit 2
fi fi
- name: Check exception tracking
if: ${{ !cancelled() }} && github.event_name == 'pull_request'
run: |
problematic_files=()
while read -r file; do
if ! grep -qE '^{\.push raises: \[\]\.}' "$file"; then
problematic_files+=("$file")
fi
done < <(git diff --name-only --diff-filter=AM --ignore-submodules HEAD^ HEAD | grep -E '\.nim$' || true)
if (( ${#problematic_files[@]} )); then
echo "The following files do not have '{.push raises: []}':"
for file in "${problematic_files[@]}"; do
echo "- $file"
done
echo "See https://status-im.github.io/nim-style-guide/errors.exceptions.html"
exit 2
fi
- name: Check submodules - name: Check submodules
if: ${{ !cancelled() }} && github.event_name == 'pull_request' if: ${{ !cancelled() }} && github.event_name == 'pull_request'
run: | run: |