# 部署管道 — moziplus v2.0 # # 触发条件: # - push 到 main 分支 # # Gitea v1.23.4 限制注意: # - 不支持 failure() 表达式 # - 不支持 concurrency / permissions # - 部署脚本 scripts/deploy.sh,支持 --version/--rollback/--health-check name: Deploy on: push: branches: [main] jobs: # ── Job 1: CI(main 分支跑完整测试)───────────────── ci: runs-on: macos-arm64 steps: - uses: actions/checkout@v4 - name: Setup Python run: | python3 -m venv /tmp/ci-venv-deploy /tmp/ci-venv-deploy/bin/pip install --quiet flake8 fastapi pydantic pyyaml uvicorn requests pytest pytest-asyncio httpx - name: Lint run: | /tmp/ci-venv-deploy/bin/flake8 src/ --max-line-length=120 --extend-ignore=E501 - name: Unit & Integration Tests run: | /tmp/ci-venv-deploy/bin/pytest tests/ -m "not e2e" -x -q # ── Job 2: 部署 ───────────────────────────────────── deploy: runs-on: macos-arm64 needs: ci steps: - uses: actions/checkout@v4 - name: Record current version run: | bash scripts/deploy.sh --version || echo "No deploy history yet" - name: Deploy run: | bash scripts/deploy.sh --source="$GITHUB_WORKSPACE" --target="$HOME/.sanguo_projects/sanguo_moziplus_v2" --health-check # 回滚由 notify-deploy-failure job 检测失败后通知人工介入 # ── Job 3: 部署失败通知 ────────────────────────────── notify-deploy-failure: runs-on: macos-arm64 needs: [ci, deploy] if: always() steps: - name: Check deploy result and notify env: GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }} run: | STATUS=$(curl -sf \ -H "Authorization: token $GITEA_TOKEN" \ "${{ gitea.api_url }}/repos/${{ gitea.repository }}/commits/${{ gitea.sha }}/status" \ | python3 -c "import sys,json; print(json.load(sys.stdin).get('state',''))" 2>/dev/null || echo "") echo "Deploy status: $STATUS" if [ "$STATUS" != "success" ]; then echo "Deploy failed, creating Issue for manual intervention..." # 创建 Issue 通知人工介入 curl -sf -X POST \ -H "Authorization: token $GITEA_TOKEN" \ -H "Content-Type: application/json" \ "${{ gitea.api_url }}/repos/${{ gitea.repository }}/issues" \ -d "{\"title\": \"🔴 部署失败: commit ${{ gitea.sha }}\", \"body\": \"部署失败,需人工介入排查。\\n\\n触发 commit: \`${{ gitea.sha }}\`\\n分支: main\\n\\n请检查 deploy 日志并手动处理。\", \"labels\": [\"bug\", \"priority:high\"]}" \ || echo "Failed to create issue" echo "Issue created for deploy failure." else echo "Deploy succeeded." fi