Skip to main content

MCP server exposing Azure DevOps workflow automation tools

Project description

ADO Workflows MCP Server

CI coverage PyPI License: MIT

An MCP server exposing ado-workflows as tool calls for AI agents. Enables Copilot and other MCP clients to discover Azure DevOps repositories, manage pull requests, and interact with PR comments and reviews.

Quick Install

Install in VS Code Install in VS Code Insiders

Click a badge above to install with one click, or follow manual installation below.

Features

  • Repository Discovery: Scan directories for git repos with Azure DevOps remotes
  • PR Lifecycle: Create pull requests, establish PR context from URLs or IDs
  • Review Management: Check reviewer votes, detect stale approvals, find PRs needing attention
  • Comment Workflows: Analyze, post, reply to, and batch-resolve PR comment threads
  • Session Caching: Cache repository context to avoid redundant git CLI lookups
  • Error Handling: Actionable errors with suggestions via actionable-errors

MCP Tools

Repository Discovery

Tool Description
repository_discovery Scan a directory for git repos with Azure DevOps remotes, select the best match
set_repository_context Cache repository context for the session (avoids redundant git CLI lookups)
get_repository_context_status Inspect current cached context state for debugging
clear_repository_context Reset cached context, forcing fresh discovery

Pull Requests

Tool Description
establish_pr_context Parse a PR URL or resolve a numeric PR ID into reusable context
create_pull_request Create a new PR from branch names with optional title, description, and draft mode

PR Review

Tool Description
get_pr_review_status Fetch reviewer votes, commit history, and detect stale approvals
analyze_pending_reviews Discover PRs needing review attention across a repository

PR Comments

Tool Description
analyze_pr_comments Categorize comment threads by status with author statistics
post_pr_comment Post a new comment thread to a PR
reply_to_pr_comment Reply to an existing comment thread
resolve_pr_comments Batch-resolve comment threads (partial-success semantics)

Installation

Quick Install (Recommended)

Click one of the badges at the top to automatically install in VS Code!

Manual Installation

cd ado-workflows-mcp
uv sync --all-extras

VS Code / Copilot Configuration

Add to your VS Code settings or .vscode/mcp.json:

{
  "mcp.servers": {
    "ado-workflows": {
      "command": "uvx",
      "args": ["--from", "git+https://github.com/grimlor/ado-workflows-mcp", "ado-workflows-mcp"],
      "description": "Azure DevOps workflow automation tools"
    }
  }
}

The server communicates over stdio using the Model Context Protocol.

Authentication

Uses Azure DefaultAzureCredential via the ado-workflows library. Authenticate with any method that DefaultAzureCredential supports:

az login                           # Azure CLI (local dev)
az login --use-device-code         # Headless / SSH

Managed identity, environment variables, and other credential providers work automatically in hosted environments.

Error Handling

All errors are returned as structured ActionableError objects with:

  • error / suggestion — human-readable context
  • ai_guidance — machine-readable recovery instructions (action_required, checks, steps, command, discovery_tool)

Errors are returned as data, never raised — the MCP transport stays clean.

Typical Workflow

1. repository_discovery        → find the ADO repo
2. set_repository_context      → cache it for the session
3. establish_pr_context        → resolve a PR URL or ID
4. get_pr_review_status        → check approval state
5. analyze_pr_comments         → see active threads
6. post_pr_comment / reply     → leave feedback
7. resolve_pr_comments         → mark threads as fixed

Development

uv run task check                # lint + type + test (all-in-one)
uv run task test                 # Run tests (37 BDD specs)
uv run task cov                  # Run tests with coverage
uv run task lint                 # Lint (with auto-fix)
uv run task format               # Format code
uv run task type                 # Type check

Note: uv run is optional when the venv is activated via direnv.

Project Structure

src/ado_workflows_mcp/
├── server.py              # FastMCP server entry point
├── mcp_instance.py        # MCP singleton
├── tools/
│   ├── repositories.py    # Repository discovery tools
│   ├── repository_context.py  # Session context management
│   ├── pull_requests.py   # PR lifecycle tools
│   ├── pr_review.py       # Review status tools
│   ├── pr_comments.py     # Comment workflow tools
│   └── _helpers.py        # Shared error-handling utilities
└── py.typed               # PEP 561 marker

Testing

37 BDD specs across 10 requirement classes — organized by consumer requirement, not code structure.

Requirement Class Specs Coverage
TestRepositoryDiscovery 3 Success, working-dir failure, SDK failure
TestSetRepositoryContext 3 Valid context, missing fields, SDK failure
TestGetRepositoryContextStatus 3 Populated, empty, error
TestClearRepositoryContext 2 Reset + clear state
TestEstablishPRContext 3 URL parse, ID resolve, SDK failure
TestCreatePullRequest 3 Success, missing branch, SDK failure
TestGetPRReviewStatus 3 Success, invalid PR, SDK failure
TestAnalyzePendingReviews 3 Results, empty, SDK failure
TestAnalyzePRComments 3 Categorized, no threads, SDK failure
TestPostPRComment 3 Valid post, empty content, SDK failure
TestReplyToPRComment 3 Valid reply, missing thread, SDK failure
TestResolvePRComments 3 Batch resolve, empty list, SDK failure

Documentation

  • Architecture — Tool layers, error propagation, and design decisions

Related

License

This project is licensed under the MIT License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ado_workflows_mcp-0.7.1.tar.gz (117.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ado_workflows_mcp-0.7.1-py3-none-any.whl (25.1 kB view details)

Uploaded Python 3

File details

Details for the file ado_workflows_mcp-0.7.1.tar.gz.

File metadata

  • Download URL: ado_workflows_mcp-0.7.1.tar.gz
  • Upload date:
  • Size: 117.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ado_workflows_mcp-0.7.1.tar.gz
Algorithm Hash digest
SHA256 ef73b8305cbb342b0a7bfee55b00a84a7496e8575b3580f002f8d3f90821c9c1
MD5 ae48c4f08abae53d164c69ee5776a148
BLAKE2b-256 3e83f25f9144ef8c3d7fb33178dc16869af96fccc9bfcda03394023362d76436

See more details on using hashes here.

Provenance

The following attestation bundles were made for ado_workflows_mcp-0.7.1.tar.gz:

Publisher: release.yml on grimlor/ado-workflows-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ado_workflows_mcp-0.7.1-py3-none-any.whl.

File metadata

File hashes

Hashes for ado_workflows_mcp-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e1ed3f4ddacf26d192b331626ef4844989bda0f4a9f68156610f5fb51196aa68
MD5 ee9a26cb66a7dfb1991116649daca35c
BLAKE2b-256 0d114b5a7ac728b8037a94a93d7888803766a8581108db4be1d4d1c383597db3

See more details on using hashes here.

Provenance

The following attestation bundles were made for ado_workflows_mcp-0.7.1-py3-none-any.whl:

Publisher: release.yml on grimlor/ado-workflows-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page