Development & Contribution¶
This guide covers how to contribute to Protolink, from setting up your development environment to submitting pull requests.
Getting Started¶
Prerequisites¶
- Python 3.10+ - Required for all development
- Git - For version control
- uv - Recommended package manager (or
pip)
Clone and Setup¶
# Clone the repository
git clone https://github.com/nMaroulis/protolink.git
cd protolink
# Install in development mode
uv pip install -e ".[dev]"
# Or with pip
pip install -e ".[dev]"
This installs Protolink in editable mode with all development dependencies.
Development Workflow¶
1. Fork and Clone¶
- Fork the repository on GitHub
- Clone your fork locally:
git clone https://github.com/<your-username>/protolink.git
cd protolink
# Add upstream for syncing
git remote add upstream https://github.com/nMaroulis/protolink.git
2. Create a Feature Branch¶
git checkout -b feature/your-feature-name
3. Make Changes¶
- Write your code
- Add tests for new functionality
- Update documentation if needed
4. Quality Checks¶
# Format code
ruff format .
# Lint and auto-fix
ruff check . --fix
# Type checking
ty check .
# Run tests
pytest -v tests
5. Commit and Push¶
git add .
git commit -m "feat: add your feature description"
git push origin feature/your-feature-name
6. Open Pull Request¶
- Open a PR from your fork to
main - Describe your changes clearly
- Include any breaking changes
Code Quality¶
Formatting and Linting¶
Protolink uses Ruff for code formatting and linting.
Ruff Configuration
The project uses the default Ruff configuration with some custom rules. See ruff.toml for details.
# Format all code
ruff format .
# Lint and auto-fix issues
ruff check . --fix
# Check without auto-fixing
ruff check .
Type Checking¶
Protolink uses ty for static type checking.
# Run type checks
ty check .
# Check specific files
ty check protolink/agents/base.py
Type Safety
- All new code should be fully typed
- Use
str | Noneinstead ofOptional[str](PEP 604) - Add type hints for all public APIs
Testing¶
Run the test suite with pytest:
# Run all tests
pytest -v tests
# Run specific test file
pytest -v tests/test_agent.py
# Run with coverage
pytest --cov=protolink tests
Test Structure
- Unit tests:
tests/test_*.py - Integration tests:
tests/integration/ - Fixtures and utilities in
tests/conftest.py
Development Tools¶
Pre-commit Hooks¶
The project includes pre-commit hooks for code quality:
# Install pre-commit hooks
pre-commit install
# Run hooks manually
pre-commit run --all-files
Documentation¶
Preview documentation locally:
# Serve docs
mkdocs serve
# Open http://127.0.0.1:8000
Deploy documentation (maintainers only):
mkdocs gh-deploy
Project Structure¶
protolink/
├── protolink/ # Main package
│ ├── agents/ # Agent implementations
│ ├── client/ # Client code
│ ├── core/ # Core models
│ ├── discovery/ # Registry and discovery
│ ├── llms/ # LLM integrations
│ ├── models/ # Exposes core models for importation
│ ├── server/ # Server implementations
│ ├── transport/ # Transport layers
│ ├── tools/ # Tools and adapters (e.g. MCP)
│ ├── types/ # Type aliases
│ └── utils/ # Utilities
├── tests/ # Test suite
├── docs/ # Documentation
├── examples/ # Example scripts
└── README.md # Project overview
Contribution Guidelines¶
Code Style¶
- Follow PEP 8 and PEP 604
- Use descriptive variable and function names
- Add docstrings for all public functions and classes
- Keep functions focused and single-purpose
Commit Messages¶
Use conventional commits:
feat:- New featuresfix:- Bug fixesdocs:- Documentation changesstyle:- Code style changesrefactor:- Code refactoringtest:- Test changeschore:- Maintenance tasks
Pull Request Process¶
- Update Documentation - If your change affects user-facing APIs
- Add Tests - Ensure new functionality is covered
- Pass CI - All checks must pass
- Review - Address feedback from maintainers
Breaking Changes
If your change includes breaking changes:
- Clearly document them in the PR
- Update the version in __version__.py
- Add migration notes to documentation
Debugging and Troubleshooting¶
Common Issues¶
Type Checking Errors¶
# Check specific file for detailed errors
ty check protolink/your/file.py --verbose
Test Failures¶
# Run tests with detailed output
pytest -v -s tests/test_failing.py
# Run specific test with debugging
pytest -v -s tests/test_failing.py::test_function
Import Issues¶
# Install in development mode
pip install -e .
# Check Python path
python -c "import protolink; print(protolink.__file__)"
Development Tips¶
- Use
uvfor faster dependency management - Enable debug logging:
export PROTOLINK_LOG_LEVEL=debug - Use breakpoints:
import pdb; pdb.set_trace() - Run tests in watch mode:
ptw tests
Release Process¶
Maintainers can follow this process for releases:
- Update Version in
protolink/__version__.py - Update Changelog in
CHANGELOG.md - Tag Release:
git tag v0.1.0 - Push Tags:
git push origin --tags - Build Package:
python -m build - Upload to PyPI:
python -m twine upload dist/*
Community¶
Getting Help¶
- GitHub Issues - Bug reports and feature requests
- Discussions - General questions and ideas
- Documentation - API reference and guides
Code of Conduct¶
Please be respectful and constructive in all interactions. By participating in this project, you agree to follow our community guidelines.
Thank you for contributing to Protolink! 🚀
🎉🎉 Congratulations, You made it! 🎉🎉
Want to see more? Stay tuned, as the project is actively maintained and everything is changing rapidly!