Read this in: 한국어 | 日本語 | 简体中文
Azure Functions Doctor is the pre-deploy health gate for Azure Functions Python v2 projects — a diagnostic CLI that catches configuration issues, missing dependencies, and environment problems before they cause runtime failures in production.
Part of the Azure Functions Python DX Toolkit → Bring FastAPI-like developer experience to Azure Functions
Deploying a broken Azure Functions app is expensive — the worker starts, the host reads config, and only then does it surface the issue in a production log. Common problems that slip through:
- Missing dependencies —
azure-functionsnot inrequirements.txt, discovered only at cold start - Invalid configuration —
host.jsonmisconfigured,extensionBundlemissing or outdated - Runtime incompatibilities — Python version mismatch with Azure Functions runtime
- Silent failures — no virtual environment, Core Tools not installed, Application Insights key missing
azure-functions-doctor moves that failure left — catch it locally or in CI, not in production.
- 14+ diagnostic checks — Python version, dependencies, host.json, Core Tools, Durable Functions, and more
- Multiple output formats — table, JSON, SARIF, JUnit for CI integration
- Profile support —
minimalorfullrulesets depending on your needs - Official GitHub Action —
yeongseon/azure-functions-doctor@v1for CI gates
This repository targets the decorator-based Azure Functions Python v2 programming model only.
- Supported model:
func.FunctionApp()with decorators such as@app.route() - Unsupported model: legacy
function.json-based Python v1 projects
Use azure-functions-doctor as part of a pre-deployment checklist alongside azure-functions-logging for observability.
This package does not own:
- Fixing issues — it diagnoses configuration problems but does not auto-fix them
- API documentation — use
azure-functions-openapifor API documentation and spec generation - Request validation — use
azure-functions-validationfor request/response validation and serialization
From PyPI:
pip install azure-functions-doctorFrom source:
git clone https://github.com/yeongseon/azure-functions-doctor.git
cd azure-functions-doctor
python3 -m venv .venv
source .venv/bin/activate
pip install -e .Run the doctor in the current project:
azure-functions doctorRun against a specific project:
azure-functions doctor --path ./examples/v2/http-triggerUse a required-only profile:
azure-functions doctor --profile minimalOutput JSON for CI:
azure-functions doctor --format jsonazure-functions-doctor doctor --path ./examples/v2/http-triggerAzure Functions Doctor
Path: ./examples/v2/http-trigger
Programming Model
[✓] Programming model v2: Keyword '@app.|@bp.' found in source code (AST)
Python Env
[✓] Python version: Python 3.10.12 (>=3.10)
[✓] requirements.txt: requirements.txt exists
[✓] azure-functions package: Package 'azure-functions' declared in requirements.txt
Project Structure
[✓] host.json: host.json exists
[✓] host.json version: host.json version is "2.0"
Tooling
[✓] Azure Functions Core Tools (func): func detected
...
Doctor summary:
0 fails, 5 warnings, 15 passed
Exit code: 0
The same command runs in CI pipelines — see CI Integration below and docs/deployment.md for details.
Use azure-functions-doctor as a CI gate to block deployments on required failures.
- name: Run azure-functions-doctor
run: |
pip install azure-functions-doctor
azure-functions doctor --profile minimal --format json --output doctor.json
- name: Upload report
if: always()
uses: actions/upload-artifact@v4
with:
name: doctor-report
path: doctor.json- uses: yeongseon/azure-functions-doctor@v1
with:
path: .
profile: minimal
format: sarif
output: doctor.sarif
upload-sarif: "true"See docs/examples/ci_integration.md for Azure DevOps, pre-commit, VS Code, and SARIF upload examples.
The demo below is generated from demo/doctor-demo.tape with VHS.
It runs the real azure-functions doctor CLI against the representative example
and then against an intentionally broken copy to show the pass/fail contrast.
The final terminal state is also captured as a static image for quick inspection.
The default ruleset includes checks for:
- Azure Functions Python v2 decorator usage
- Python version
- virtual environment activation
- Python executable availability
requirements.txtazure-functionsdependency declarationhost.jsonlocal.settings.json(optional)- Azure Functions Core Tools presence and version (optional)
- Durable Functions host configuration (optional)
- Application Insights configuration (optional)
extensionBundleconfiguration (optional)- ASGI/WSGI callable exposure (optional)
- common unwanted files in the project tree (optional)
- Python 3.10+
- Hatch for development workflows
- Azure Functions Core Tools v4+ recommended for local runs
- Before deploying an Azure Functions app (local pre-flight check)
- In CI/CD pipelines as a deployment gate
- When onboarding a new developer to catch environment setup issues
- After upgrading Python version or Azure Functions runtime
- As a pre-commit hook for configuration validation
- docs/index.md
- docs/usage.md
- docs/rules.md
- docs/diagnostics.md
- docs/development.md
- docs/examples/ci_integration.md
This package is part of the Azure Functions Python DX Toolkit.
Design principle: azure-functions-doctor owns pre-deploy diagnostics. It does not fix issues or generate code — it surfaces actionable findings so developers can fix them. Runtime behavior belongs to azure-functions-openapi (API documentation and spec generation), azure-functions-validation (request/response validation), and azure-functions-langgraph (LangGraph runtime exposure).
| Package | Role |
|---|---|
| azure-functions-openapi | OpenAPI spec generation and Swagger UI |
| azure-functions-validation | Request/response validation and serialization |
| azure-functions-db | Database bindings for SQL, PostgreSQL, MySQL, SQLite, and Cosmos DB |
| azure-functions-langgraph | LangGraph deployment adapter for Azure Functions |
| azure-functions-scaffold | Project scaffolding CLI |
| azure-functions-logging | Structured logging and observability |
| azure-functions-doctor | Pre-deploy diagnostic CLI |
| azure-functions-durable-graph | Manifest-first graph runtime with Durable Functions (experimental) |
| azure-functions-python-cookbook | Recipes and examples |
This repository includes llms.txt and llms-full.txt for LLM-friendly documentation:
llms.txt— Concise index of package info, CLI commands, quick start, and ecosystem overviewllms-full.txt— Comprehensive API reference with output formats, diagnostic rules, custom rules, and CI integration patterns
When working with this codebase, LLM assistants should:
- Use
llms.txtfor quick reference — package version (0.16.2), Python requirements (>=3.10,<3.15), CLI entry points - Refer to
llms-full.txtfor implementation details — output contracts, rule structure, custom rule patterns, handler types - Check
src/azure_functions_doctor/cli.py— authoritative source for CLI options and validation - Review
src/azure_functions_doctor/assets/rules/v2.json— complete ruleset with check definitions - Consult
src/azure_functions_doctor/handlers.py— diagnostic rule handlers and pattern matchers
For bug reports, feature requests, or documentation improvements, please open an issue or pull request on GitHub.
This project is an independent community project and is not affiliated with, endorsed by, or maintained by Microsoft.
Azure and Azure Functions are trademarks of Microsoft Corporation.
MIT

