The reusable linting workflow tries to be as strict as possible. It is up to the repositories using it to define reasonable exceptions. Here are some ways described how this can be done.
Simply add a .flake8 config file to the root of your repository
See example here or visit official documentation.
flake8 --config=.flake8 --count --statistics --show-source .
Nothing needed, it uses config file of flake8.
See https://black.readthedocs.io/en/stable/guides/using_black_with_other_tools.html
black --check --diff --line-length 79 .
There are two different configs - one which must be followed and one which is more strict
but allowed to fail. Both are contained in this repository and used for the reusable linting
workflow. If that fits, all is good. If you need more specific adjustments, name them the
same way and place them in your directory root to adjust.
pylint .
pylint --rc-file=.pylintrc_allowed_to_fail .
ruff contains rules inspired by black, flake8, pylint and more and is extremely fast in linting and formatting Python code.
The linting config is aligned to the one from GRASS GIS.
Per default, a lot of linting rules are active. If needed, add a ruff.toml
config file to the root of your repository
and add rules which to ignore.
See example here or visit official documentation.
ruff check --config ruff-merged.toml --output-format=full . --preview --unsafe-fixes
Merge repository-specific ruff.toml
and the one from this repo:
pip install toml-union
wget --continue https://raw.githubusercontent.com/mundialis/github-workflows/refs/heads/main/linting-config-examples/ruff.toml -O /tmp/ruff.toml -q
toml-union ruff.toml /tmp/ruff.toml -o ruff-merged.toml
For initial setup in your repository, the list of rules to be ignored can be generated:
ruff check --config ruff-merged.toml . --preview --unsafe-fixes --output-format json | jq .[].code | sort -u
(Need to add ,
at the end of each line).
Superlinter is a wrapper for many different linters. Each has a different way to be configured. Example config files exist for markdownlint and shellcheck.
Some allow exceptions to be defined directly on top of a file or above the line.
- See example config file
.markdownlint.yaml
- Disable checks inside .md files on top of file:
<!-- markdownlint-configure-file {"MD013": { "line_length": 150 }} -->
Or more sophisticated
<!-- markdownlint-configure-file
{
"MD013": { "line_length": 150 },
"MD024": { "siblings_only": true }, # no-duplicate-heading, in CHANGELOG it is ok
"MD034": false # no-bare-urls
}
-->
- See example config file
.shellcheckrc
- Disable checks inside .sh files, direclty above line:
# shellcheck disable=SC2317
Hadolint lints Dockerfiles.
- Disable checks inside Dockerfiles, directly above line:
# hadolint ignore=DL3018
When not using pre-commit, all files can be checked locally via docker command.
This way, all used linters don't need to be installed locally individually.
As linters might change, check in .github/workflows/linting.yml
around L160
which environmental variables can to be used.
docker run \
-e LOG_LEVEL=DEBUG \
-e RUN_LOCAL=true \
-e DEFAULT_BRANCH=main \
-e BASH_SEVERITY=warning \
-e VALIDATE_BASH=true \
-e VALIDATE_BASH_EXEC=true \
-e VALIDATE_CSS=true \
-e VALIDATE_DOCKERFILE_HADOLINT=true \
-e VALIDATE_GITHUB_ACTIONS=true \
-e VALIDATE_HTML=true \
-e VALIDATE_JAVASCRIPT_ES=true \
-e VALIDATE_JAVASCRIPT_STANDARD=true \
-e VALIDATE_JSON=true \
-e VALIDATE_MARKDOWN=true \
-e VALIDATE_POWERSHELL=true \
-e VALIDATE_RENOVATE=true \
-e VALIDATE_XML=true \
-e VALIDATE_YAML=true \
-v /home/ctawalika/repos/actinia/actinia-core/:/tmp/lint \
ghcr.io/super-linter/super-linter:latest
Or with only one certain linter:
docker run \
-e RUN_LOCAL=true \
-e DEFAULT_BRANCH=main \
-e VALIDATE_BASH=true \
-v ${HOME}/repos/actinia/actinia-core/:/tmp/lint \
ghcr.io/super-linter/super-linter:latest