Developing for GuideLLM
Thank you for your interest in contributing to GuideLLM! 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.
Setting Up Your Development Environment
Prerequisites
Before you begin, ensure you have the following installed:
- Python 3.10 or higher
- pip (Python package manager)
- Tox
- Git
Cloning the Repository
- Clone the repository to your local machine:
- (Optional) If you plan to contribute changes back, fork the repository and clone your fork instead:
Installing Dependencies
To install the required dependencies for the package and development, run:
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.
Implementing Changes
Writing Code
- Create a Branch: Create a new branch for your changes:
-
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.
Tag use of AI coding assistants
When AI coding assistants are used to generate or substantially modify code, the GuideLLM project requires that you add one of the following trailers to the git commit message:
Generated-by: <name of the AI coding assistant>: when the code in the commit was generated primarily by an AI coding assistant.Assisted-by: <name of the AI coding assistant>: when the commit includes substantial code created or modified by the AI coding assistant.
For example:
This is the commit summary.
Details of the changes made in this commit.
Generated-by: Cursor
Signed-off-by: John Doe <john.doe@example.com>
You can optionally add the LLM model name after the name of the AI coding assistant, separated by a space.
For example:
Running Quality, Style, and Type Checks
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.
Code Quality and Style
To check code quality, including linting and formatting:
To automatically fix style issues:
Type Checking
To ensure type safety using Mypy:
Link Checking
To ensure valid links added to the documentation / Markdown files:
Automating Quality Checks with Pre-Commit Hooks (Optional)
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:
This will set up the hooks to run automatically before each commit. To manually run the hooks on all files, use:
Running Tests
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.
Running All Tests
To run all tests:
Running Specific Tests
- Unit tests (focused on individual components with mocking):
- Integration tests (focused on interactions between components ideally without mocking):
- End-to-end tests (focused on the entire system and user interfaces):
Running Tests with Coverage
To ensure your changes are covered by tests, run:
Review the coverage report to confirm that your new code is adequately tested.
Opening a Pull Request
- Push Changes: Push your branch to your forked repository (if you forked):
- 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.
Developing the Web UI
The GuideLLM project includes a frontend UI located in src/ui, built using Next.js. This section provides instructions for working on the UI.
Getting Started
First, install dependencies:
Then, start the local development server:
Then open http://localhost:3000 in your browser.
Building for Production
To build the app for production (output in the out directory):
Running UI Tests
- Unit tests:
- Integration tests:
- Integration+Unit tests with coverage:
- End-to-end tests (using Cypress, ensure live dev server):
Code Quality and Styling
- Fix styling issues:
- Run ESLint checks:
- Run TS type checks:
Tagging Tests
Reference jest-runner-groups. Add @group with the tag in a docblock at the top of the test file to indicate which types of tests are contained within. Can't distinguish between different types of tests in the same file.
🧪 UI Development Notes
During development, it can be helpful to view sample data. We include a sample benchmark run wired into the Redux store under:
In the future this will be replaced by a configurable untracked file for dev use.
Logging
Logging is useful for learning how GuideLLM works and finding problems.
Logging is set using the following environment variables:
GUIDELLM__LOGGING__DISABLED: Disable logging (default: false).GUIDELLM__LOGGING__CLEAR_LOGGERS: Clear existing loggers from loguru (default: true).GUIDELLM__LOGGING__CONSOLE_LOG_LEVEL: Log level for console logging (default: none, options: DEBUG, INFO, WARNING, ERROR, CRITICAL).GUIDELLM__LOGGING__LOG_FILE: Path to the log file for file logging (default: guidellm.log if log file level set else none)GUIDELLM__LOGGING__LOG_FILE_LEVEL: Log level for file logging (default: INFO if log file set else none).
If logging isn't responding to the environment variables, run the guidellm env command to validate that the environment variables match and are being set correctly.
Additional Resources
- 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.