This library provides common tools used for development...
Project description
core-dev-tools
core-dev-tools is a Python meta-package that centralizes the standard development toolchain for the entire ecosystem. Instead of each project independently declaring and versioning its own development tools, every project installs this single package and immediately has access to the full, curated set of tools.
There is no Python source code, the value of this package is entirely in its curated dependency list. A single pip install core-dev-tools is enough to equip any project or CI/CD pipeline with tools for:
Testing — pytest, pytest-cov, pytest-xdist, coverage, tox
Linting & formatting — Ruff, Pylint
Type checking — Mypy, Pyright, ty
Security & compliance — Bandit (bandit --check), pip-audit
Packaging & publishing — Build, Twine
Pre-commit hooks — pre-commit
Documentation — Sphinx
Task automation — taskipy, UV
Configuration — click, environs
This ensures consistent, version-controlled tooling across every project in the ecosystem without any per-project duplication.
Installation
Install from PyPI using pip:
pip install core-dev-tools
uv pip install core-dev-tools # Or using UV...
Getting Started
Install once per project or environment, all tools are immediately available on the PATH:
ruff check . # Lint
mypy . # Type check
bandit -r . # Security scan
pytest -n auto --cov=. # Tests with parallel execution and coverage
pip-audit # Dependency vulnerability scan
For detailed documentation, visit: https://core-dev-tools.readthedocs.io/
CI/CD Usage
The primary motivation for this package is CI/CD pipelines. Rather than listing every tool in each project’s pipeline configuration, simply install core-dev-tools at the start of the pipeline:
# Example GitLab CI / GitHub Actions step
- pip install core-dev-tools
Then run the tools you need in subsequent steps:
ruff check . # Enforce code style
pylint src/ # Static analysis
mypy src/ # Type checking
bandit -r src/ # Security compliance
pip-audit # CVE scan on dependencies
pytest -n auto --cov=src/ # Run test suite with coverage
tox # Multi-environment testing
Updating tool versions for the entire ecosystem is a single change in this package’s pyproject.toml, every downstream project picks it up on their next install.
Available Tools
UV
An extremely fast Python package and project manager, written in Rust.
More information: https://docs.astral.sh/uv/
uv [OPTIONS] <COMMAND>
Ruff Linter
The Ruff Linter is an extremely fast Python linter designed as a drop-in replacement for Flake8 (plus dozens of plugins), isort, pydocstyle, pyupgrade, autoflake, and more.
More information: https://docs.astral.sh/ruff/linter/
ruff check # Lint files in the current directory.
ruff check --fix # Lint files in the current directory and fix any fixable errors.
ruff check --watch # Lint files in the current directory and re-lint on change.
ruff check path/to/code/ # Lint files in `path/to/code`.
PyLint
Pylint is a tool that checks for errors in Python code, tries to enforce a coding standard (stricter/static code analyzer (if you want more opinions than ruff)) and looks for bad code smells.
More information: https://docs.pylint.org/
pylint <module_or_package>
Mypy
Mypy is an optional static type checker for Python that aims to combine the benefits of dynamic (or “duck”) typing and static typing.
More information:
mypy .
Pyright
Pyright is a full-featured, standards-compliant static type checker for Python. It is designed for high performance and can be used with large Python source bases.
More information: https://microsoft.github.io/pyright
pyright
Bandit
Bandit is a tool designed to find common security issues in Python code. To do this Bandit processes each file, builds an AST from it, and runs appropriate plugins against the AST nodes. Once Bandit has finished scanning all the files it generates a report.
More information: https://pypi.org/project/bandit/
bandit -r <path>
click
Click is a Python package for creating beautiful command line interfaces in a composable way with as little code as necessary. It is highly configurable and comes with sensible defaults out of the box.
More information: https://click.palletsprojects.com/
@click.command()
@click.option("--name", prompt="Your name", help="The person to greet.")
def hello(name):
click.echo(f"Hello {name}!")
coverage
coverage measures code coverage of Python programs. It monitors which lines of your program are executed and which are not, making it easy to identify untested code.
More information: https://coverage.readthedocs.io/
coverage run -m pytest # Run tests and measure coverage.
coverage report # Print coverage summary to terminal.
coverage html # Generate HTML coverage report.
environs
environs is a Python library for parsing environment variables. It makes it easy to define expected types, default values, and validation rules for environment-based configuration, with support for .env files.
More information: https://github.com/sloria/environs
from environs import Env
env = Env()
env.read_env() # Read .env file if it exists.
DEBUG = env.bool("DEBUG") # Parse and cast to bool.
PORT = env.int("PORT", 5000) # With a default value.
pip-audit
It is a tool for scanning Python environments for packages with known vulnerabilities. It uses the Python Packaging Advisory Database (https://github.com/pypa/advisory-database) via the PyPI JSON API as a source of vulnerability reports.
More information: https://pypi.org/project/pip-audit/
pip-audit
pre-commit
pre-commit is a framework for managing and maintaining multi-language pre-commit hooks. It integrates with git to automatically run checks (linters, formatters, security scanners) before each commit.
More information: https://pre-commit.com/
pre-commit install # Install hooks into the git repository.
pre-commit run --all-files # Run all hooks against all files.
pre-commit autoupdate # Update hook versions to latest.
pytest
pytest is a mature, full-featured Python testing framework. It makes it easy to write small, readable tests and scales to support complex functional testing for applications and libraries.
More information: https://docs.pytest.org/
pytest # Run all tests.
pytest tests/test_foo.py # Run a single test file.
pytest -k "test_name" # Run tests matching a keyword expression.
pytest -v # Run with verbose output.
pytest-cov
pytest-cov is a pytest plugin that measures code coverage during test runs. It integrates with the coverage package and supports parallel test execution via pytest-xdist.
More information: https://pytest-cov.readthedocs.io/
pytest --cov=<source> # Run tests with coverage report.
pytest --cov=<source> --cov-report=html # Generate HTML coverage report.
pytest --cov=<source> --cov-report=term # Print coverage summary to terminal.
pytest-xdist
pytest-xdist is a pytest plugin that extends pytest with distributed and parallel test execution modes. It allows tests to run across multiple CPUs or even remote machines.
More information: https://pytest-xdist.readthedocs.io/
pytest -n auto # Run tests in parallel using all available CPUs.
pytest -n <num> # Run tests in parallel using <num> workers.
Tox
It aims to automate and standardize testing in Python. It is part of a larger vision of easing the packaging, testing and release process of Python software (alongside pytest and devpi).
More information:
tox
taskipy
The complementary task runner for python.
More information: https://pypi.org/project/taskipy/
task <task-name>
Sphinx
Sphinx makes it easy to create intelligent and beautiful documentation.
More information: https://www.sphinx-doc.org/
sphinx-quickstart docs
cd docs
make html
Build
A simple, correct Python packaging build frontend. It manages pyproject.toml-based builds, invoking build-backend hooks as appropriate to build a distribution package. It is a simple build tool and does not perform any dependency management.
More information: https://pypi.org/project/build/
python -m build
Twine
Twine is a utility for publishing Python packages to PyPI and other repositories. It provides build system independent uploads of source and binary distribution artifacts for both new and existing projects.
More information: https://twine.readthedocs.io/en/stable/
twine check dist/*
twine upload -u USER -p PASSWORD dist/*
ty
ty is an extremely fast Python type checker and language server written in Rust, developed by Astral (the creators of Ruff and uv). It is designed to be a high-performance alternative to mypy and pyright.
More information: https://docs.astral.sh/ty/
ty check # Type-check the current project.
ty check <path> # Type-check a specific file or directory.
Contributing
Contributions are welcome! Please:
Fork the repository
Create a feature branch
Write tests for new functionality
Ensure all tests pass: pytest -n auto
Run linting: pylint .
Run security checks: bandit .
Submit a pull request
License
This project is licensed under the MIT License. See the LICENSE file for details.
Links
Documentation: https://core-dev-tools.readthedocs.io/en/latest/
Repository: https://gitlab.com/bytecode-solutions/core/core-dev-tools
Issues: https://gitlab.com/bytecode-solutions/core/core-dev-tools/-/issues
Changelog: https://gitlab.com/bytecode-solutions/core/core-dev-tools/-/blob/main/CHANGELOG.md
Support
For questions or support, please open an issue on GitLab or contact the maintainers.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file core_dev_tools-2.0.0.tar.gz.
File metadata
- Download URL: core_dev_tools-2.0.0.tar.gz
- Upload date:
- Size: 8.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
54524ef62419cd88ca70330e35ab119cd31d79364b1d28a63f0cd3de1a19e2cc
|
|
| MD5 |
49f421726bc45b4b8d579b0caca67aae
|
|
| BLAKE2b-256 |
f89fe640218be35d8f5606ae0b8da37eae8e7436726f639ed813959b21dc6f0f
|
File details
Details for the file core_dev_tools-2.0.0-py3-none-any.whl.
File metadata
- Download URL: core_dev_tools-2.0.0-py3-none-any.whl
- Upload date:
- Size: 6.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0183b5a29cfd81c00a63d4cb926eb3d03bd79c87802a3b7b26e9d3bba2d86290
|
|
| MD5 |
79b41b99b43df60a64f1087ad8780aff
|
|
| BLAKE2b-256 |
af15e82340f040aaa0b21e16a18ef3a6a5e72d308faeed283a634d5895614c0e
|