2018-05-19 16:27:54 +02:00
|
|
|
This folder contains lint scripts.
|
|
|
|
|
2023-01-17 17:52:05 +01:00
|
|
|
Running locally
|
|
|
|
===============
|
|
|
|
|
|
|
|
To run linters locally with the same versions as the CI environment, use the included
|
|
|
|
Dockerfile:
|
|
|
|
|
|
|
|
```sh
|
2023-08-18 15:23:04 +02:00
|
|
|
DOCKER_BUILDKIT=1 docker build -t bitcoin-linter --file "./ci/lint_imagefile" ./ && docker run --rm -v $(pwd):/bitcoin -it bitcoin-linter
|
2023-01-17 17:52:05 +01:00
|
|
|
```
|
|
|
|
|
2023-08-18 15:23:04 +02:00
|
|
|
Building the container can be done every time, because it is fast when the
|
|
|
|
result is cached and it prevents issues when the image changes.
|
2023-01-17 17:52:05 +01:00
|
|
|
|
2023-02-14 17:42:12 +01:00
|
|
|
test runner
|
|
|
|
===========
|
|
|
|
|
2024-03-02 21:26:48 +01:00
|
|
|
To run all the lint checks in the test runner outside the docker you first need
|
|
|
|
to install the rust toolchain using your package manager of choice or
|
|
|
|
[rustup](https://www.rust-lang.org/tools/install).
|
|
|
|
|
|
|
|
Then you can use:
|
2023-02-14 17:42:12 +01:00
|
|
|
|
|
|
|
```sh
|
2024-02-09 10:31:40 +01:00
|
|
|
( cd ./test/lint/test_runner/ && cargo fmt && cargo clippy && RUST_BACKTRACE=1 cargo run )
|
2023-02-14 17:42:12 +01:00
|
|
|
```
|
2023-01-17 17:52:05 +01:00
|
|
|
|
2024-01-16 10:53:48 +01:00
|
|
|
#### Dependencies
|
|
|
|
|
|
|
|
| Lint test | Dependency |
|
|
|
|
|-----------|:----------:|
|
2024-05-02 22:30:59 +02:00
|
|
|
| [`lint-python.py`](/test/lint/lint-python.py) | [flake8](https://github.com/PyCQA/flake8)
|
|
|
|
| [`lint-python.py`](/test/lint/lint-python.py) | [lief](https://github.com/lief-project/LIEF)
|
|
|
|
| [`lint-python.py`](/test/lint/lint-python.py) | [mypy](https://github.com/python/mypy)
|
|
|
|
| [`lint-python.py`](/test/lint/lint-python.py) | [pyzmq](https://github.com/zeromq/pyzmq)
|
|
|
|
| [`lint-python-dead-code.py`](/test/lint/lint-python-dead-code.py) | [vulture](https://github.com/jendrikseipp/vulture)
|
|
|
|
| [`lint-shell.py`](/test/lint/lint-shell.py) | [ShellCheck](https://github.com/koalaman/shellcheck)
|
|
|
|
| [`lint-spelling.py`](/test/lint/lint-spelling.py) | [codespell](https://github.com/codespell-project/codespell)
|
2024-05-07 16:37:31 +02:00
|
|
|
| markdown link check | [mlc](https://github.com/becheran/mlc)
|
2024-01-16 10:53:48 +01:00
|
|
|
|
2024-03-05 14:43:21 +01:00
|
|
|
In use versions and install instructions are available in the [CI setup](../../ci/lint/04_install.sh).
|
2024-01-16 10:53:48 +01:00
|
|
|
|
|
|
|
Please be aware that on Linux distributions all dependencies are usually available as packages, but could be outdated.
|
|
|
|
|
|
|
|
#### Running the tests
|
|
|
|
|
|
|
|
Individual tests can be run by directly calling the test script, e.g.:
|
|
|
|
|
|
|
|
```
|
|
|
|
test/lint/lint-files.py
|
|
|
|
```
|
|
|
|
|
2018-05-19 16:27:54 +02:00
|
|
|
check-doc.py
|
|
|
|
============
|
|
|
|
Check for missing documentation of command line options.
|
|
|
|
|
|
|
|
commit-script-check.sh
|
|
|
|
======================
|
|
|
|
Verification of [scripted diffs](/doc/developer-notes.md#scripted-diffs).
|
2019-10-17 16:53:21 +02:00
|
|
|
Scripted diffs are only assumed to run on the latest LTS release of Ubuntu. Running them on other operating systems
|
|
|
|
might require installing GNU tools, such as GNU sed.
|
2018-05-19 16:27:54 +02:00
|
|
|
|
|
|
|
git-subtree-check.sh
|
|
|
|
====================
|
|
|
|
Run this script from the root of the repository to verify that a subtree matches the contents of
|
|
|
|
the commit it claims to have been updated to.
|
|
|
|
|
2020-12-04 09:33:15 +01:00
|
|
|
```
|
|
|
|
Usage: test/lint/git-subtree-check.sh [-r] DIR [COMMIT]
|
|
|
|
test/lint/git-subtree-check.sh -?
|
|
|
|
```
|
|
|
|
|
|
|
|
- `DIR` is the prefix within the repository to check.
|
|
|
|
- `COMMIT` is the commit to check, if it is not provided, HEAD will be used.
|
|
|
|
- `-r` checks that subtree commit is present in repository.
|
|
|
|
|
|
|
|
To do a full check with `-r`, make sure that you have fetched the upstream repository branch in which the subtree is
|
2018-05-19 16:27:54 +02:00
|
|
|
maintained:
|
|
|
|
* for `src/secp256k1`: https://github.com/bitcoin-core/secp256k1.git (branch master)
|
2021-09-29 08:40:43 +02:00
|
|
|
* for `src/leveldb`: https://github.com/bitcoin-core/leveldb-subtree.git (branch bitcoin-fork)
|
2018-05-19 16:27:54 +02:00
|
|
|
* for `src/crypto/ctaes`: https://github.com/bitcoin-core/ctaes.git (branch master)
|
2021-09-29 08:40:43 +02:00
|
|
|
* for `src/crc32c`: https://github.com/bitcoin-core/crc32c-subtree.git (branch bitcoin-fork)
|
2020-02-18 23:45:02 +01:00
|
|
|
* for `src/minisketch`: https://github.com/sipa/minisketch.git (branch master)
|
2018-05-19 16:27:54 +02:00
|
|
|
|
2020-06-12 12:33:00 +02:00
|
|
|
To do so, add the upstream repository as remote:
|
|
|
|
|
|
|
|
```
|
|
|
|
git remote add --fetch secp256k1 https://github.com/bitcoin-core/secp256k1.git
|
|
|
|
```
|
2024-02-26 11:36:10 +01:00
|
|
|
|
|
|
|
lint_ignore_dirs.py
|
|
|
|
===================
|
|
|
|
Add list of common directories to ignore when running tests
|