Merge branch 'main' of https://github.com/xerrors/Yuxi-Know #13
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| # GitHub Actions workflow for Ruff code formatting and linting | |
| # 自动运行 Ruff 格式检查和修复 | |
| # | |
| # 触发条件: | |
| # 1. Push 到 main 分支时:自动格式化并提交 | |
| # 2. Pull Request 时:检查格式并标记问题(不自动提交) | |
| name: Ruff Format Check | |
| on: | |
| push: | |
| branches: | |
| - main | |
| paths: | |
| - '**.py' | |
| - 'pyproject.toml' | |
| - 'Makefile' | |
| - '.github/workflows/ruff.yml' | |
| pull_request: | |
| branches: | |
| - main | |
| paths: | |
| - '**.py' | |
| - 'pyproject.toml' | |
| - 'Makefile' | |
| # 设置写入权限,允许自动提交格式化代码 | |
| permissions: | |
| contents: write | |
| pull-requests: write | |
| jobs: | |
| ruff: | |
| name: Ruff Format & Lint | |
| runs-on: ubuntu-latest | |
| steps: | |
| # 1. 检出代码 | |
| - name: Checkout repository | |
| uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| token: ${{ secrets.GITHUB_TOKEN }} | |
| # 2. 安装 uv(项目使用 uv 作为包管理器) | |
| - name: Install uv | |
| uses: astral-sh/setup-uv@v4 | |
| with: | |
| version: "0.7.2" | |
| # 3. 设置 Python 环境 | |
| - name: Set up Python | |
| uses: actions/setup-python@v5 | |
| with: | |
| python-version: '3.12' | |
| # 4. 安装 ruff 依赖(根据项目配置,ruff 在 dev 依赖组中) | |
| - name: Install dependencies | |
| run: | | |
| uv sync --group dev | |
| # 5. 运行 Ruff 格式检查(与项目的 make lint 命令一致) | |
| - name: Run Ruff format check | |
| id: ruff-format | |
| # PR 事件中不失败,仅报告问题;Push 事件中仍然会失败 | |
| continue-on-error: ${{ github.event_name == 'pull_request' }} | |
| run: | | |
| set +e # 不立即退出失败 | |
| echo "Running ruff check (uv run python -m ruff check .)..." | |
| uv run python -m ruff check . | |
| ruff_check_result=$? | |
| echo "Running ruff format diff check (uv run python -m ruff format src --diff)..." | |
| uv run python -m ruff format src --diff | |
| ruff_format_result=$? | |
| echo "Running import sorting check (uv run python -m ruff check --select I src)..." | |
| uv run python -m ruff check --select I src | |
| ruff_import_result=$? | |
| # 检查是否有任何错误 | |
| if [ $ruff_check_result -eq 0 ] && [ $ruff_format_result -eq 0 ] && [ $ruff_import_result -eq 0 ]; then | |
| echo "ruff_format_passed=true" >> $GITHUB_OUTPUT | |
| echo "✅ Ruff format check passed" | |
| else | |
| echo "ruff_format_passed=false" >> $GITHUB_OUTPUT | |
| echo "❌ Ruff format check failed (this is expected for PR reviews)" | |
| echo "::warning::Ruff format check found issues that should be addressed" | |
| # 汇总错误信息 | |
| echo "## Ruff Format Issues Summary" > $GITHUB_STEP_SUMMARY | |
| echo "" >> $GITHUB_STEP_SUMMARY | |
| echo "The following formatting issues were found:" >> $GITHUB_STEP_SUMMARY | |
| echo "" >> $GITHUB_STEP_SUMMARY | |
| # 运行 ruff check 以获取详细错误信息 | |
| echo "### Detailed Issues:" >> $GITHUB_STEP_SUMMARY | |
| uv run python -m ruff check . --output-format=github >> $GITHUB_STEP_SUMMARY 2>&1 || true | |
| echo "" >> $GITHUB_STEP_SUMMARY | |
| echo "To fix these issues locally, run:" >> $GITHUB_STEP_SUMMARY | |
| echo "\`\`\`bash" >> $GITHUB_STEP_SUMMARY | |
| echo "make format" >> $GITHUB_STEP_SUMMARY | |
| echo "\`\`\`" >> $GITHUB_STEP_SUMMARY | |
| fi | |
| # 6. 针对不同事件类型执行不同操作 | |
| - name: Process Ruff Results | |
| if: ${{ github.event_name == 'push' }} | |
| env: | |
| GIT_AUTHOR_NAME: "GitHub Actions" | |
| GIT_AUTHOR_EMAIL: "[email protected]" | |
| GIT_COMMITTER_NAME: "GitHub Actions" | |
| GIT_COMMITTER_EMAIL: "[email protected]" | |
| run: | | |
| echo "Processing push event to main branch..." | |
| # 检查当前是否有未提交的修改 | |
| if ! git diff --exit-code --quiet; then | |
| echo "⚠️ Warning: There are uncommitted changes before formatting" | |
| echo "The formatting process might need to handle this specially." | |
| fi | |
| # 先检查是否有格式问题 | |
| echo "Checking for formatting issues..." | |
| set +e | |
| uv run python -m ruff check . --quiet | |
| has_ruff_issues=$? | |
| set -e | |
| if [ $has_ruff_issues -eq 0 ]; then | |
| echo "✅ No formatting issues found" | |
| exit 0 | |
| fi | |
| echo "Formatting issues detected, running automatic fixes..." | |
| # 自动应用格式修复(与项目的 make format 命令一致) | |
| echo "Running uv run ruff format ." | |
| uv run ruff format . | |
| echo "Running uv run ruff check . --fix" | |
| uv run ruff check . --fix | |
| echo "Running uv run python -m ruff check --select I src --fix" | |
| uv run python -m ruff check --select I src --fix | |
| # 检查是否有格式变更 | |
| echo "Checking for formatting changes..." | |
| if git diff --exit-code --quiet; then | |
| echo "✅ No formatting changes needed" | |
| else | |
| echo "📝 Formatting changes detected" | |
| echo "Changed files:" | |
| git diff --name-only | |
| # 添加所有变更并提交 | |
| git add . | |
| git commit -m "style: auto-format with ruff [skip ci]" | |
| echo "📤 Pushing formatting changes..." | |
| git push | |
| echo "✅ Formatting changes committed and pushed" | |
| fi | |
| - name: Create PR Comment with Format Issues | |
| if: ${{ github.event_name == 'pull_request' && steps.ruff-format.outputs.ruff_format_passed == 'false' }} | |
| uses: actions/github-script@v7 | |
| with: | |
| github-token: ${{ secrets.GITHUB_TOKEN }} | |
| script: | | |
| const issue_number = context.issue.number; | |
| const repo = context.repo; | |
| // 获取工作流运行 ID 以链接到特定的检查运行 | |
| const run_id = process.env.GITHUB_RUN_ID; | |
| const run_url = `https://github.com/${repo.owner}/${repo.repo}/actions/runs/${run_id}`; | |
| const commentBody = `## 📋 Ruff Format Review | |
| The Ruff format check found some issues in this pull request. **This does not block the PR** - it's just a review of code style: | |
| 🔍 **Issues found**: | |
| - Unused imports | |
| - Line length violations (>120 characters) | |
| - Import sorting issues | |
| ⚙️ **To fix these issues locally**: | |
| \`\`\`bash | |
| # Run automatic formatting (same as make format) | |
| make format | |
| # Or manually with uv: | |
| uv run ruff format . | |
| uv run ruff check . --fix | |
| uv run python -m ruff check --select I src --fix | |
| \`\`\` | |
| 📝 **To just check without fixing**: | |
| \`\`\`bash | |
| make lint | |
| \`\`\` | |
| 🔗 **View detailed linting output**: [Ruff Check Run #${run_id}](${run_url}) | |
| --- | |
| *Note: This is an automated review for code formatting consistency. The PR can still be merged even with these formatting issues.*`; | |
| // 先尝试更新已有的评论(如果存在) | |
| try { | |
| const comments = await github.rest.issues.listComments({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| issue_number: issue_number, | |
| }); | |
| const botComment = comments.data.find(comment => | |
| comment.user.login.includes('github-actions') || | |
| comment.body.includes('Ruff Format Review') | |
| ); | |
| if (botComment) { | |
| await github.rest.issues.updateComment({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| comment_id: botComment.id, | |
| body: commentBody | |
| }); | |
| console.log("✅ Updated existing comment"); | |
| } else { | |
| await github.rest.issues.createComment({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| issue_number: issue_number, | |
| body: commentBody | |
| }); | |
| console.log("✅ Created new comment"); | |
| } | |
| } catch (error) { | |
| console.error("Error managing comment:", error); | |
| // 如果出错,仍然尝试创建新评论 | |
| await github.rest.issues.createComment({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| issue_number: issue_number, | |
| body: commentBody | |
| }); | |
| } | |
| - name: Create PR Comment on Success | |
| if: ${{ github.event_name == 'pull_request' && steps.ruff-format.outputs.ruff_format_passed == 'true' }} | |
| uses: actions/github-script@v7 | |
| with: | |
| github-token: ${{ secrets.GITHUB_TOKEN }} | |
| script: | | |
| const issue_number = context.issue.number; | |
| const repo = context.repo; | |
| const commentBody = `## ✅ Ruff Format Review Passed | |
| ✅ **All Python files follow the project's formatting standards!** | |
| Great work maintaining code consistency! 🎉 | |
| --- | |
| *Note: This is an automated review for code formatting. Your code follows the project's Ruff configuration.*`; | |
| // 清理可能存在的失败评论(如果之前有失败,现在修复了) | |
| try { | |
| const comments = await github.rest.issues.listComments({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| issue_number: issue_number, | |
| }); | |
| const botComment = comments.data.find(comment => | |
| comment.user.login.includes('github-actions') || | |
| comment.body.includes('Ruff Format Review') | |
| ); | |
| if (botComment) { | |
| await github.rest.issues.updateComment({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| comment_id: botComment.id, | |
| body: commentBody | |
| }); | |
| console.log("✅ Updated existing comment"); | |
| } else { | |
| await github.rest.issues.createComment({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| issue_number: issue_number, | |
| body: commentBody | |
| }); | |
| console.log("✅ Created new comment"); | |
| } | |
| } catch (error) { | |
| console.error("Error managing comment:", error); | |
| await github.rest.issues.createComment({ | |
| owner: repo.owner, | |
| repo: repo.repo, | |
| issue_number: issue_number, | |
| body: commentBody | |
| }); | |
| } |