Skip to content

Development Guide

Thank you for considering contributing to APM! This document outlines the process for contributing to the project.

By participating in this project, you agree to abide by our Code of Conduct. Please read it before contributing.

Before submitting a bug report:

  1. Check the GitHub Issues to see if the bug has already been reported.
  2. Update your copy of the code to the latest version to ensure the issue hasn’t been fixed.

When submitting a bug report:

  1. Use our bug report template.
  2. Include detailed steps to reproduce the bug.
  3. Describe the expected behavior and what actually happened.
  4. Include any relevant logs or error messages.

Enhancement suggestions are welcome! Please:

  1. Use our feature request template.
  2. Clearly describe the enhancement and its benefits.
  3. Provide examples of how the enhancement would work.
  1. Fork the repository.
  2. Create a new branch for your feature/fix: git checkout -b feature/your-feature-name or git checkout -b fix/issue-description.
  3. Make your changes.
  4. Run tests: uv run pytest
  5. Ensure your code follows our coding style (we use Black and isort).
  6. Commit your changes with a descriptive message.
  7. Push to your fork.
  8. Submit a pull request.
  1. Fill out the PR template — describe what changed, why, and link the issue.
  2. Ensure your PR addresses only one concern (one feature, one bug fix).
  3. Include tests for new functionality.
  4. Update documentation if needed.
  5. PRs must pass all CI checks before they can be merged.

Every new issue is automatically labeled needs-triage. Maintainers review incoming issues and:

  1. Accept — remove needs-triage, add accepted, and assign a milestone.
  2. Prioritize — optionally add priority/high or priority/low.
  3. Close — if it’s a duplicate (duplicate) or out of scope, close with a comment explaining why.

Labels used for triage: needs-triage, accepted, needs-design, priority/high, priority/low.

This project uses uv to manage Python environments and dependencies:

Terminal window
# Clone the repository
git clone https://github.com/microsoft/apm.git
cd apm
# Install all dependencies (creates .venv automatically)
uv sync --extra dev

We use pytest for testing. After completing the setup above, run the test suite with:

Terminal window
uv run pytest -q

If you don’t have uv available, you can use a standard Python venv and pip:

Terminal window
# create and activate a venv (POSIX / WSL)
python -m venv .venv
source .venv/bin/activate
# install this package in editable mode and test deps
pip install -U pip
pip install -e .[dev]
# run tests
pytest -q

This project follows:

  • PEP 8 for Python style guidelines
  • We use Black for code formatting and isort for import sorting

You can run these tools with:

Terminal window
uv run black .
uv run isort .

If your changes affect how users interact with the project, update the documentation accordingly.

By contributing to this project, you agree that your contributions will be licensed under the project’s MIT License.

If you have any questions, feel free to open an issue or reach out to the maintainers.