shipstation-client is a Python cli/package created with https://github.com/TezRomacH/python-package-template
For your development we've prepared:
- Supports for
Python 3.10and higher. Poetryas the dependencies manager. See configuration inpyproject.toml.- Power of
black,isortandpyupgradeformatters. - Ready-to-use
pre-commithooks with formatters above. - Type checks with the configured
mypy. - Testing with
pytest. - Docstring checks with
darglint. - Security checks with
safetyandbandit. - Well-made
.editorconfigand.gitignore. You don't have to worry about those things.
For building and deployment:
GitHubintegration.Makefilefor building routines. Everything is already set up for security checks, codestyle checks, code formatting, testing, linting, docker builds, etc. More details at Makefile summary).- Dockerfile for your package.
Github Actionswith predefined build workflow as the default CI/CD.
Setup Poetry
- Initialize
gitinside your repo:
git init- If you don't have
Poetryinstalled, run:
make download-poetry- Initialize poetry and install
pre-commithooks:
make installpip install shipstation-clientor install with Poetry
poetry add shipstation-clientThen you can run
shipstation-client --helpshipstation-client --name Romanor if installed with Poetry:
poetry run shipstation-client --helppoetry run shipstation-client --name RomanMakefile contains many functions for fast assembling and convenient work.
1. Download Poetry
make download-poetry2. Install all dependencies and pre-commit hooks
make installIf you do not want to install pre-commit hooks, run the command with the NO_PRE_COMMIT flag:
make install NO_PRE_COMMIT=13. Check the security of your code
make check-safetyThis command launches a Poetry and Pip integrity check as well as identifies security issues with Safety and Bandit. By default, the build will not crash if any of the items fail. But you can set STRICT=1 for the entire build, or you can configure strictness for each item separately.
make check-safety STRICT=1or only for safety:
make check-safety SAFETY_STRICT=1multiple
make check-safety PIP_STRICT=1 SAFETY_STRICT=1List of flags for
check-safety(can be set to1or0):STRICT,POETRY_STRICT,PIP_STRICT,SAFETY_STRICT,BANDIT_STRICT.
4. Check the codestyle
The command is similar to check-safety but to check the code style, obviously. It uses Black, Darglint, Isort, and Mypy inside.
make check-styleIt may also contain the STRICT flag.
make check-style STRICT=1List of flags for
check-style(can be set to1or0):STRICT,BLACK_STRICT,DARGLINT_STRICT,ISORT_STRICT,MYPY_STRICT.
5. Run all the codestyle formaters
Codestyle uses pre-commit hooks, so ensure you've run make install before.
make codestyle6. Run tests
make test7. Run all the linters
make lintthe same as:
make test && make check-safety && make check-styleList of flags for
lint(can be set to1or0):STRICT,POETRY_STRICT,PIP_STRICT,SAFETY_STRICT,BANDIT_STRICT,BLACK_STRICT,DARGLINT_STRICT,ISORT_STRICT,MYPY_STRICT.
8. Build docker
make dockerwhich is equivalent to:
make docker VERSION=latestMore information here.
This project is licensed under the terms of the MIT license. See LICENSE for more details.
@misc{shipstation-client,
author = {AgriTheory},
title = {`shipstation-client` is a Python cli/package created with https://github.com/TezRomacH/python-package-template},
year = {2024},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/agritheory/shipstation-client}}
}
This project was generated with python-package-template.