Development Setup¶
Complete setup guide for contributors.
Prerequisites¶
- Python 3.8 or higher
- Git
- uv (recommended) or pip
Initial Setup¶
1. Fork and Clone¶
2. Install uv¶
# macOS/Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
3. Install Dependencies¶
This creates a virtual environment at .venv/ and installs:
- Production dependencies
- Development tools (pytest, ruff, pyright)
- Documentation tools (mkdocs)
- Optional extras
4. Activate Environment¶
5. Download C-CDA References¶
mkdir -p references
cd references
git clone https://github.com/jddamore/ccda-search.git C-CDA_2.1
cd ..
Development Tools¶
Running Tests¶
# All tests
pytest
# With coverage
pytest --cov=ccdakit --cov-report=html
# Specific test
pytest tests/test_builders/test_document.py::TestClinicalDocument
# Parallel
pytest -n auto
# Watch mode
pytest-watch
Code Quality¶
# Lint
ruff check .
# Auto-fix
ruff check --fix .
# Format
ruff format .
# Type check
pyright ccdakit
Documentation¶
# Serve docs locally
mkdocs serve
# Build docs
mkdocs build
# Deploy to GitHub Pages
mkdocs gh-deploy
IDE Setup¶
VS Code¶
Create .vscode/settings.json:
{
  "python.defaultInterpreterPath": ".venv/bin/python",
  "python.testing.pytestEnabled": true,
  "python.testing.pytestArgs": ["tests"],
  "python.linting.enabled": false,
  "ruff.enable": true,
  "editor.formatOnSave": true,
  "editor.codeActionsOnSave": {
    "source.organizeImports": true
  }
}
Recommended extensions: - Python - Pylance - Ruff
PyCharm¶
- Open project
- Select .venv/bin/pythonas interpreter
- Enable pytest as test runner
- Configure Ruff as external tool
Project Structure¶
ccdakit/
├── ccdakit/              # Source code
│   ├── core/            # Core classes
│   ├── protocols/       # Protocol definitions
│   ├── builders/        # XML builders
│   ├── validators/      # Validation
│   └── utils/           # Utilities
├── tests/               # Test suite
├── examples/            # Example scripts
├── docs/                # Documentation
├── references/          # C-CDA references
└── schemas/             # XSD schemas
Common Tasks¶
Add a New Section¶
- Create protocol: ccdakit/protocols/mysection.py
- Create builder: ccdakit/builders/sections/mysection.py
- Add tests: tests/test_builders/test_mysection.py
- Update exports: ccdakit/__init__.py
- Document it: docs/guides/sections.md
Run Specific Tests¶
# Single test
pytest tests/test_core/test_config.py::test_configure
# All unit tests
pytest tests/test_core
# Integration tests
pytest tests/test_integration
# Coverage for specific module
pytest --cov=ccdakit.builders tests/test_builders
Debug Tests¶
Troubleshooting¶
Import Errors¶
Test Failures¶
Type Errors¶
# Check specific file
pyright ccdakit/builders/document.py
# Ignore specific errors
# Add to pyrightconfig.json