2022-12-05 09:58:23 -08:00
|
|
|
# PiSCSI Python Apps
|
2022-01-22 00:08:29 +01:00
|
|
|
|
2022-12-05 09:58:23 -08:00
|
|
|
This directory contains Python-based clients for PiSCSI as well as common
|
2022-01-22 00:08:29 +01:00
|
|
|
packages that are shared among the clients.
|
|
|
|
|
|
|
|
The following paragraphs in this README contain instructions that are shared
|
|
|
|
among all Python apps.
|
|
|
|
|
2023-11-09 19:44:32 +09:00
|
|
|
## Supported Python interpreters
|
2022-08-25 17:57:44 -07:00
|
|
|
|
|
|
|
The policy in this project is to support the Python 3 interpreter that comes
|
2023-11-09 19:44:32 +09:00
|
|
|
standard with the current stable, as well as the previous stable releases of Debian.
|
2022-08-25 17:57:44 -07:00
|
|
|
|
|
|
|
At the time of writing they are:
|
2023-10-25 19:35:22 +09:00
|
|
|
- Python 3.11 in [Debian Bookworm](https://packages.debian.org/bookworm/python3)
|
|
|
|
- Python 3.9 in [Debian Bullseye](https://packages.debian.org/bullseye/python3)
|
2022-08-25 17:57:44 -07:00
|
|
|
|
2023-11-09 19:44:32 +09:00
|
|
|
## Dependencies
|
|
|
|
|
|
|
|
We use 'pip freeze' to manage explicit Python dependencies in this project.
|
|
|
|
After adding new or bumping the versions of Python dependencies,
|
|
|
|
please run the following command in the requisite subdir commit the results:
|
|
|
|
|
|
|
|
```
|
|
|
|
pip freeze -l > requirements.txt
|
|
|
|
```
|
|
|
|
|
2023-10-25 19:35:22 +09:00
|
|
|
## Static analysis and formatting
|
2022-01-22 00:08:29 +01:00
|
|
|
|
2023-10-25 19:35:22 +09:00
|
|
|
The CI workflow is set up to check code formatting with `black`,
|
|
|
|
and linting with `flake8`. If non-conformant code is found, the CI job
|
|
|
|
will fail.
|
|
|
|
|
|
|
|
Before checking in new code, install the development packages and run
|
|
|
|
these two tools locally.
|
|
|
|
|
|
|
|
```
|
|
|
|
pip install -r web/requirements-dev.txt
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that `black` only works correctly if you run it in the root of the
|
|
|
|
`python/` dir:
|
|
|
|
|
|
|
|
```
|
|
|
|
cd python
|
|
|
|
black .
|
|
|
|
```
|
|
|
|
|
|
|
|
Optionally: It is recommended to run pylint against new code to protect against bugs
|
2022-01-22 00:08:29 +01:00
|
|
|
and keep the code readable and maintainable.
|
|
|
|
The local pylint configuration lives in .pylintrc.
|
|
|
|
In order for pylint to recognize venv libraries, the pylint-venv package is required.
|
|
|
|
|
|
|
|
```
|
|
|
|
sudo apt install pylint3
|
|
|
|
sudo pip install pylint-venv
|
|
|
|
source venv/bin/activate
|
|
|
|
pylint3 python_source_file.py
|
|
|
|
```
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
```
|
|
|
|
# check a single file
|
|
|
|
pylint web/src/web.py
|
|
|
|
|
|
|
|
# check the python modules
|
|
|
|
pylint common/src
|
|
|
|
pylint web/src
|
|
|
|
pylint oled/src
|
2022-08-25 17:57:44 -07:00
|
|
|
```
|