Thank you for your interest in contributing to Speculators! This document provides detailed instructions for setting up your development environment, implementing changes, and adhering to the project's best practices. Your contributions help us grow and improve this project.
Before you begin, ensure you have the following installed:
- Python 3.9 or higher
- pip (Python package manager)
- Tox
- Git
-
Clone the repository to your local machine:
git clone https://github.com/neuralmagic/guidellm.git cd guidellm
-
(Optional) If you plan to contribute changes back, fork the repository and clone your fork instead:
git clone https://github.com/<your-username>/guidellm.git cd guidellm
To install the required dependencies for the package and development, run:
pip install -e ./[dev]
The -e
flag installs the package in editable mode, allowing you to make changes to the code without reinstalling it. The [dev]
part installs additional dependencies needed for development, such as testing and linting tools.
-
Create a Branch: Create a new branch for your changes:
git checkout -b feature/your-feature-name
-
Make Changes: Implement your changes in the appropriate files. Ensure that all public functions and classes have clear and concise docstrings.
-
Update Documentation: Update or add documentation to reflect your changes. This includes updating README files, docstrings, and any relevant guides.
We use Tox to simplify running various tasks in isolated environments. Tox standardizes environments to ensure consistency across local development, CI/CD pipelines, and releases. This guarantees that the code behaves the same regardless of where it is executed.
Additionally, to ensure consistency and quality of the codebase, we use ruff for linting and styling, isort for sorting imports, mypy for type checking, and mdformat for formatting Markdown files.
To check code quality, including linting and formatting:
tox -e quality
To automatically fix style issues:
tox -e style
To ensure type safety using Mypy:
tox -e types
To ensure valid links added to the documentation / Markdown files:
tox -e links
We use pre-commit to automate quality checks before commits. Pre-commit hooks run checks like linting, formatting, and type checking, ensuring that only high-quality code is committed.
To install the pre-commit hooks, run:
pre-commit install
This will set up the hooks to run automatically before each commit. To manually run the hooks on all files, use:
pre-commit run --all-files
For testing, we use pytest as our testing framework. We have different test suites for unit tests, integration tests, and end-to-end tests. To run the tests, you can use Tox, which will automatically create isolated environments for each test suite. Tox will also ensure that the tests are run in a consistent environment, regardless of where they are executed.
To run all tests:
tox
-
Unit tests (focused on individual components with mocking):
tox -e test-unit
-
Integration tests (focused on interactions between components ideally without mocking):
tox -e test-integration
-
End-to-end tests (focused on the entire system and user interfaces):
tox -e test-e2e
To ensure your changes are covered by tests, run:
tox -e test-unit -- --cov=speculators --cov-report=html
Review the coverage report to confirm that your new code is adequately tested.
-
Push Changes: Push your branch to your forked repository (if you forked):
git push origin feature/your-feature-name
-
Open a Pull Request: Go to the original repository and open a pull request. Use the following template for your pull request description:
# Title; ex: Add feature X to improve Y ## Summary: Short paragraph detailing the pull request changes and reasoning in addition to any relevant context. ## Details: - Detailed list of changes made in the pull request ## Test Plan: - Detailed list of steps to test the changes made in the pull request ## Related Issues - List of related issues or other pull requests; ex: "Fixes #1234"
-
Address Feedback: Respond to any feedback from reviewers and make necessary changes.
- CONTRIBUTING.md: Guidelines for contributing to the project.
- CODE_OF_CONDUCT.md: Our expectations for community behavior.
- tox.ini: Configuration for Tox environments.
- .pre-commit-config.yaml: Configuration for pre-commit hooks.