{"id":48992575,"url":"https://github.com/yeongseon/azure-functions-doctor-python","last_synced_at":"2026-04-26T14:01:30.602Z","repository":{"id":295620598,"uuid":"990435418","full_name":"yeongseon/azure-functions-doctor-python","owner":"yeongseon","description":"Pre-deploy diagnostic CLI for Azure Functions Python v2 — Part of the Azure Functions Python DX Toolkit","archived":false,"fork":false,"pushed_at":"2026-04-26T12:24:02.000Z","size":48046,"stargazers_count":19,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-04-26T13:12:32.076Z","etag":null,"topics":["azure","azure-functions","cli","diagnostics","dx-toolkit","python","serverless"],"latest_commit_sha":null,"homepage":"https://yeongseon.github.io/azure-functions-doctor-python/","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/yeongseon.png","metadata":{"files":{"readme":"README.ja.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":"SUPPORT.md","governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":"AGENTS.md","dco":null,"cla":null}},"created_at":"2025-05-26T05:43:53.000Z","updated_at":"2026-04-26T12:19:28.000Z","dependencies_parsed_at":"2025-09-06T13:08:32.981Z","dependency_job_id":"ef19bfe4-513f-4acc-a4cd-f409a7e10ea5","html_url":"https://github.com/yeongseon/azure-functions-doctor-python","commit_stats":null,"previous_names":["yeongseon/azure-functions-doctor","yeongseon/azure-functions-doctor-for-python","yeongseon/azure-functions-doctor-python"],"tags_count":32,"template":false,"template_full_name":null,"purl":"pkg:github/yeongseon/azure-functions-doctor-python","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yeongseon%2Fazure-functions-doctor-python","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yeongseon%2Fazure-functions-doctor-python/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yeongseon%2Fazure-functions-doctor-python/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yeongseon%2Fazure-functions-doctor-python/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/yeongseon","download_url":"https://codeload.github.com/yeongseon/azure-functions-doctor-python/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yeongseon%2Fazure-functions-doctor-python/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":32299644,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-26T09:34:17.070Z","status":"ssl_error","status_checked_at":"2026-04-26T09:34:00.993Z","response_time":129,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["azure","azure-functions","cli","diagnostics","dx-toolkit","python","serverless"],"created_at":"2026-04-18T15:04:06.859Z","updated_at":"2026-04-26T14:01:30.590Z","avatar_url":"https://github.com/yeongseon.png","language":"Python","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Azure Functions Doctor\n\n[![PyPI](https://img.shields.io/pypi/v/azure-functions-doctor.svg)](https://pypi.org/project/azure-functions-doctor/)\n[![Python Version](https://img.shields.io/badge/python-3.10%20%7C%203.11%20%7C%203.12%20%7C%203.13%20%7C%203.14-blue)](https://pypi.org/project/azure-functions-doctor/)\n[![CI](https://github.com/yeongseon/azure-functions-doctor/actions/workflows/ci-test.yml/badge.svg)](https://github.com/yeongseon/azure-functions-doctor/actions/workflows/ci-test.yml)\n[![Release](https://github.com/yeongseon/azure-functions-doctor/actions/workflows/release.yml/badge.svg)](https://github.com/yeongseon/azure-functions-doctor/actions/workflows/release.yml)\n[![Security Scans](https://github.com/yeongseon/azure-functions-doctor/actions/workflows/security.yml/badge.svg)](https://github.com/yeongseon/azure-functions-doctor/actions/workflows/security.yml)\n[![codecov](https://codecov.io/gh/yeongseon/azure-functions-doctor/branch/main/graph/badge.svg)](https://codecov.io/gh/yeongseon/azure-functions-doctor)\n[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit)](https://pre-commit.com/)\n[![Docs](https://img.shields.io/badge/docs-gh--pages-blue)](https://yeongseon.github.io/azure-functions-doctor/)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](LICENSE)\n\n他の言語: [English](README.md) | [한국어](README.ko.md) | [简体中文](README.zh-CN.md)\n\nAzure Functions Doctor は、**Azure Functions Python v2 プログラミングモデル**で構築されたプロジェクトのための診断 CLI ツールです。\n\nこのツールは、ローカルプロジェクトにおける以下のような一般的な問題をチェックします：\n\n- サポートされていない Python バージョン\n- `host.json` または `requirements.txt` の欠如\n- `azure-functions` 依存関係の欠如\n- 仮想環境（virtual environments）の欠如\n- Azure Functions Core Tools の欠如\n- 不完全なローカル開発環境のセットアップ\n\n## Why Use It\n\nAzure Functions Python プロジェクトのセットアップには、複数の設定ファイル、依存関係、ツールが必要です。いずれか一つでも欠けると、分かりにくいランタイムエラーが発生します。`azure-functions-doctor` は厳選されたルールセットに基づいてプロジェクトをチェックし、問題が本番環境に到達する前に報告します。\n\n## Scope\n\nこのリポジトリは、デコレータベースの Azure Functions Python v2 プログラミングモデルのみを対象としています。\n\n- サポートされているモデル: `@app.route()` などのデコレータを使用した `func.FunctionApp()`\n- サポートされていないモデル: 従来の `function.json` ベースの Python v1 プロジェクト\n\n## Installation\n\nPyPI からインストール：\n\n```bash\npip install azure-functions-doctor\n```\n\nソースからインストール：\n\n```bash\ngit clone https://github.com/yeongseon/azure-functions-doctor.git\ncd azure-functions-doctor\npython3 -m venv .venv\nsource .venv/bin/activate\npip install -e .\n```\n\n## Quick Start\n\n現在のプロジェクトで doctor を実行：\n\n```bash\nazure-functions doctor\n```\n\n特定のプロジェクトパスを指定して実行：\n\n```bash\nazure-functions doctor --path ./examples/v2/http-trigger\n```\n\n必須項目のみをチェックするプロファイルを使用：\n\n```bash\nazure-functions doctor --profile minimal\n```\n\nCI 用に JSON 形式で出力：\n\n```bash\nazure-functions doctor --format json\n```\n\n## Demo\n\n以下のデモは、VHS を使用して [`demo/doctor-demo.tape`](demo/doctor-demo.tape) から生成されました。\n代表的なサンプルプロジェクトと、意図的にエラーを発生させたコピーに対して実際の `azure-functions doctor` CLI を実行し、成功と失敗の対比を示しています。\n\n![Doctor demo](docs/assets/doctor-demo.gif)\n\n最終的なターミナルの状態は、素早く確認できるように静止画像としてもキャプチャされています。\n\n![Doctor final output](docs/assets/doctor-demo-final.png)\n\n## Features\n\nデフォルトのルールセットは以下を検証します：\n\n- Azure Functions Python v2 デコレータの使用\n- Python バージョン\n- 仮想環境の有効化\n- Python 実行ファイルの利用可能性\n- `requirements.txt`\n- `azure-functions` 依存関係の宣言\n- `host.json`\n- `local.settings.json`（オプション）\n- Azure Functions Core Tools の存在とバージョン（オプション）\n- Durable Functions ホスト設定（オプション）\n- Application Insights 設定（オプション）\n- `extensionBundle` 設定（オプション）\n- ASGI/WSGI callable の公開（オプション）\n- プロジェクトツリー内の一般的な不要ファイル（オプション）\n\n## Examples\n\n- [examples/v2/http-trigger/README.md](examples/v2/http-trigger/README.md)\n- [examples/v2/multi-trigger/README.md](examples/v2/multi-trigger/README.md)\n\n## Requirements\n\n- Python 3.10+\n- 開発ワークフローのための Hatch\n- ローカル実行のために Azure Functions Core Tools v4+ を推奨\n\n## Documentation\n\n- [docs/index.md](docs/index.md)\n- [docs/usage.md](docs/usage.md)\n- [docs/rules.md](docs/rules.md)\n- [docs/diagnostics.md](docs/diagnostics.md)\n- [docs/development.md](docs/development.md)\n\n## Ecosystem\n\n- [azure-functions-validation](https://github.com/yeongseon/azure-functions-validation) — リクエストとレスポンスのバリデーション\n- [azure-functions-openapi](https://github.com/yeongseon/azure-functions-openapi) — OpenAPI と Swagger UI\n- [azure-functions-langgraph](https://github.com/yeongseon/azure-functions-langgraph) — LangGraph デプロイアダプター\n- [azure-functions-logging](https://github.com/yeongseon/azure-functions-logging) — 構造化ロギング\n- [azure-functions-scaffold](https://github.com/yeongseon/azure-functions-scaffold) — プロジェクトスキャフォールディング\n- [azure-functions-durable-graph](https://github.com/yeongseon/azure-functions-durable-graph) — Durable Functions ベースのグラフランタイム *(計画中)*\n- [azure-functions-python-cookbook](https://github.com/yeongseon/azure-functions-python-cookbook) — レシピとサンプル\n\n## Disclaimer\n\nこのプロジェクトは独立したコミュニティプロジェクトであり、Microsoft と提携・承認・保守関係にはありません。\n\nAzure および Azure Functions は Microsoft Corporation の商標です。\n\n## License\n\nMIT\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyeongseon%2Fazure-functions-doctor-python","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fyeongseon%2Fazure-functions-doctor-python","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyeongseon%2Fazure-functions-doctor-python/lists"}